From 11368f9b50db86ce4f2ae0b549fb575a19af2a74 Mon Sep 17 00:00:00 2001 From: Marco Pesenti Gritti Date: Tue, 10 May 2005 12:48:34 +0000 Subject: Put the toolbar xml in evince own dot dir 2005-05-10 Marco Pesenti Gritti * lib/Makefile.am: * shell/ev-window.c: (ev_window_cmd_edit_toolbar_cb), (ev_window_init): * shell/main.c: (main): Put the toolbar xml in evince own dot dir --- diff --git a/ChangeLog b/ChangeLog index 5e72f86..e474af6 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,14 @@ 2005-05-10 Marco Pesenti Gritti + * lib/Makefile.am: + * shell/ev-window.c: (ev_window_cmd_edit_toolbar_cb), + (ev_window_init): + * shell/main.c: (main): + + Put the toolbar xml in evince own dot dir + +2005-05-10 Marco Pesenti Gritti + * shell/ev-window.c: (ev_window_init): Make the toolbar not removable diff --git a/lib/Makefile.am b/lib/Makefile.am index 9a3bd51..6bcfc2e 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -12,4 +12,6 @@ noinst_LTLIBRARIES = libev.la libev_la_SOURCES= \ ev-debug.c \ ev-debug.h \ + ev-file-helpers.c \ + ev-file-helpers.h \ $(NULL) diff --git a/lib/ev-file-helpers.c b/lib/ev-file-helpers.c new file mode 100644 index 0000000..d9daf6a --- /dev/null +++ b/lib/ev-file-helpers.c @@ -0,0 +1,83 @@ +/* + * Copyright (C) 2002 Jorn Baayen + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * $Id$ + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include +#include +#include + +#include "ev-file-helpers.h" + +static char *dot_dir = NULL; + +static gboolean +ensure_dir_exists (const char *dir) +{ + if (g_file_test (dir, G_FILE_TEST_IS_DIR) == FALSE) + { + if (g_file_test (dir, G_FILE_TEST_EXISTS) == TRUE) + { + g_warning ("%s exists, please move it out of the way.", dir); + return FALSE; + } + + if (mkdir (dir, 488) != 0) + { + g_warning ("Failed to create directory %s.", dir); + return FALSE; + } + } + + return TRUE; +} + +const char * +ev_dot_dir (void) +{ + if (dot_dir == NULL) + { + gboolean exists; + + dot_dir = g_build_filename (g_get_home_dir (), + GNOME_DOT_GNOME, + "evince", + NULL); + + exists = ensure_dir_exists (dot_dir); + g_assert (exists); + } + + return dot_dir; +} + +void +ev_file_helpers_init (void) +{ +} + +void +ev_file_helpers_shutdown (void) +{ + g_free (dot_dir); + dot_dir = NULL; +} diff --git a/lib/ev-file-helpers.h b/lib/ev-file-helpers.h new file mode 100644 index 0000000..43dc75c --- /dev/null +++ b/lib/ev-file-helpers.h @@ -0,0 +1,36 @@ +/* + * Copyright (C) 2002 Jorn Baayen + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * $Id$ + */ + +#ifndef EPHY_FILE_HELPERS_H +#define EPHY_FILE_HELPERS_H + +#include + +G_BEGIN_DECLS + +const char *ev_dot_dir (void); + +void ev_file_helpers_init (void); + +void ev_file_helpers_shutdown (void); + +G_END_DECLS + +#endif /* EPHY_FILE_HELPERS_H */ diff --git a/shell/ev-window.c b/shell/ev-window.c index 6a6e00d..2db012d 100644 --- a/shell/ev-window.c +++ b/shell/ev-window.c @@ -52,6 +52,9 @@ #include "egg-editable-toolbar.h" #include "ephy-zoom.h" #include "ephy-zoom-action.h" +#include "ev-application.h" +#include "ev-stock-icons.h" +#include "ev-file-helpers.h" #include #include @@ -66,9 +69,6 @@ #include -#include "ev-application.h" -#include "ev-stock-icons.h" - typedef enum { PAGE_MODE_SINGLE_PAGE, PAGE_MODE_CONTINUOUS_PAGE, @@ -1666,8 +1666,10 @@ static void ev_window_cmd_edit_toolbar_cb (GtkDialog *dialog, gint response, gpointer data) { EvWindow *ev_window = EV_WINDOW (data); - egg_editable_toolbar_set_edit_mode (EGG_EDITABLE_TOOLBAR (ev_window->priv->toolbar), FALSE); - egg_toolbars_model_save (ev_window->priv->toolbar_model, ev_window->priv->toolbar_file, "1.0"); + egg_editable_toolbar_set_edit_mode + (EGG_EDITABLE_TOOLBAR (ev_window->priv->toolbar), FALSE); + egg_toolbars_model_save (ev_window->priv->toolbar_model, + ev_window->priv->toolbar_file, "1.0"); gtk_widget_destroy (GTK_WIDGET (dialog)); } @@ -2714,7 +2716,7 @@ ev_window_init (EvWindow *ev_window) ev_window->priv->toolbar_model = egg_toolbars_model_new (); ev_window->priv->toolbar_file = g_build_filename - (g_get_home_dir (), ".gnome2/evince_toolbar.xml", NULL); + (ev_dot_dir (), "evince_toolbar.xml", NULL); if (!g_file_test (ev_window->priv->toolbar_file, G_FILE_TEST_EXISTS)) { egg_toolbars_model_load (ev_window->priv->toolbar_model, diff --git a/shell/main.c b/shell/main.c index 321334b..b0a0b76 100644 --- a/shell/main.c +++ b/shell/main.c @@ -32,6 +32,7 @@ #include "ev-stock-icons.h" #include "ev-debug.h" #include "ev-job-queue.h" +#include "ev-file-helpers.h" static struct poptOption popt_options[] = { @@ -87,6 +88,7 @@ main (int argc, char *argv[]) ev_job_queue_init (); g_set_application_name (_("Evince Document Viewer")); + ev_file_helpers_init (); ev_debug_init (); ev_stock_icons_init (); gtk_window_set_default_icon_name ("postscript-viewer"); @@ -102,6 +104,7 @@ main (int argc, char *argv[]) gnome_accelerators_sync (); poptFreeContext (context); + ev_file_helpers_shutdown (); return 0; } -- cgit v0.9.1