mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 00:06:24 +01:00
guri: Various minor documentation tweaks and improvements
Signed-off-by: Philip Withnall <withnall@endlessm.com>
This commit is contained in:
parent
602b7cca33
commit
ff60d2ebf5
380
glib/guri.c
380
glib/guri.c
@ -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 it’s not a valid URI, an error is returned explaining how it’s 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 attribute–value 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
|
||||||
**/
|
**/
|
||||||
|
57
glib/guri.h
57
glib/guri.h
@ -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
|
||||||
**/
|
**/
|
||||||
|
Loading…
Reference in New Issue
Block a user