mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-28 06:56:16 +01:00
Merge branch 'uri-double-slash-path' into 'main'
guri: Fix paths starting with ‘//’ when parsing See merge request GNOME/glib!4407
This commit is contained in:
commit
fcc0e4d556
12
glib/guri.c
12
glib/guri.c
@ -1535,6 +1535,18 @@ g_uri_parse_relative (GUri *base_uri,
|
|||||||
remove_dot_segments (uri->path);
|
remove_dot_segments (uri->path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Fix up the invalid cases from
|
||||||
|
* https://datatracker.ietf.org/doc/html/rfc3986#section-3, as otherwise
|
||||||
|
* calling g_uri_to_string() on this URI will fail. These can be caused by
|
||||||
|
* remove_dot_segments(), e.g. `data:/.//` gets normalised to `data://` whose
|
||||||
|
* path is invalid given the lack of an authority. */
|
||||||
|
if (uri->host == NULL && uri->path[0] == '/' && uri->path[1] == '/')
|
||||||
|
{
|
||||||
|
char *new_path = g_strconcat ("/.", uri->path, NULL);
|
||||||
|
g_free (uri->path);
|
||||||
|
uri->path = g_steal_pointer (&new_path);
|
||||||
|
}
|
||||||
|
|
||||||
return g_steal_pointer (&uri);
|
return g_steal_pointer (&uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -769,6 +769,18 @@ static const UriAbsoluteTest absolute_tests[] = {
|
|||||||
/* Invalid IDN hostname */
|
/* Invalid IDN hostname */
|
||||||
{ "http://xn--mixed-\xc3\xbcp/", G_URI_FLAGS_NONE, FALSE, G_URI_ERROR_BAD_HOST,
|
{ "http://xn--mixed-\xc3\xbcp/", G_URI_FLAGS_NONE, FALSE, G_URI_ERROR_BAD_HOST,
|
||||||
{ NULL, NULL, NULL, -1, NULL, NULL, NULL } },
|
{ NULL, NULL, NULL, -1, NULL, NULL, NULL } },
|
||||||
|
|
||||||
|
/* Paths with double slashes */
|
||||||
|
{ "data:.///",
|
||||||
|
G_URI_FLAGS_HAS_PASSWORD | G_URI_FLAGS_ENCODED_PATH | G_URI_FLAGS_ENCODED_QUERY | G_URI_FLAGS_ENCODED_FRAGMENT | G_URI_FLAGS_SCHEME_NORMALIZE,
|
||||||
|
TRUE, 0,
|
||||||
|
{ "data", NULL, NULL, -1, "/.//", NULL, NULL }
|
||||||
|
},
|
||||||
|
{ "data:/.//",
|
||||||
|
G_URI_FLAGS_HAS_PASSWORD | G_URI_FLAGS_ENCODED_PATH | G_URI_FLAGS_ENCODED_QUERY | G_URI_FLAGS_ENCODED_FRAGMENT | G_URI_FLAGS_SCHEME_NORMALIZE,
|
||||||
|
TRUE, 0,
|
||||||
|
{ "data", NULL, NULL, -1, "/.//", NULL, NULL }
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -1743,6 +1755,19 @@ test_uri_join (void)
|
|||||||
uri = g_uri_join (G_URI_FLAGS_NONE, "scheme", NULL, "foo:bar._webdav._tcp.local", -1, "", NULL, NULL);
|
uri = g_uri_join (G_URI_FLAGS_NONE, "scheme", NULL, "foo:bar._webdav._tcp.local", -1, "", NULL, NULL);
|
||||||
g_assert_cmpstr (uri, ==, "scheme://foo%3Abar._webdav._tcp.local");
|
g_assert_cmpstr (uri, ==, "scheme://foo%3Abar._webdav._tcp.local");
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
|
|
||||||
|
uri = g_uri_join (G_URI_FLAGS_NONE, "data", NULL, NULL, -1, "/.//", NULL, NULL);
|
||||||
|
g_assert_cmpstr (uri, ==, "data:/.//");
|
||||||
|
g_free (uri);
|
||||||
|
|
||||||
|
uri = g_uri_join (G_URI_FLAGS_NONE, "data", NULL, NULL, -1, ".///", NULL, NULL);
|
||||||
|
g_assert_cmpstr (uri, ==, "data:.///");
|
||||||
|
g_free (uri);
|
||||||
|
|
||||||
|
/* From https://url.spec.whatwg.org/#url-serializing */
|
||||||
|
uri = g_uri_join (G_URI_FLAGS_NONE, "web+demo", NULL, NULL, -1, "/.//not-a-host/", NULL, NULL);
|
||||||
|
g_assert_cmpstr (uri, ==, "web+demo:/.//not-a-host/");
|
||||||
|
g_free (uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user