mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-11 23:16:14 +01:00
Add some uri list tests.c.
2004-10-22 Matthias Clasen <mclasen@redhat.com> * tests/uri-test.c (run_uri_list_tests): Add some uri list tests.c. * glib/gconvert.h: * glib/gconvert.c (g_uri_list_extract_uris): New function to split a text/uri-list data into individual uris and strip comments.
This commit is contained in:
parent
e96fe301fa
commit
8df27c8dd5
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* tests/uri-test.c (run_uri_list_tests): Add some
|
||||||
|
uri list tests.c.
|
||||||
|
|
||||||
|
* glib/gconvert.h:
|
||||||
|
* glib/gconvert.c (g_uri_list_extract_uris): New function to
|
||||||
|
split a text/uri-list data into individual uris and strip comments.
|
||||||
|
|
||||||
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/goption.c (get_change): Don't return the wrong
|
* glib/goption.c (get_change): Don't return the wrong
|
||||||
|
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* tests/uri-test.c (run_uri_list_tests): Add some
|
||||||
|
uri list tests.c.
|
||||||
|
|
||||||
|
* glib/gconvert.h:
|
||||||
|
* glib/gconvert.c (g_uri_list_extract_uris): New function to
|
||||||
|
split a text/uri-list data into individual uris and strip comments.
|
||||||
|
|
||||||
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/goption.c (get_change): Don't return the wrong
|
* glib/goption.c (get_change): Don't return the wrong
|
||||||
|
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* tests/uri-test.c (run_uri_list_tests): Add some
|
||||||
|
uri list tests.c.
|
||||||
|
|
||||||
|
* glib/gconvert.h:
|
||||||
|
* glib/gconvert.c (g_uri_list_extract_uris): New function to
|
||||||
|
split a text/uri-list data into individual uris and strip comments.
|
||||||
|
|
||||||
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/goption.c (get_change): Don't return the wrong
|
* glib/goption.c (get_change): Don't return the wrong
|
||||||
|
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* tests/uri-test.c (run_uri_list_tests): Add some
|
||||||
|
uri list tests.c.
|
||||||
|
|
||||||
|
* glib/gconvert.h:
|
||||||
|
* glib/gconvert.c (g_uri_list_extract_uris): New function to
|
||||||
|
split a text/uri-list data into individual uris and strip comments.
|
||||||
|
|
||||||
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/goption.c (get_change): Don't return the wrong
|
* glib/goption.c (get_change): Don't return the wrong
|
||||||
|
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-22 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
|
* tests/uri-test.c (run_uri_list_tests): Add some
|
||||||
|
uri list tests.c.
|
||||||
|
|
||||||
|
* glib/gconvert.h:
|
||||||
|
* glib/gconvert.c (g_uri_list_extract_uris): New function to
|
||||||
|
split a text/uri-list data into individual uris and strip comments.
|
||||||
|
|
||||||
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
2004-10-20 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* glib/goption.c (get_change): Don't return the wrong
|
* glib/goption.c (get_change): Don't return the wrong
|
||||||
|
@ -1644,3 +1644,76 @@ g_filename_to_uri (const gchar *filename,
|
|||||||
|
|
||||||
return escaped_uri;
|
return escaped_uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_uri_list_extract_uris:
|
||||||
|
* @uri_list: an URI list
|
||||||
|
*
|
||||||
|
* Splits an URI list conforming to the text/uri-list
|
||||||
|
* mime type defined in RFC 2483 into individual URIs,
|
||||||
|
* discarding any comments. The URIs are not validated.
|
||||||
|
*
|
||||||
|
* Returns: a newly allocated %NULL-terminated list of
|
||||||
|
* strings holding the individual URIs. The array should
|
||||||
|
* be freed with g_strfreev().
|
||||||
|
*
|
||||||
|
* Since: 2.6
|
||||||
|
*/
|
||||||
|
gchar **
|
||||||
|
g_uri_list_extract_uris (const gchar *uri_list)
|
||||||
|
{
|
||||||
|
GSList *uris, *u;
|
||||||
|
const gchar *p, *q;
|
||||||
|
gchar **result;
|
||||||
|
gint n_uris = 0;
|
||||||
|
|
||||||
|
uris = NULL;
|
||||||
|
|
||||||
|
p = uri_list;
|
||||||
|
|
||||||
|
/* We don't actually try to validate the URI according to RFC
|
||||||
|
* 2396, or even check for allowed characters - we just ignore
|
||||||
|
* comments and trim whitespace off the ends. We also
|
||||||
|
* allow LF delimination as well as the specified CRLF.
|
||||||
|
*
|
||||||
|
* We do allow comments like specified in RFC 2483.
|
||||||
|
*/
|
||||||
|
while (p)
|
||||||
|
{
|
||||||
|
if (*p != '#')
|
||||||
|
{
|
||||||
|
while (g_ascii_isspace (*p))
|
||||||
|
p++;
|
||||||
|
|
||||||
|
q = p;
|
||||||
|
while (*q && (*q != '\n') && (*q != '\r'))
|
||||||
|
q++;
|
||||||
|
|
||||||
|
if (q > p)
|
||||||
|
{
|
||||||
|
q--;
|
||||||
|
while (q > p && g_ascii_isspace (*q))
|
||||||
|
q--;
|
||||||
|
|
||||||
|
if (q > p)
|
||||||
|
{
|
||||||
|
uris = g_slist_prepend (uris, g_strndup (p, q - p + 1));
|
||||||
|
n_uris++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p = strchr (p, '\n');
|
||||||
|
if (p)
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = g_new (gchar *, n_uris + 1);
|
||||||
|
|
||||||
|
result[n_uris--] = 0;
|
||||||
|
for (u = uris; u; u = u->next)
|
||||||
|
result[n_uris--] = u->data;
|
||||||
|
|
||||||
|
g_slist_free (uris);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
@ -117,6 +117,7 @@ gchar *g_filename_to_uri (const gchar *filename,
|
|||||||
const gchar *hostname,
|
const gchar *hostname,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
|
gchar **g_uri_list_extract_uris (const gchar *uri_list);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
|
@ -352,9 +352,9 @@ run_roundtrip_tests (void)
|
|||||||
|
|
||||||
if (safe_strcmp (to_uri_tests[i].filename, res))
|
if (safe_strcmp (to_uri_tests[i].filename, res))
|
||||||
{
|
{
|
||||||
g_message ("roundtrip test %d failed, filename modified: "
|
g_print ("roundtrip test %d failed, filename modified: "
|
||||||
" expected \"%s\", but got \"%s\"\n",
|
" expected \"%s\", but got \"%s\"\n",
|
||||||
i, to_uri_tests[i].filename, res);
|
i, to_uri_tests[i].filename, res);
|
||||||
any_failed = TRUE;
|
any_failed = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -372,6 +372,58 @@ run_roundtrip_tests (void)
|
|||||||
g_print ("\n");
|
g_print ("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
run_uri_list_tests (void)
|
||||||
|
{
|
||||||
|
/* straight from the RFC */
|
||||||
|
gchar *list =
|
||||||
|
"# urn:isbn:0-201-08372-8\r\n"
|
||||||
|
"http://www.huh.org/books/foo.html\r\n"
|
||||||
|
"http://www.huh.org/books/foo.pdf \r\n"
|
||||||
|
" ftp://ftp.foo.org/books/foo.txt\r\n";
|
||||||
|
gchar *expected_uris[] = {
|
||||||
|
"http://www.huh.org/books/foo.html",
|
||||||
|
"http://www.huh.org/books/foo.pdf",
|
||||||
|
"ftp://ftp.foo.org/books/foo.txt"
|
||||||
|
};
|
||||||
|
|
||||||
|
gchar **uris;
|
||||||
|
gint j;
|
||||||
|
|
||||||
|
uris = g_uri_list_extract_uris (list);
|
||||||
|
|
||||||
|
if (g_strv_length (uris) != 3)
|
||||||
|
{
|
||||||
|
g_print ("uri list test failed: "
|
||||||
|
" expected %d uris, but got %d\n",
|
||||||
|
3, g_strv_length (uris));
|
||||||
|
any_failed = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (j = 0; j < 3; j++)
|
||||||
|
{
|
||||||
|
if (safe_strcmp (uris[j], expected_uris[j]))
|
||||||
|
{
|
||||||
|
g_print ("uri list test failed: "
|
||||||
|
" expected \"%s\", but got \"%s\"\n",
|
||||||
|
expected_uris[j], uris[j]);
|
||||||
|
any_failed = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
g_strfreev (uris);
|
||||||
|
|
||||||
|
uris = g_uri_list_extract_uris ("# just hot air\r\n# more hot air");
|
||||||
|
if (g_strv_length (uris) != 0)
|
||||||
|
{
|
||||||
|
g_print ("uri list test 2 failed: "
|
||||||
|
" expected %d uris, but got %d (first is \"%s\")\n",
|
||||||
|
0, g_strv_length (uris), uris[0]);
|
||||||
|
any_failed = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc,
|
main (int argc,
|
||||||
char *argv[])
|
char *argv[])
|
||||||
@ -390,6 +442,7 @@ main (int argc,
|
|||||||
run_to_uri_tests ();
|
run_to_uri_tests ();
|
||||||
run_from_uri_tests ();
|
run_from_uri_tests ();
|
||||||
run_roundtrip_tests ();
|
run_roundtrip_tests ();
|
||||||
|
run_uri_list_tests ();
|
||||||
|
|
||||||
return any_failed ? 1 : 0;
|
return any_failed ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user