glib: Use g_file_set_contents_full() throughout GLib and GIO

Where applicable. Where the current use of `g_file_set_contents()` seems
the most appropriate, leave that in place.

Signed-off-by: Philip Withnall <withnall@endlessm.com>

Helps: #1302
This commit is contained in:
Philip Withnall 2020-05-27 18:00:48 +01:00
parent 24ed91ce33
commit 3b6460b94c
6 changed files with 25 additions and 11 deletions

View File

@ -830,10 +830,12 @@ keyring_generate_entry (const gchar *cookie_context,
/* and now actually write the cookie file if there are changes (this is atomic) */ /* and now actually write the cookie file if there are changes (this is atomic) */
if (changed_file) if (changed_file)
{ {
if (!g_file_set_contents (path, if (!g_file_set_contents_full (path,
new_contents->str, new_contents->str,
-1, -1,
error)) G_FILE_SET_CONTENTS_CONSISTENT,
0600,
error))
{ {
*out_id = 0; *out_id = 0;
*out_cookie = 0; *out_cookie = 0;

View File

@ -3630,7 +3630,9 @@ update_mimeapps_list (const char *desktop_id,
data = g_key_file_to_data (key_file, &data_size, error); data = g_key_file_to_data (key_file, &data_size, error);
g_key_file_free (key_file); g_key_file_free (key_file);
res = g_file_set_contents (filename, data, data_size, error); res = g_file_set_contents_full (filename, data, data_size,
G_FILE_SET_CONTENTS_CONSISTENT | G_FILE_SET_CONTENTS_ONLY_EXISTING,
0600, error);
desktop_file_dirs_invalidate_user_config (); desktop_file_dirs_invalidate_user_config ();
@ -3774,7 +3776,9 @@ g_desktop_app_info_set_as_default_for_extension (GAppInfo *appinfo,
" </mime-type>\n" " </mime-type>\n"
"</mime-info>\n", mimetype, extension, extension); "</mime-info>\n", mimetype, extension, extension);
g_file_set_contents (filename, contents, -1, NULL); g_file_set_contents_full (filename, contents, -1,
G_FILE_SET_CONTENTS_CONSISTENT | G_FILE_SET_CONTENTS_ONLY_EXISTING,
0600, NULL);
g_free (contents); g_free (contents);
run_update_command ("update-mime-database", "mime"); run_update_command ("update-mime-database", "mime");
@ -3923,7 +3927,9 @@ g_desktop_app_info_ensure_saved (GDesktopAppInfo *info,
/* FIXME - actually handle error */ /* FIXME - actually handle error */
(void) g_close (fd, NULL); (void) g_close (fd, NULL);
res = g_file_set_contents (filename, data, data_size, error); res = g_file_set_contents_full (filename, data, data_size,
G_FILE_SET_CONTENTS_CONSISTENT | G_FILE_SET_CONTENTS_ONLY_EXISTING,
0600, error);
g_free (data); g_free (data);
if (!res) if (!res)
{ {

View File

@ -2211,7 +2211,9 @@ g_local_file_trash (GFile *file,
original_name_escaped, delete_time); original_name_escaped, delete_time);
g_free (delete_time); g_free (delete_time);
g_file_set_contents (infofile, data, -1, NULL); g_file_set_contents_full (infofile, data, -1,
G_FILE_SET_CONTENTS_CONSISTENT | G_FILE_SET_CONTENTS_ONLY_EXISTING,
0600, NULL);
/* TODO: Maybe we should verify that you can delete the file from the trash /* TODO: Maybe we should verify that you can delete the file from the trash
* before moving it? OTOH, that is hard, as it needs a recursive scan * before moving it? OTOH, that is hard, as it needs a recursive scan

View File

@ -573,7 +573,9 @@ write_config_file (GTestDBus *self)
"</busconfig>\n"); "</busconfig>\n");
close (fd); close (fd);
g_file_set_contents (path, contents->str, contents->len, &error); g_file_set_contents_full (path, contents->str, contents->len,
G_FILE_SET_CONTENTS_NONE,
0600, &error);
g_assert_no_error (error); g_assert_no_error (error);
g_string_free (contents, TRUE); g_string_free (contents, TRUE);

View File

@ -4611,7 +4611,9 @@ g_key_file_parse_comment_as_value (GKeyFile *key_file,
* @error: a pointer to a %NULL #GError, or %NULL * @error: a pointer to a %NULL #GError, or %NULL
* *
* Writes the contents of @key_file to @filename using * Writes the contents of @key_file to @filename using
* g_file_set_contents(). * g_file_set_contents(). If you need stricter guarantees about durability of
* the written file than are provided by g_file_set_contents(), use
* g_file_set_contents_full() with the return value of g_key_file_to_data().
* *
* This function can fail for any of the reasons that * This function can fail for any of the reasons that
* g_file_set_contents() may fail. * g_file_set_contents() may fail.

View File

@ -1552,7 +1552,7 @@ g_rmdir (const gchar *filename)
* *
* As `close()` and `fclose()` are part of the C library, this implies that it is * As `close()` and `fclose()` are part of the C library, this implies that it is
* currently impossible to close a file if the application C library and the C library * currently impossible to close a file if the application C library and the C library
* used by GLib are different. Convenience functions like g_file_set_contents() * used by GLib are different. Convenience functions like g_file_set_contents_full()
* avoid this problem. * avoid this problem.
* *
* Returns: A `FILE*` if the file was successfully opened, or %NULL if * Returns: A `FILE*` if the file was successfully opened, or %NULL if