guri: Various minor documentation tweaks and improvements

Signed-off-by: Philip Withnall <withnall@endlessm.com>
This commit is contained in:
Philip Withnall 2020-08-06 13:53:31 +01:00
parent 602b7cca33
commit ff60d2ebf5
2 changed files with 267 additions and 170 deletions

View File

@ -34,16 +34,49 @@
* their components, and build valid URIs from individual components. * their components, and build valid URIs from individual components.
* *
* Note that #GUri scope is to help manipulate URIs in various applications, * Note that #GUri scope is to help manipulate URIs in various applications,
* following the RFC 3986. In particular, it doesn't intend to cover web browser * following [RFC 3986](https://tools.ietf.org/html/rfc3986). In particular,
* needs, and doesn't implement the WHATWG URL standard. No APIs are provided to * it doesn't intend to cover web browser needs, and doesn't implement the
* help prevent homograph attacks. * [WHATWG URL](https://url.spec.whatwg.org/) standard. No APIs are provided to
* help prevent
* [homograph attacks](https://en.wikipedia.org/wiki/IDN_homograph_attack), so
* #GUri is not suitable for formatting URIs for display to the user for making
* security-sensitive decisions.
*
* ## Relative and absolute URIs # {#relative-absolute-uris}
*
* As defined in [RFC 3986](https://tools.ietf.org/html/rfc3986#section-4), the
* hierarchical nature of URIs means that they can either be relative
* references (sometimes referred to as relative URIs) or URIs (for
* clarity, URIs are referred to in this documentation as
* absolute URIs although
* [in constrast to RFC 3986](https://tools.ietf.org/html/rfc3986#section-4.3),
* fragment identifiers are always allowed).
*
* Relative references have one or more components of the URI missing. In
* particular, they have no scheme. Any other component, such as hostname,
* query, etc. may be missing, apart from a path, which has to be specified (but
* may be empty). The path may be relative, starting with `./` rather than `/`.
*
* For example, a valid relative reference is `./path?query`,
* `/?query#fragment` or `//example.com`.
*
* Absolute URIs have a scheme specified. Any other components of the URI which
* are missing are specified as explicitly unset in the URI, rather than being
* resolved relative to a base URI using g_uri_parse_relative().
*
* For example, a valid absolute URI is `file:///home/bob` or
* `https://search.com?query=string`.
*
* A #GUri instance is always an absolute URI. A string may be an absolute URI
* or a relative reference; see the documentation for individual functions as to
* what forms they accept.
* *
* ## Parsing URIs * ## Parsing URIs
* *
* The most minimalist APIs for parsing URIs are g_uri_split() and * The most minimalist APIs for parsing URIs are g_uri_split() and
* g_uri_split_with_user(). These split a URI into its component * g_uri_split_with_user(). These split a URI into its component
* parts, and return the parts; the difference between the two is that * parts, and return the parts; the difference between the two is that
* g_uri_split() treats the "userinfo" component of the URI as a * g_uri_split() treats the userinfo component of the URI as a
* single element, while g_uri_split_with_user() can (depending on the * single element, while g_uri_split_with_user() can (depending on the
* #GUriFlags you pass) treat it as containing a username, password, * #GUriFlags you pass) treat it as containing a username, password,
* and authentication parameters. Alternatively, g_uri_split_network() * and authentication parameters. Alternatively, g_uri_split_network()
@ -68,20 +101,23 @@
* use g_uri_peek_scheme() on the URI string to check the scheme * use g_uri_peek_scheme() on the URI string to check the scheme
* first, and use that to decide what flags to parse it with. * first, and use that to decide what flags to parse it with.
* *
* For example, you might want to use %G_URI_PARAMS_WWW_FORM when parsing the
* params for a web URI, so compare the result of g_uri_peek_scheme() against
* `http` and `https`.
*
* ## Building URIs * ## Building URIs
* *
* g_uri_join() and g_uri_join_with_user() can be used to construct * g_uri_join() and g_uri_join_with_user() can be used to construct
* valid URI strings from a set of component strings; they are the * valid URI strings from a set of component strings. They are the
* inverse of g_uri_split() and g_uri_split_with_user(). * inverse of g_uri_split() and g_uri_split_with_user().
* *
* Similarly, g_uri_build() and g_uri_build_with_user() can be used to * Similarly, g_uri_build() and g_uri_build_with_user() can be used to
* construct a #GUri from a set of component strings. * construct a #GUri from a set of component strings.
* *
* As with the parsing functions, the building functions take a * As with the parsing functions, the building functions take a
* #GUriFlags argument; in particular, it is important to keep in mind * #GUriFlags argument. In particular, it is important to keep in mind
* whether the URI components you are using have `%`-encoded * whether the URI components you are using are already `%`-encoded. If so,
* characters in them or not, and pass the appropriate flags * you must pass the %G_URI_FLAGS_ENCODED flag.
* accordingly.
* *
* ## `file://` URIs * ## `file://` URIs
* *
@ -96,10 +132,10 @@
* *
* Note that there is no `g_uri_equal ()` function, because comparing * Note that there is no `g_uri_equal ()` function, because comparing
* URIs usefully requires scheme-specific knowledge that #GUri does * URIs usefully requires scheme-specific knowledge that #GUri does
* not have. For example, "`http://example.com/`" and * not have. For example, `http://example.com/` and
* "`http://EXAMPLE.COM:80`" have exactly the same meaning according * `http://EXAMPLE.COM:80` have exactly the same meaning according
* to the HTTP specification, and "`data:,foo`" and * to the HTTP specification, and `data:,foo` and
* "`data:;base64,Zm9v`" resolve to the same thing according to the * `data:;base64,Zm9v` resolve to the same thing according to the
* `data:` URI specification. * `data:` URI specification.
* *
* Since: 2.66 * Since: 2.66
@ -113,13 +149,14 @@
* Since #GUri only represents absolute URIs, all #GUris will have a * Since #GUri only represents absolute URIs, all #GUris will have a
* URI scheme, so g_uri_get_scheme() will always return a non-%NULL * URI scheme, so g_uri_get_scheme() will always return a non-%NULL
* answer. Likewise, by definition, all URIs have a path component, so * answer. Likewise, by definition, all URIs have a path component, so
* g_uri_get_path() will always return non-%NULL (though it may return * g_uri_get_path() will always return a non-%NULL string (which may be empty).
* the empty string).
* *
* If the URI string has an "authority" component (that is, if the * If the URI string has an
* scheme is followed by "`://`" rather than just "`:`"), then the * [authority component](https://tools.ietf.org/html/rfc3986#section-3) (that
* #GUri will contain a hostname, and possibly a port and "userinfo". * is, if the scheme is followed by `://` rather than just `:`), then the
* Additionally, depending on how the #GUri was constructed/parsed, * #GUri will contain a hostname, and possibly a port and userinfo.
* Additionally, depending on how the #GUri was constructed/parsed (for example,
* using the %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS flags),
* the userinfo may be split out into a username, password, and * the userinfo may be split out into a username, password, and
* additional authorization-related parameters. * additional authorization-related parameters.
* *
@ -134,14 +171,14 @@
* For example, with the encoded flag: * For example, with the encoded flag:
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GUri *uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_ENCODED, &err); * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_ENCODED, &err);
* g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue"); * g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue");
* ]| * ]|
* *
* While the default `%`-decoding behaviour would give: * While the default `%`-decoding behaviour would give:
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GUri *uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_NONE, &err); * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_NONE, &err);
* g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http://host/path?param=value"); * g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http://host/path?param=value");
* ]| * ]|
* *
@ -149,13 +186,13 @@
* with an error indicating the bad string location: * with an error indicating the bad string location:
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GUri *uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fbad%3D%00alue", G_URI_FLAGS_NONE, &err); * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fbad%3D%00alue", G_URI_FLAGS_NONE, &err);
* g_assert_error(err, G_URI_ERROR, G_URI_ERROR_BAD_QUERY); * g_assert_error (err, G_URI_ERROR, G_URI_ERROR_BAD_QUERY);
* ]| * ]|
* *
* You should pass %G_URI_FLAGS_ENCODED or %G_URI_FLAGS_ENCODED_QUERY if you * You should pass %G_URI_FLAGS_ENCODED or %G_URI_FLAGS_ENCODED_QUERY if you
* need to handle that case manually. In particular, if the query string * need to handle that case manually. In particular, if the query string
* contains '=' characters that are '%'-encoded, you should let * contains `=` characters that are `%`-encoded, you should let
* g_uri_parse_params() do the decoding once of the query. * g_uri_parse_params() do the decoding once of the query.
* *
* #GUri is immutable once constructed, and can safely be accessed from * #GUri is immutable once constructed, and can safely be accessed from
@ -847,9 +884,9 @@ g_uri_split_internal (const gchar *uri_string,
* the userinfo, or %NULL * the userinfo, or %NULL
* @host: (out) (nullable) (optional) (transfer full): on return, contains the * @host: (out) (nullable) (optional) (transfer full): on return, contains the
* host, or %NULL * host, or %NULL
* @port: (out) (nullable) (optional) (transfer full): on return, contains the * @port: (out) (optional) (transfer full): on return, contains the
* port, or -1 * port, or `-1`
* @path: (out) (nullable) (optional) (transfer full): on return, contains the * @path: (out) (not nullable) (optional) (transfer full): on return, contains the
* path * path
* @query: (out) (nullable) (optional) (transfer full): on return, contains the * @query: (out) (nullable) (optional) (transfer full): on return, contains the
* query, or %NULL * query, or %NULL
@ -857,11 +894,11 @@ g_uri_split_internal (const gchar *uri_string,
* the fragment, or %NULL * the fragment, or %NULL
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_ref (which can be an absolute or relative URI) * Parses @uri_ref (which can be an
* according to @flags, and returns the pieces. Any component that * [absolute or relative URI][relative-absolute-uris]) according to @flags, and
* doesn't appear in @uri_ref will be returned as %NULL (but note * returns the pieces. Any component that doesn't appear in @uri_ref will be
* that all URIs always have a path component, though it may be the * returned as %NULL (but note that all URIs always have a path component,
* empty string). * though it may be the empty string).
* *
* If @flags contains %G_URI_FLAGS_ENCODED, then `%`-encoded characters in * If @flags contains %G_URI_FLAGS_ENCODED, then `%`-encoded characters in
* @uri_ref will remain encoded in the output strings. (If not, * @uri_ref will remain encoded in the output strings. (If not,
@ -914,9 +951,9 @@ g_uri_split (const gchar *uri_ref,
* the auth_params, or %NULL * the auth_params, or %NULL
* @host: (out) (nullable) (optional) (transfer full): on return, contains the * @host: (out) (nullable) (optional) (transfer full): on return, contains the
* host, or %NULL * host, or %NULL
* @port: (out) (nullable) (optional) (transfer full): on return, contains the * @port: (out) (optional) (transfer full): on return, contains the
* port, or -1 * port, or `-1`
* @path: (out) (nullable) (optional) (transfer full): on return, contains the * @path: (out) (not nullable) (optional) (transfer full): on return, contains the
* path * path
* @query: (out) (nullable) (optional) (transfer full): on return, contains the * @query: (out) (nullable) (optional) (transfer full): on return, contains the
* query, or %NULL * query, or %NULL
@ -924,11 +961,11 @@ g_uri_split (const gchar *uri_ref,
* the fragment, or %NULL * the fragment, or %NULL
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_ref (which can be an absolute or relative URI) * Parses @uri_ref (which can be an
* according to @flags, and returns the pieces. Any component that * [absolute or relative URI][relative-absolute-uris]) according to @flags, and
* doesn't appear in @uri_ref will be returned as %NULL (but note * returns the pieces. Any component that doesn't appear in @uri_ref will be
* that all URIs always have a path component, though it may be the * returned as %NULL (but note that all URIs always have a path component,
* empty string). * though it may be the empty string).
* *
* See g_uri_split(), and the definition of #GUriFlags, for more * See g_uri_split(), and the definition of #GUriFlags, for more
* information on the effect of @flags. Note that @password will only * information on the effect of @flags. Note that @password will only
@ -973,12 +1010,12 @@ g_uri_split_with_user (const gchar *uri_ref,
* the scheme (converted to lowercase), or %NULL * the scheme (converted to lowercase), or %NULL
* @host: (out) (nullable) (optional) (transfer full): on return, contains the * @host: (out) (nullable) (optional) (transfer full): on return, contains the
* host, or %NULL * host, or %NULL
* @port: (out) (nullable) (optional) (transfer full): on return, contains the * @port: (out) (optional) (transfer full): on return, contains the
* port, or -1 * port, or `-1`
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_string (which must be an absolute URI) according to * Parses @uri_string (which must be an [absolute URI][relative-absolute-uris])
* @flags, and returns the pieces relevant to connecting to a host. * according to @flags, and returns the pieces relevant to connecting to a host.
* See the documentation for g_uri_split() for more details; this is * See the documentation for g_uri_split() for more details; this is
* mostly a wrapper around that function with simpler arguments. * mostly a wrapper around that function with simpler arguments.
* However, it will return an error if @uri_string is a relative URI, * However, it will return an error if @uri_string is a relative URI,
@ -1045,13 +1082,16 @@ g_uri_split_network (const gchar *uri_string,
* @flags: flags for parsing @uri_string * @flags: flags for parsing @uri_string
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_string according to @flags, to determine whether it is valid * Parses @uri_string according to @flags, to determine whether it is a valid
* absolute URI. * [absolute URI][relative-absolute-uris], i.e. it does not need to be resolved
* relative to another URI using g_uri_parse_relative().
*
* If its not a valid URI, an error is returned explaining how its invalid.
* *
* See g_uri_split(), and the definition of #GUriFlags, for more * See g_uri_split(), and the definition of #GUriFlags, for more
* information on the effect of @flags. * information on the effect of @flags.
* *
* Returns: %TRUE if @uri_string parsed successfully, %FALSE on error. * Returns: %TRUE if @uri_string is a valid absolute URI, %FALSE on error.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1136,7 +1176,8 @@ remove_dot_segments (gchar *path)
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_string according to @flags. If the result is not a * Parses @uri_string according to @flags. If the result is not a
* valid absolute URI, it will be discarded, and an error returned. * valid [absolute URI][relative-absolute-uris], it will be discarded, and an
* error returned.
* *
* Return value: (transfer full): a new #GUri. * Return value: (transfer full): a new #GUri.
* *
@ -1155,14 +1196,15 @@ g_uri_parse (const gchar *uri_string,
/** /**
* g_uri_parse_relative: * g_uri_parse_relative:
* @base_uri: (nullable): a base absolute URI * @base_uri: (nullable) (transfer none): a base absolute URI
* @uri_ref: a string representing a relative or absolute URI * @uri_ref: a string representing a relative or absolute URI
* @flags: flags describing how to parse @uri_ref * @flags: flags describing how to parse @uri_ref
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_ref according to @flags and, if it is a relative * Parses @uri_ref according to @flags and, if it is a
* URI, resolves it relative to @base_uri. If the result is not a * [relative URI][relative-absolute-uris], resolves it relative to @base_uri.
* valid absolute URI, it will be discarded, and an error returned. * If the result is not a valid absolute URI, it will be discarded, and an error
* returned.
* *
* Return value: (transfer full): a new #GUri. * Return value: (transfer full): a new #GUri.
* *
@ -1272,14 +1314,15 @@ g_uri_parse_relative (GUri *base_uri,
* @flags: flags describing how to parse @uri_ref * @flags: flags describing how to parse @uri_ref
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Parses @uri_ref according to @flags and, if it is a relative * Parses @uri_ref according to @flags and, if it is a
* URI, resolves it relative to @base_uri_string. If the result is not * [relative URI][relative-absolute-uris], resolves it relative to
* a valid absolute URI, it will be discarded, and an error returned. * @base_uri_string. If the result is not a valid absolute URI, it will be
* discarded, and an error returned.
* *
* (If @base_uri_string is %NULL, this just returns @uri_ref, or * (If @base_uri_string is %NULL, this just returns @uri_ref, or
* %NULL if @uri_ref is invalid or not absolute.) * %NULL if @uri_ref is invalid or not absolute.)
* *
* Return value: the resolved URI string. * Return value: (transfer full): the resolved URI string.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1453,13 +1496,14 @@ g_uri_join_internal (GUriFlags flags,
* @scheme: (nullable): the URI scheme, or %NULL * @scheme: (nullable): the URI scheme, or %NULL
* @userinfo: (nullable): the userinfo component, or %NULL * @userinfo: (nullable): the userinfo component, or %NULL
* @host: (nullable): the host component, or %NULL * @host: (nullable): the host component, or %NULL
* @port: the port, or -1 * @port: the port, or `-1`
* @path: the path component * @path: (not nullable): the path component
* @query: (nullable): the query component, or %NULL * @query: (nullable): the query component, or %NULL
* @fragment: (nullable): the fragment, or %NULL * @fragment: (nullable): the fragment, or %NULL
* *
* Joins the given components together according to @flags to create * Joins the given components together according to @flags to create
* an absolute URI string. @path may not be %NULL (though it may be ""). * an absolute URI string. @path may not be %NULL (though it may be the empty
* string).
* *
* When @host is present, @path must either be empty or begin with a slash (`/`) * When @host is present, @path must either be empty or begin with a slash (`/`)
* character. When @host is not present, @path cannot begin with two slash * character. When @host is not present, @path cannot begin with two slash
@ -1467,9 +1511,12 @@ g_uri_join_internal (GUriFlags flags,
* [RFC 3986, section 3](https://tools.ietf.org/html/rfc3986#section-3). * [RFC 3986, section 3](https://tools.ietf.org/html/rfc3986#section-3).
* *
* See also g_uri_join_with_user(), which allows specifying the * See also g_uri_join_with_user(), which allows specifying the
* components of the "userinfo" separately. * components of the userinfo separately.
* *
* Return value: an absolute URI string * %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS are ignored if set
* in @flags.
*
* Return value: (transfer full): an absolute URI string
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1506,18 +1553,22 @@ g_uri_join (GUriFlags flags,
* @auth_params: (nullable): the auth params of the userinfo, or * @auth_params: (nullable): the auth params of the userinfo, or
* %NULL * %NULL
* @host: (nullable): the host component, or %NULL * @host: (nullable): the host component, or %NULL
* @port: the port, or -1 * @port: the port, or `-1`
* @path: the path component * @path: (not nullable): the path component
* @query: (nullable): the query component, or %NULL * @query: (nullable): the query component, or %NULL
* @fragment: (nullable): the fragment, or %NULL * @fragment: (nullable): the fragment, or %NULL
* *
* Joins the given components together according to @flags to create * Joins the given components together according to @flags to create
* an absolute URI string. @path may not be %NULL (though it may be ""). * an absolute URI string. @path may not be %NULL (though it may be the empty
* string).
* *
* In contrast to g_uri_join(), this allows specifying the components * In contrast to g_uri_join(), this allows specifying the components
* of the "userinfo" separately. It otherwise behaves the same. * of the userinfo separately. It otherwise behaves the same.
* *
* Return value: an absolute URI string * %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS are ignored if set
* in @flags.
*
* Return value: (transfer full): an absolute URI string
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1549,11 +1600,11 @@ g_uri_join_with_user (GUriFlags flags,
/** /**
* g_uri_build: * g_uri_build:
* @flags: flags describing how to build the #GUri * @flags: flags describing how to build the #GUri
* @scheme: the URI scheme * @scheme: (not nullable): the URI scheme
* @userinfo: (nullable): the userinfo component, or %NULL * @userinfo: (nullable): the userinfo component, or %NULL
* @host: (nullable): the host component, or %NULL * @host: (nullable): the host component, or %NULL
* @port: the port, or -1 * @port: the port, or `-1`
* @path: the path component * @path: (not nullable): the path component
* @query: (nullable): the query component, or %NULL * @query: (nullable): the query component, or %NULL
* @fragment: (nullable): the fragment, or %NULL * @fragment: (nullable): the fragment, or %NULL
* *
@ -1598,13 +1649,13 @@ g_uri_build (GUriFlags flags,
/** /**
* g_uri_build_with_user: * g_uri_build_with_user:
* @flags: flags describing how to build the #GUri * @flags: flags describing how to build the #GUri
* @scheme: the URI scheme * @scheme: (not nullable): the URI scheme
* @user: (nullable): the user component of the userinfo, or %NULL * @user: (nullable): the user component of the userinfo, or %NULL
* @password: (nullable): the password component of the userinfo, or %NULL * @password: (nullable): the password component of the userinfo, or %NULL
* @auth_params: (nullable): the auth params of the userinfo, or %NULL * @auth_params: (nullable): the auth params of the userinfo, or %NULL
* @host: (nullable): the host component, or %NULL * @host: (nullable): the host component, or %NULL
* @port: the port, or -1 * @port: the port, or `-1`
* @path: the path component * @path: (not nullable): the path component
* @query: (nullable): the query component, or %NULL * @query: (nullable): the query component, or %NULL
* @fragment: (nullable): the fragment, or %NULL * @fragment: (nullable): the fragment, or %NULL
* *
@ -1612,9 +1663,9 @@ g_uri_build (GUriFlags flags,
* (%G_URI_FLAGS_HAS_PASSWORD is added unconditionally). The @flags must be * (%G_URI_FLAGS_HAS_PASSWORD is added unconditionally). The @flags must be
* coherent with the passed values, in particular use `%`-encoded values with * coherent with the passed values, in particular use `%`-encoded values with
* %G_URI_FLAGS_ENCODED. * %G_URI_FLAGS_ENCODED.
*
* In contrast to g_uri_build(), this allows specifying the components * In contrast to g_uri_build(), this allows specifying the components
* of the "userinfo" field separately. Note that @user must be non-%NULL * of the userinfo field separately. Note that @user must be non-%NULL
* if either @password or @auth_params is non-%NULL. * if either @password or @auth_params is non-%NULL.
* *
* Return value: (transfer full): a new #GUri * Return value: (transfer full): a new #GUri
@ -1686,8 +1737,12 @@ g_uri_build_with_user (GUriFlags flags,
* a string which is at least semantically equivalent to the source * a string which is at least semantically equivalent to the source
* URI (according to RFC 3986). * URI (according to RFC 3986).
* *
* Return value: a string representing @uri, which the caller must * If @uri might contain sensitive details, such as authentication parameters,
* free. * or private data in its query string, and the returned string is going to be
* logged, then consider using g_uri_to_string_partial() to redact parts.
*
* Return value: (transfer full): a string representing @uri, which the caller
* must free.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1706,9 +1761,9 @@ g_uri_to_string (GUri *uri)
* *
* Returns a string representing @uri, subject to the options in * Returns a string representing @uri, subject to the options in
* @flags. See g_uri_to_string() and #GUriHideFlags for more details. * @flags. See g_uri_to_string() and #GUriHideFlags for more details.
*
* Return value: a string representing @uri, which the caller must * Return value: (transfer full): a string representing @uri, which the caller
* free. * must free.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1774,8 +1829,8 @@ str_ascii_case_equal (gconstpointer v1,
* GUriParamsIter: * GUriParamsIter:
* *
* Many URI schemes include one or more attribute/value pairs as part of the URI * Many URI schemes include one or more attribute/value pairs as part of the URI
* value (for example "scheme://server/path?query=string&is=there" has two * value. For example `scheme://server/path?query=string&is=there` has two
* attributes "query=string" and "is=there" in its query part). * attributes `query=string` and `is=there` in its query part.
* *
* A #GUriParamsIter structure represents an iterator that can be used to * A #GUriParamsIter structure represents an iterator that can be used to
* iterate over the attribute/value pairs of a URI query string. #GUriParamsIter * iterate over the attribute/value pairs of a URI query string. #GUriParamsIter
@ -1799,31 +1854,45 @@ G_STATIC_ASSERT (G_ALIGNOF (GUriParamsIter) >= G_ALIGNOF (RealIter));
/** /**
* g_uri_params_iter_init: * g_uri_params_iter_init:
* @iter: an uninitialized #GUriParamsIter * @iter: an uninitialized #GUriParamsIter
* @params: a `%`-encoded string containing "attribute=value" * @params: a `%`-encoded string containing `attribute=value`
* parameters * parameters
* @length: the length of @params, or -1 if it is NUL-terminated * @length: the length of @params, or `-1` if it is nul-terminated
* @separators: the separator byte character set between parameters. (usually * @separators: the separator byte character set between parameters. (usually
* "&", but sometimes ";" or both "&;"). Note that this function works on * `&`, but sometimes `;` or both `&;`). Note that this function works on
* bytes not characters, so it can't be used to delimit UTF-8 strings for * bytes not characters, so it can't be used to delimit UTF-8 strings for
* anything but ASCII characters. You may pass an empty set, in which case * anything but ASCII characters. You may pass an empty set, in which case
* no splitting will occur. * no splitting will occur.
* @flags: flags to modify the way the parameters are handled. * @flags: flags to modify the way the parameters are handled.
* *
* Initializes an attribute/value pair iterator. The iterator keeps references * Initializes an attribute/value pair iterator.
* over the @params and @separators arguments, those variables must thus outlive *
* the iterator and not be modified during the iteration. * The iterator keeps pointers to the @params and @separators arguments, those
* variables must thus outlive the iterator and not be modified during the
* iteration.
*
* If %G_URI_PARAMS_WWW_FORM is passed in @flags, `+` characters in the param
* string will be replaced with spaces in the output. For example, `foo=bar+baz`
* will give attribute `foo` with value `bar baz`. This is commonly used on the
* web (the `https` and `http` schemes only), but is deprecated in favour of
* the equivalent of encoding spaces as `%20`.
*
* Unlike with g_uri_parse_params(), %G_URI_PARAMS_CASE_INSENSITIVE has no
* effect if passed to @flags for g_uri_params_iter_init(). The caller is
* responsible for doing their own case-insensitive comparisons.
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GUriParamsIter iter; * GUriParamsIter iter;
* GError *error = NULL; * GError *error = NULL;
* gchar *attr, *value; * gchar *unowned_attr, *unowned_value;
* *
* g_uri_params_iter_init (&iter, "foo=bar&baz=bar", -1, "&", G_URI_PARAMS_NONE); * g_uri_params_iter_init (&iter, "foo=bar&baz=bar&Foo=frob&baz=bar2", -1, "&", G_URI_PARAMS_NONE);
* while (g_uri_params_iter_next (&iter, &attr, &value, &error)) * while (g_uri_params_iter_next (&iter, &unowned_attr, &unowned_value, &error))
* { * {
* // do something with attr and value * g_autofree gchar *attr = g_steal_pointer (&unowned_attr);
* g_free (attr); * g_autofree gchar *value = g_steal_pointer (&unowned_value);
* g_free (value); * // do something with attr and value; this code will be called 4 times
* // for the params string in this example: once with attr=foo and value=bar,
* // then with baz/bar, then Foo/frob, then baz/bar2.
* } * }
* if (error) * if (error)
* // handle parsing error * // handle parsing error
@ -1869,13 +1938,18 @@ g_uri_params_iter_init (GUriParamsIter *iter,
* the value, or %NULL. * the value, or %NULL.
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
* *
* Advances @iter and retrieves the next attribute/value. If %FALSE is returned, * Advances @iter and retrieves the next attribute/value. %FALSE is returned if
* @attribute and @value are not set, and the iterator becomes invalid. Note * an error has occurred (in which case @error is set), or if the end of the
* that the same attribute value may be returned multiple times, since URIs * iteration is reached (in which case @attribute and @value are set to %NULL
* and the iterator becomes invalid). If %TRUE is returned,
* g_uri_params_iter_next() may be called again to receive another
* attribute/value pair.
*
* Note that the same @attribute may be returned multiple times, since URIs
* allow repeated attributes. * allow repeated attributes.
* *
* Returns: %FALSE if the end of the parameters has been reached or an error was * Returns: %FALSE if the end of the parameters has been reached or an error was
* encountered. * encountered. %TRUE otherwise.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -1938,11 +2012,11 @@ g_uri_params_iter_next (GUriParamsIter *iter,
/** /**
* g_uri_parse_params: * g_uri_parse_params:
* @params: a `%`-encoded string containing "attribute=value" * @params: a `%`-encoded string containing `attribute=value`
* parameters * parameters
* @length: the length of @params, or -1 if it is NUL-terminated * @length: the length of @params, or `-1` if it is nul-terminated
* @separators: the separator byte character set between parameters. (usually * @separators: the separator byte character set between parameters. (usually
* "&", but sometimes ";" or both "&;"). Note that this function works on * `&`, but sometimes `;` or both `&;`). Note that this function works on
* bytes not characters, so it can't be used to delimit UTF-8 strings for * bytes not characters, so it can't be used to delimit UTF-8 strings for
* anything but ASCII characters. You may pass an empty set, in which case * anything but ASCII characters. You may pass an empty set, in which case
* no splitting will occur. * no splitting will occur.
@ -1957,17 +2031,26 @@ g_uri_params_iter_next (GUriParamsIter *iter,
* *
* The @params string is assumed to still be `%`-encoded, but the returned * The @params string is assumed to still be `%`-encoded, but the returned
* values will be fully decoded. (Thus it is possible that the returned values * values will be fully decoded. (Thus it is possible that the returned values
* may contain '=' or @separators, if the value was encoded in the input.) * may contain `=` or @separators, if the value was encoded in the input.)
* Invalid `%`-encoding is treated as with the non-%G_URI_FLAGS_PARSE_STRICT * Invalid `%`-encoding is treated as with the non-%G_URI_FLAGS_PARSE_STRICT
* rules for g_uri_parse(). (However, if @params is the path or query string * rules for g_uri_parse(). (However, if @params is the path or query string
* from a #GUri that was parsed with %G_URI_FLAGS_PARSE_STRICT and * from a #GUri that was parsed with %G_URI_FLAGS_PARSE_STRICT and
* %G_URI_FLAGS_ENCODED, then you already know that it does not contain any * %G_URI_FLAGS_ENCODED, then you already know that it does not contain any
* invalid encoding.) * invalid encoding.)
* *
* Return value: (transfer full) (element-type utf8 utf8): a hash table of * %G_URI_PARAMS_WWW_FORM is handled as documented for g_uri_params_iter_init().
* attribute/value pairs. Both names and values will be fully-decoded. If *
* @params cannot be parsed (eg, it contains two @separators characters in a * If %G_URI_PARAMS_CASE_INSENSITIVE is passed to @flags, attributes will be
* row), then %NULL is returned. * compared case-insensitively, so a params string `attr=123&Attr=456` will only
* return a single attributevalue pair, `Attr=456`. Case will be preserved in
* the returned attributes.
*
* If @params cannot be parsed (for example, it contains two @separators
* characters in a row), then @error is set and %NULL is returned.
*
* Return value: (transfer full) (element-type utf8 utf8): A hash table of
* attribute/value pairs, with both names and values fully-decoded; or %NULL
* on error.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2022,7 +2105,7 @@ g_uri_parse_params (const gchar *params,
* Gets @uri's scheme. Note that this will always be all-lowercase, * Gets @uri's scheme. Note that this will always be all-lowercase,
* regardless of the string or strings that @uri was created from. * regardless of the string or strings that @uri was created from.
* *
* Return value: @uri's scheme. * Return value: (not nullable): @uri's scheme.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2041,7 +2124,7 @@ g_uri_get_scheme (GUri *uri)
* Gets @uri's userinfo, which may contain `%`-encoding, depending on * Gets @uri's userinfo, which may contain `%`-encoding, depending on
* the flags with which @uri was created. * the flags with which @uri was created.
* *
* Return value: @uri's userinfo. * Return value: (nullable): @uri's userinfo.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2057,12 +2140,12 @@ g_uri_get_userinfo (GUri *uri)
* g_uri_get_user: * g_uri_get_user:
* @uri: a #GUri * @uri: a #GUri
* *
* Gets the "username" component of @uri's userinfo, which may contain * Gets the username component of @uri's userinfo, which may contain
* `%`-encoding, depending on the flags with which @uri was created. * `%`-encoding, depending on the flags with which @uri was created.
* If @uri was not created with %G_URI_FLAGS_HAS_PASSWORD or * If @uri was not created with %G_URI_FLAGS_HAS_PASSWORD or
* %G_URI_FLAGS_HAS_AUTH_PARAMS, this is the same as g_uri_get_userinfo(). * %G_URI_FLAGS_HAS_AUTH_PARAMS, this is the same as g_uri_get_userinfo().
* *
* Return value: @uri's user. * Return value: (nullable): @uri's user.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2082,7 +2165,7 @@ g_uri_get_user (GUri *uri)
* the flags with which @uri was created. (If @uri was not created * the flags with which @uri was created. (If @uri was not created
* with %G_URI_FLAGS_HAS_PASSWORD then this will be %NULL.) * with %G_URI_FLAGS_HAS_PASSWORD then this will be %NULL.)
* *
* Return value: @uri's password. * Return value: (nullable): @uri's password.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2106,7 +2189,7 @@ g_uri_get_password (GUri *uri)
* Depending on the URI scheme, g_uri_parse_params() may be useful for * Depending on the URI scheme, g_uri_parse_params() may be useful for
* further parsing this information. * further parsing this information.
* *
* Return value: @uri's authentication parameters. * Return value: (nullable): @uri's authentication parameters.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2129,10 +2212,10 @@ g_uri_get_auth_params (GUri *uri)
* If @uri contained an IPv6 address literal, this value will be just * If @uri contained an IPv6 address literal, this value will be just
* that address, without the brackets around it that are necessary in * that address, without the brackets around it that are necessary in
* the string form of the URI. Note that in this case there may also * the string form of the URI. Note that in this case there may also
* be a scope ID attached to the address. Eg, "`fe80::1234%``em1`" (or * be a scope ID attached to the address. Eg, `fe80::1234%``em1` (or
* "`fe80::1234%``25em1" if the string is still encoded). * `fe80::1234%``25em1` if the string is still encoded).
* *
* Return value: @uri's host. * Return value: (not nullable): @uri's host.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2150,7 +2233,7 @@ g_uri_get_host (GUri *uri)
* *
* Gets @uri's port. * Gets @uri's port.
* *
* Return value: @uri's port, or -1 if no port was specified. * Return value: @uri's port, or `-1` if no port was specified.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2169,7 +2252,7 @@ g_uri_get_port (GUri *uri)
* Gets @uri's path, which may contain `%`-encoding, depending on the * Gets @uri's path, which may contain `%`-encoding, depending on the
* flags with which @uri was created. * flags with which @uri was created.
* *
* Return value: @uri's path. * Return value: (not nullable): @uri's path.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2188,10 +2271,10 @@ g_uri_get_path (GUri *uri)
* Gets @uri's query, which may contain `%`-encoding, depending on the * Gets @uri's query, which may contain `%`-encoding, depending on the
* flags with which @uri was created. * flags with which @uri was created.
* *
* For queries consisting of a series of "`name=value`" parameters, * For queries consisting of a series of `name=value` parameters,
* g_uri_parse_params() may be useful. * #GUriParamsIter or g_uri_parse_params() may be useful.
* *
* Return value: @uri's query. * Return value: (nullable): @uri's query.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2210,7 +2293,7 @@ g_uri_get_query (GUri *uri)
* Gets @uri's fragment, which may contain `%`-encoding, depending on * Gets @uri's fragment, which may contain `%`-encoding, depending on
* the flags with which @uri was created. * the flags with which @uri was created.
* *
* Return value: @uri's fragment. * Return value: (nullable): @uri's fragment.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2368,8 +2451,8 @@ g_uri_escape_string (const gchar *unescaped,
/** /**
* g_uri_unescape_bytes: * g_uri_unescape_bytes:
* @escaped_string: A URI-escaped string * @escaped_string: A URI-escaped string
* @length: the length of @escaped_string to escape, or -1 if it * @length: the length (in bytes) of @escaped_string to escape, or `-1` if it
* is NUL-terminated. * is nul-terminated.
* @illegal_characters: (nullable): a string of illegal characters * @illegal_characters: (nullable): a string of illegal characters
* not to be allowed, or %NULL. * not to be allowed, or %NULL.
* @error: #GError for error reporting, or %NULL to ignore. * @error: #GError for error reporting, or %NULL to ignore.
@ -2377,17 +2460,17 @@ g_uri_escape_string (const gchar *unescaped,
* Unescapes a segment of an escaped string as binary data. * Unescapes a segment of an escaped string as binary data.
* *
* Note that in contrast to g_uri_unescape_string(), this does allow * Note that in contrast to g_uri_unescape_string(), this does allow
* `NUL` bytes to appear in the output. * nul bytes to appear in the output.
* *
* If any of the characters in @illegal_characters or the NUL * If any of the characters in @illegal_characters appears as an escaped
* character appears as an escaped character in @escaped_string, then * character in @escaped_string, then that is an error and %NULL will be
* that is an error and %NULL will be returned. This is useful if you * returned. This is useful if you want to avoid for instance having a slash
* want to avoid for instance having a slash being expanded in an * being expanded in an escaped path element, which might confuse pathname
* escaped path element, which might confuse pathname handling. * handling.
* *
* Returns: (transfer full): an unescaped version of @escaped_string or %NULL on * Returns: (transfer full): an unescaped version of @escaped_string or %NULL on
* error (if decoding failed, using %G_URI_ERROR_MISC error code). The returned * error (if decoding failed, using %G_URI_ERROR_FAILED error code). The
* #GBytes should be unreffed when no longer needed. * returned #GBytes should be unreffed when no longer needed.
* *
* Since: 2.66 * Since: 2.66
**/ **/
@ -2428,18 +2511,18 @@ g_uri_unescape_bytes (const gchar *escaped_string,
* *
* Escapes arbitrary data for use in a URI. * Escapes arbitrary data for use in a URI.
* *
* Normally all characters that are not "unreserved" (i.e. ASCII * Normally all characters that are not unreserved (i.e. ASCII
* alphanumerical characters plus dash, dot, underscore and tilde) are * alphanumerical characters plus dash, dot, underscore and tilde) are
* escaped. But if you specify characters in @reserved_chars_allowed * escaped. But if you specify characters in @reserved_chars_allowed
* they are not escaped. This is useful for the "reserved" characters * they are not escaped. This is useful for the reserved characters
* in the URI specification, since those are allowed unescaped in some * in the URI specification, since those are allowed unescaped in some
* portions of a URI. * portions of a URI.
* *
* Though technically incorrect, this will also allow escaping "0" * Though technically incorrect, this will also allow escaping nul
* bytes as "`%``00`". * bytes as `%``00`.
* *
* Returns: an escaped version of @unescaped. The returned string * Returns: (transfer full): an escaped version of @unescaped. The returned
* should be freed when no longer needed. * string should be freed when no longer needed.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -2482,14 +2565,16 @@ g_uri_scheme_length (const gchar *uri)
* g_uri_parse_scheme: * g_uri_parse_scheme:
* @uri: a valid URI. * @uri: a valid URI.
* *
* Gets the scheme portion of a URI string. RFC 3986 decodes the scheme as: * Gets the scheme portion of a URI string.
* [RFC 3986](https://tools.ietf.org/html/rfc3986#section-3) decodes the scheme
* as:
* |[ * |[
* URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] * URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ]
* ]| * ]|
* Common schemes include "file", "http", "svn+ssh", etc. * Common schemes include `file`, `https`, `svn+ssh`, etc.
* *
* Returns: The "scheme" component of the URI, or %NULL on error. * Returns: (transfer full) (nullable): The scheme component of the URI, or
* The returned string should be freed when no longer needed. * %NULL on error. The returned string should be freed when no longer needed.
* *
* Since: 2.16 * Since: 2.16
**/ **/
@ -2508,15 +2593,20 @@ g_uri_parse_scheme (const gchar *uri)
* g_uri_peek_scheme: * g_uri_peek_scheme:
* @uri: a valid URI. * @uri: a valid URI.
* *
* Gets the scheme portion of a URI string. RFC 3986 decodes the scheme as: * Gets the scheme portion of a URI string.
* [RFC 3986](https://tools.ietf.org/html/rfc3986#section-3) decodes the scheme
* as:
* |[ * |[
* URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] * URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ]
* ]| * ]|
* Common schemes include "file", "http", "svn+ssh", etc. * Common schemes include `file`, `https`, `svn+ssh`, etc.
* *
* Returns: The "scheme" component of the URI, or %NULL on error. The * Unlike g_uri_parse_scheme(), the returned scheme is normalized to
* returned string is normalized to all-lowercase, and interned via * all-lowercase and does not need to be freed.
* g_intern_string(), so it does not need to be freed. *
* Returns: (transfer none) (nullable): The scheme component of the URI, or
* %NULL on error. The returned string is normalized to all-lowercase, and
* interned via g_intern_string(), so it does not need to be freed.
* *
* Since: 2.66 * Since: 2.66
**/ **/

View File

@ -37,15 +37,17 @@ void g_uri_unref (GUri *uri);
/** /**
* GUriFlags: * GUriFlags:
* @G_URI_FLAGS_PARSE_STRICT: Parse the URI strictly according to the RFC * @G_URI_FLAGS_NONE: No flags set.
* 3986 grammar, rather than fixing up or ignoring common mistakes. * @G_URI_FLAGS_PARSE_STRICT: Parse the URI strictly according to the
* [RFC 3986](https://tools.ietf.org/html/rfc3986) grammar, rather than
* fixing up or ignoring common mistakes.
* @G_URI_FLAGS_HAS_PASSWORD: The userinfo field may contain a password, * @G_URI_FLAGS_HAS_PASSWORD: The userinfo field may contain a password,
* which will be separated from the username by ':'. * which will be separated from the username by `:`.
* @G_URI_FLAGS_HAS_AUTH_PARAMS: The userinfo may contain additional * @G_URI_FLAGS_HAS_AUTH_PARAMS: The userinfo may contain additional
* authentication-related parameters, which will be separated from * authentication-related parameters, which will be separated from
* the username and/or password by ';'. * the username and/or password by `;`.
* @G_URI_FLAGS_NON_DNS: The host component should not be assumed to be a * @G_URI_FLAGS_NON_DNS: The host component should not be assumed to be a
* DNS hostname or IP address. (Eg, for `smb` URIs with NetBIOS * DNS hostname or IP address (for example, for `smb` URIs with NetBIOS
* hostnames). * hostnames).
* @G_URI_FLAGS_ENCODED: When parsing a URI, this indicates that `%`-encoded * @G_URI_FLAGS_ENCODED: When parsing a URI, this indicates that `%`-encoded
* characters in the userinfo, path, query, and fragment fields * characters in the userinfo, path, query, and fragment fields
@ -58,7 +60,6 @@ void g_uri_unref (GUri *uri);
* @G_URI_FLAGS_ENCODED_PATH: Same as %G_URI_FLAGS_ENCODED, for the path only. * @G_URI_FLAGS_ENCODED_PATH: Same as %G_URI_FLAGS_ENCODED, for the path only.
* @G_URI_FLAGS_ENCODED_FRAGMENT: Same as %G_URI_FLAGS_ENCODED, for the * @G_URI_FLAGS_ENCODED_FRAGMENT: Same as %G_URI_FLAGS_ENCODED, for the
* fragment only. * fragment only.
* @G_URI_FLAGS_NONE: No flags set.
* *
* Flags that describe a URI. * Flags that describe a URI.
* *
@ -179,11 +180,11 @@ GUri * g_uri_build_with_user (GUriFlags flags,
/** /**
* GUriHideFlags: * GUriHideFlags:
* @G_URI_HIDE_NONE: No flags set.
* @G_URI_HIDE_USERINFO: Hide the userinfo. * @G_URI_HIDE_USERINFO: Hide the userinfo.
* @G_URI_HIDE_PASSWORD: Hide the password. * @G_URI_HIDE_PASSWORD: Hide the password.
* @G_URI_HIDE_AUTH_PARAMS: Hide the auth_params. * @G_URI_HIDE_AUTH_PARAMS: Hide the auth_params.
* @G_URI_HIDE_FRAGMENT: Hide the fragment. * @G_URI_HIDE_FRAGMENT: Hide the fragment.
* @G_URI_HIDE_NONE: No flags set.
* *
* Flags describing what parts of the URI to hide in * Flags describing what parts of the URI to hide in
* g_uri_to_string_partial(). Note that %G_URI_HIDE_PASSWORD and * g_uri_to_string_partial(). Note that %G_URI_HIDE_PASSWORD and
@ -233,10 +234,12 @@ GUriFlags g_uri_get_flags (GUri *uri);
/** /**
* GUriParamsFlags: * GUriParamsFlags:
* @G_URI_PARAMS_NONE: No flags set. * @G_URI_PARAMS_NONE: No flags set.
* @G_URI_PARAMS_CASE_INSENSITIVE: whether parameter names are case insensitive. * @G_URI_PARAMS_CASE_INSENSITIVE: Parameter names are case insensitive.
* @G_URI_PARAMS_WWW_FORM: replace `+` with space character. * @G_URI_PARAMS_WWW_FORM: Replace `+` with space character. Only useful for
* URLs on the web, using the `https` or `http` schemas.
* *
* Flags modifying the way parameters are handled. * Flags modifying the way parameters are handled by g_uri_parse_params() and
* #GUriParamsIter.
* *
* Since: 2.66 * Since: 2.66
*/ */
@ -292,16 +295,17 @@ GQuark g_uri_error_quark (void);
/** /**
* GUriError: * GUriError:
* @G_URI_ERROR_MISC: miscellaneous error * @G_URI_ERROR_MISC: Generic error if no more specific error is available.
* @G_URI_ERROR_BAD_SCHEME: the scheme of a URI could not be parsed. * See the error message for details.
* @G_URI_ERROR_BAD_USER: the user/userinfo of a URI could not be parsed. * @G_URI_ERROR_BAD_SCHEME: The scheme of a URI could not be parsed.
* @G_URI_ERROR_BAD_PASSWORD: the password of a URI could not be parsed. * @G_URI_ERROR_BAD_USER: The user/userinfo of a URI could not be parsed.
* @G_URI_ERROR_BAD_AUTH_PARAMS: the authentication parameters of a URI could not be parsed. * @G_URI_ERROR_BAD_PASSWORD: The password of a URI could not be parsed.
* @G_URI_ERROR_BAD_HOST: the host of a URI could not be parsed. * @G_URI_ERROR_BAD_AUTH_PARAMS: The authentication parameters of a URI could not be parsed.
* @G_URI_ERROR_BAD_PORT: the port of a URI could not be parsed. * @G_URI_ERROR_BAD_HOST: The host of a URI could not be parsed.
* @G_URI_ERROR_BAD_PATH: the path of a URI could not be parsed. * @G_URI_ERROR_BAD_PORT: The port of a URI could not be parsed.
* @G_URI_ERROR_BAD_QUERY: the query of a URI could not be parsed. * @G_URI_ERROR_BAD_PATH: The path of a URI could not be parsed.
* @G_URI_ERROR_BAD_FRAGMENT: the fragment of a URI could not be parsed. * @G_URI_ERROR_BAD_QUERY: The query of a URI could not be parsed.
* @G_URI_ERROR_BAD_FRAGMENT: The fragment of a URI could not be parsed.
* *
* Error codes returned by #GUri methods. * Error codes returned by #GUri methods.
* *
@ -323,7 +327,8 @@ typedef enum {
/** /**
* G_URI_RESERVED_CHARS_GENERIC_DELIMITERS: * G_URI_RESERVED_CHARS_GENERIC_DELIMITERS:
* *
* Generic delimiters characters as defined in RFC 3986. Includes ":/?#[]@". * Generic delimiters characters as defined in
* [RFC 3986](https://tools.ietf.org/html/rfc3986). Includes `:/?#[]@`.
* *
* Since: 2.16 * Since: 2.16
**/ **/
@ -332,7 +337,8 @@ typedef enum {
/** /**
* G_URI_RESERVED_CHARS_SUBCOMPONENT_DELIMITERS: * G_URI_RESERVED_CHARS_SUBCOMPONENT_DELIMITERS:
* *
* Subcomponent delimiter characters as defined in RFC 3986. Includes "!$&'()*+,;=". * Subcomponent delimiter characters as defined in
* [RFC 3986](https://tools.ietf.org/html/rfc3986). Includes `!$&'()*+,;=`.
* *
* Since: 2.16 * Since: 2.16
**/ **/
@ -341,7 +347,7 @@ typedef enum {
/** /**
* G_URI_RESERVED_CHARS_ALLOWED_IN_PATH_ELEMENT: * G_URI_RESERVED_CHARS_ALLOWED_IN_PATH_ELEMENT:
* *
* Allowed characters in path elements. Includes "!$&'()*+,;=:@". * Allowed characters in path elements. Includes `!$&'()*+,;=:@`.
* *
* Since: 2.16 * Since: 2.16
**/ **/
@ -350,7 +356,7 @@ typedef enum {
/** /**
* G_URI_RESERVED_CHARS_ALLOWED_IN_PATH: * G_URI_RESERVED_CHARS_ALLOWED_IN_PATH:
* *
* Allowed characters in a path. Includes "!$&'()*+,;=:@/". * Allowed characters in a path. Includes `!$&'()*+,;=:@/`.
* *
* Since: 2.16 * Since: 2.16
**/ **/
@ -359,7 +365,8 @@ typedef enum {
/** /**
* G_URI_RESERVED_CHARS_ALLOWED_IN_USERINFO: * G_URI_RESERVED_CHARS_ALLOWED_IN_USERINFO:
* *
* Allowed characters in userinfo as defined in RFC 3986. Includes "!$&'()*+,;=:". * Allowed characters in userinfo as defined in
* [RFC 3986](https://tools.ietf.org/html/rfc3986). Includes `!$&'()*+,;=:`.
* *
* Since: 2.16 * Since: 2.16
**/ **/