X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fmain.c;h=f6600f0f19edafc347dddff103e28797f0ee8066;hb=28df8004a43a579e93ea905a2426fe42e1e6dfa7;hp=d412a5e570d4d70867fb794492ff0c2265694d2d;hpb=616f5c97013f1344caa6e899de6cc99664faa5e9;p=evince.git diff --git a/shell/main.c b/shell/main.c index d412a5e5..f6600f0f 100644 --- a/shell/main.c +++ b/shell/main.c @@ -21,12 +21,14 @@ #include "config.h" #include "ev-application.h" +#include "ev-metadata-manager.h" #include #include #include #include #include +#include #include #ifdef ENABLE_DBUS @@ -52,7 +54,7 @@ load_files (const char **files) int i; if (!files) { - ev_application_open_window (EV_APP); + ev_application_open_window (EV_APP, NULL); return; } @@ -60,25 +62,29 @@ load_files (const char **files) char *uri; uri = gnome_vfs_make_uri_from_shell_arg (files[i]); - ev_application_open_uri (EV_APP, uri, ev_page_label); + ev_application_open_uri (EV_APP, uri, ev_page_label, NULL); g_free (uri); } } #ifdef ENABLE_DBUS -static void +static gboolean load_files_remote (const char **files) { int i; - GError *error; + GError *error = NULL; DBusGConnection *connection; +#if DBUS_VERSION < 35 DBusGPendingCall *call; +#endif DBusGProxy *remote_object; connection = dbus_g_bus_get (DBUS_BUS_SESSION, &error); if (connection == NULL) { g_warning (error->message); - return; + g_error_free (error); + + return FALSE; } remote_object = dbus_g_proxy_new_for_name (connection, @@ -86,36 +92,64 @@ load_files_remote (const char **files) "/org/gnome/evince/Evince", "org.gnome.evince.Application"); if (!files) { - call = dbus_g_proxy_begin_call (remote_object, "OpenWindow", DBUS_TYPE_INVALID); - if (!dbus_g_proxy_end_call (remote_object, call, &error, DBUS_TYPE_INVALID)) { +#if DBUS_VERSION < 35 + call = dbus_g_proxy_begin_call (remote_object, "OpenWindow", G_TYPE_INVALID); + + if (!dbus_g_proxy_end_call (remote_object, call, &error, G_TYPE_INVALID)) { g_warning (error->message); + g_clear_error (&error); + return FALSE; } - return; +#else + if (!dbus_g_proxy_call (remote_object, "OpenWindow", &error, G_TYPE_INVALID)) { + g_warning (error->message); + g_clear_error (&error); + return FALSE; + } +#endif + return TRUE; } for (i = 0; files[i]; i++) { + gboolean result = TRUE; const char *page_label; char *uri; uri = gnome_vfs_make_uri_from_shell_arg (files[i]); page_label = ev_page_label ? ev_page_label : ""; - +#if DBUS_VERSION < 35 call = dbus_g_proxy_begin_call (remote_object, "OpenURI", - DBUS_TYPE_STRING, &uri, - DBUS_TYPE_STRING, &page_label, - DBUS_TYPE_INVALID); - if (!dbus_g_proxy_end_call (remote_object, call, &error, DBUS_TYPE_INVALID)) { + G_TYPE_STRING, uri, + G_TYPE_STRING, page_label, + G_TYPE_INVALID); + + if (!dbus_g_proxy_end_call (remote_object, call, &error, G_TYPE_INVALID)) { g_warning (error->message); + g_clear_error (&error); + result = FALSE; } - +#else + if (!dbus_g_proxy_call (remote_object, "OpenURI", &error, + G_TYPE_STRING, uri, + G_TYPE_STRING, page_label, + G_TYPE_INVALID)) { + g_warning (error->message); + g_clear_error (&error); + result = FALSE; + } +#endif g_free (uri); + return result; } + + return TRUE; } -#endif +#endif /* ENABLE_DBUS */ int main (int argc, char *argv[]) { + gboolean enable_metadata = FALSE; poptContext context; GValue context_as_value = { 0 }; GnomeProgram *program; @@ -141,14 +175,23 @@ main (int argc, char *argv[]) #ifdef ENABLE_DBUS if (!ev_application_register_service (EV_APP)) { - load_files_remote (poptGetArgs (context)); - g_warning ("Another process was running."); - return 0; + if (load_files_remote (poptGetArgs (context))) { + g_warning ("Another process was running."); + return 0; + } } else { g_warning ("Starting evince process."); + enable_metadata = TRUE; } #endif + gnome_authentication_manager_init (); + + + if (enable_metadata) { + ev_metadata_manager_init (); + } + ev_job_queue_init (); g_set_application_name (_("Evince Document Viewer")); @@ -165,5 +208,9 @@ main (int argc, char *argv[]) poptFreeContext (context); ev_file_helpers_shutdown (); + if (enable_metadata) { + ev_metadata_manager_shutdown (); + } + return 0; }