mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-02-05 10:38:08 +01:00
gfileutils: Mention possibility of relative paths in g_file_read_link()
It’s entirely possible that `g_file_read_link()` will return a relative path. Mention that in the documentation, and include a short example of how to make the path absolute for further computation. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
This commit is contained in:
parent
0768067155
commit
14d5f25dd0
@ -2256,9 +2256,28 @@ g_build_filename (const gchar *first_element,
|
||||
* @error: return location for a #GError
|
||||
*
|
||||
* Reads the contents of the symbolic link @filename like the POSIX
|
||||
* readlink() function. The returned string is in the encoding used
|
||||
* readlink() function.
|
||||
*
|
||||
* The returned string is in the encoding used
|
||||
* for filenames. Use g_filename_to_utf8() to convert it to UTF-8.
|
||||
*
|
||||
* The returned string may also be a relative path. Use g_build_filename() to
|
||||
* convert it to an absolute path:
|
||||
* |[
|
||||
* g_autoptr(GError) local_error = NULL;
|
||||
* g_autofree gchar *link_target = g_file_read_link ("/etc/localtime", &local_error);
|
||||
*
|
||||
* if (local_error != NULL)
|
||||
* g_error ("Error reading link: %s", local_error->message);
|
||||
*
|
||||
* if (!g_path_is_absolute (link_target))
|
||||
* {
|
||||
* g_autofree gchar *absolute_link_target = g_build_filename ("/etc", link_target, NULL);
|
||||
* g_free (link_target);
|
||||
* link_target = g_steal_pointer (&absolute_link_target);
|
||||
* }
|
||||
* ]|
|
||||
*
|
||||
* Returns: (type filename) (transfer full): A newly-allocated string with
|
||||
* the contents of the symbolic link, or %NULL if an error occurred.
|
||||
*
|
||||
|
Loading…
x
Reference in New Issue
Block a user