From 70f641411b2fbab930b481ac844984819b48805d Mon Sep 17 00:00:00 2001 From: Nickolay V. Shmyrev Date: Sat, 13 May 2006 03:54:09 +0000 Subject: Bump requirements to gtk 2.8 and drop all idfefs used. * configure.ac: * properties/ev-properties-main.c: (ev_properties_get_pages): * shell/ev-application.c: (ev_application_open_window), (ev_application_open_uri_at_dest): * shell/ev-sidebar-attachments.c: (ev_sidebar_attachments_init): * shell/ev-sidebar-thumbnails.c: (adjustment_changed_cb), (ev_sidebar_thumbnails_use_icon_view), (page_changed_cb): * shell/ev-utils.c: (save_print_config_to_file): * shell/ev-window.c: (ev_window_cmd_save_as), (ev_attachment_popup_cmd_save_attachment_as): * shell/main.c: (load_files_remote): Bump requirements to gtk 2.8 and drop all idfefs used. --- (limited to 'shell/ev-utils.c') diff --git a/shell/ev-utils.c b/shell/ev-utils.c index 3dc849c..b35b77b 100644 --- a/shell/ev-utils.c +++ b/shell/ev-utils.c @@ -210,216 +210,6 @@ ev_print_region_contents (GdkRegion *region) g_free (rectangles); } - -#ifndef HAVE_G_FILE_SET_CONTENTS - -#include -#include -#include -#include -#include -#include - -static gboolean -rename_file (const char *old_name, - const char *new_name, - GError **err) -{ - errno = 0; - if (g_rename (old_name, new_name) == -1) - { - return FALSE; - } - - return TRUE; -} - -static gboolean -set_umask_permissions (int fd, - GError **err) -{ - /* All of this function is just to work around the fact that - * there is no way to get the umask without changing it. - * - * We can't just change-and-reset the umask because that would - * lead to a race condition if another thread tried to change - * the umask in between the getting and the setting of the umask. - * So we have to do the whole thing in a child process. - */ - pid_t pid; - - pid = fork (); - - if (pid == -1) - { - return FALSE; - } - else if (pid == 0) - { - /* child */ - mode_t mask = umask (0666); - - errno = 0; - if (fchmod (fd, 0666 & ~mask) == -1) - _exit (errno); - else - _exit (0); - - return TRUE; /* To quiet gcc */ - } - else - { - /* parent */ - int status; - - errno = 0; - if (waitpid (pid, &status, 0) == -1) - { - return FALSE; - } - - if (WIFEXITED (status)) - { - if (WEXITSTATUS (status) == 0) - { - return TRUE; - } - else - { - return FALSE; - } - } - else if (WIFSIGNALED (status)) - { - return FALSE; - } - else - { - return FALSE; - } - } -} - -static gchar * -write_to_temp_file (const gchar *contents, - gssize length, - const gchar *template, - GError **err) -{ - gchar *tmp_name; - gchar *display_name; - gchar *retval; - FILE *file; - gint fd; - - retval = NULL; - - tmp_name = g_strdup_printf ("%s.XXXXXX", template); - - errno = 0; - fd = g_mkstemp (tmp_name); - display_name = g_filename_display_name (tmp_name); - - if (fd == -1) - { - goto out; - } - - if (!set_umask_permissions (fd, err)) - { - close (fd); - g_unlink (tmp_name); - - goto out; - } - - errno = 0; - file = fdopen (fd, "wb"); - if (!file) - { - close (fd); - g_unlink (tmp_name); - - goto out; - } - - if (length > 0) - { - size_t n_written; - - errno = 0; - - n_written = fwrite (contents, 1, length, file); - - if (n_written < length) - { - fclose (file); - g_unlink (tmp_name); - - goto out; - } - } - - errno = 0; - if (fclose (file) == EOF) - { - g_unlink (tmp_name); - - goto out; - } - - retval = g_strdup (tmp_name); - - out: - g_free (tmp_name); - g_free (display_name); - - return retval; -} - -static gboolean -ev_file_set_contents (const gchar *filename, - const gchar *contents, - gssize length, - GError **error) -{ - gchar *tmp_filename; - gboolean retval; - GError *rename_error = NULL; - - g_return_val_if_fail (filename != NULL, FALSE); - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - g_return_val_if_fail (contents != NULL || length == 0, FALSE); - g_return_val_if_fail (length >= -1, FALSE); - - if (length == -1) - length = strlen (contents); - - tmp_filename = write_to_temp_file (contents, length, filename, error); - - if (!tmp_filename) - { - retval = FALSE; - goto out; - } - - if (!rename_file (tmp_filename, filename, &rename_error)) - { - g_unlink (tmp_filename); - g_propagate_error (error, rename_error); - retval = FALSE; - goto out; - } - - retval = TRUE; - - out: - g_free (tmp_filename); - return retval; -} - -#endif /* HAVE_G_FILE_SET_CONTENTS */ - #ifdef WITH_GNOME_PRINT gboolean using_pdf_printer (GnomePrintConfig *config) @@ -503,15 +293,10 @@ save_print_config_to_file (GnomePrintConfig *config) PRINT_CONFIG_FILENAME, NULL); -#ifdef HAVE_G_FILE_SET_CONTENTS g_file_set_contents (file_name, str, -1, NULL); -#else - ev_file_set_contents (file_name, str, -1, NULL); -#endif g_free (file_name); g_free (str); } #endif /* WITH_GNOME_PRINT */ - -- cgit v0.9.1