]> www.fi.muni.cz Git - evince.git/blobdiff - backend/ev-document.c
Grab focus on the view when clicking it
[evince.git] / backend / ev-document.c
index 02c24427f288c2523cd49a0e1eeed8ae8d98ae14..dcc620483dd10729a93884d4fff338395924af19 100644 (file)
 #include "config.h"
 
 #include "ev-document.h"
-#include "ev-backend-marshal.c"
+#include "ev-backend-marshalers.h"
 
 static void ev_document_base_init (gpointer g_class);
 
+enum
+{
+       CHANGED,
+       LAST_SIGNAL
+};
+
+static guint signals[LAST_SIGNAL] = { 0 };
+
 GType
 ev_document_get_type (void)
 {
@@ -52,17 +60,17 @@ ev_document_base_init (gpointer g_class)
 {
        static gboolean initialized = FALSE;
 
-       if (!initialized) {
-               g_signal_new ("found",
-                             EV_TYPE_DOCUMENT,
-                             G_SIGNAL_RUN_LAST,
-                             G_STRUCT_OFFSET (EvDocumentIface, found),
-                             NULL, NULL,
-                             _ev_backend_marshal_VOID__POINTER_INT_DOUBLE,
-                             G_TYPE_NONE, 3,
-                             G_TYPE_POINTER,
-                             G_TYPE_INT,
-                             G_TYPE_DOUBLE);
+       if (!initialized)
+       {
+               signals[CHANGED] =
+                       g_signal_new ("changed",
+                                     EV_TYPE_DOCUMENT,
+                                     G_SIGNAL_RUN_LAST,
+                                     G_STRUCT_OFFSET (EvDocumentIface, changed),
+                                     NULL, NULL,
+                                     g_cclosure_marshal_VOID__VOID,
+                                     G_TYPE_NONE,
+                                     0);
 
                initialized = TRUE;
        }
@@ -92,6 +100,13 @@ ev_document_set_page (EvDocument  *document,
        iface->set_page (document, page);
 }
 
+int
+ev_document_get_page (EvDocument *document)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+       return iface->get_page (document);
+}
+
 void
 ev_document_set_target (EvDocument  *document,
                        GdkDrawable *target)
@@ -138,17 +153,7 @@ ev_document_render (EvDocument  *document,
 }
 
 void
-ev_document_begin_find (EvDocument   *document,
-                       const char   *search_string,
-                       gboolean      case_sensitive)
-{
-       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
-       iface->begin_find (document, search_string, case_sensitive);
-}
-
-void
-ev_document_end_find (EvDocument   *document)
+ev_document_changed (EvDocument *document)
 {
-       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
-       iface->end_find (document);
-}
+       g_signal_emit (G_OBJECT (document), signals[CHANGED], 0);
+}