]> www.fi.muni.cz Git - evince.git/blobdiff - backend/ev-document.c
Updated Catalan translation by Gil Forcada <gilforcada@guifi.net>.
[evince.git] / backend / ev-document.c
index dcc620483dd10729a93884d4fff338395924af19..a53cbeafa6c1d4f082bc736600fe99c41b6fe72f 100644 (file)
@@ -23,7 +23,7 @@
 #include "ev-document.h"
 #include "ev-backend-marshalers.h"
 
-static void ev_document_base_init (gpointer g_class);
+static void ev_document_class_init (gpointer g_class);
 
 enum
 {
@@ -43,8 +43,9 @@ ev_document_get_type (void)
                static const GTypeInfo our_info =
                {
                        sizeof (EvDocumentIface),
-                       ev_document_base_init,
                        NULL,
+                       NULL,
+                       (GClassInitFunc)ev_document_class_init
                };
 
                type = g_type_register_static (G_TYPE_INTERFACE,
@@ -55,25 +56,35 @@ ev_document_get_type (void)
        return type;
 }
 
-static void
-ev_document_base_init (gpointer g_class)
+GQuark
+ev_document_error_quark (void)
 {
-       static gboolean initialized = FALSE;
+  static GQuark q = 0;
+  if (q == 0)
+    q = g_quark_from_static_string ("ev-document-error-quark");
 
-       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;
-       }
+  return q;
+}
+
+static void
+ev_document_class_init (gpointer g_class)
+{
+       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);
+
+       g_object_interface_install_property (g_class,
+                               g_param_spec_string ("title",
+                                                    "Document Title",
+                                                    "The title of the document",
+                                                    NULL,
+                                                    G_PARAM_READABLE));
 }
 
 gboolean
@@ -85,6 +96,25 @@ ev_document_load (EvDocument  *document,
        return iface->load (document, uri, error);
 }
 
+gboolean
+ev_document_save (EvDocument  *document,
+                 const char  *uri,
+                 GError     **error)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+       return iface->save (document, uri, error);
+}
+
+char *
+ev_document_get_title (EvDocument  *document)
+{
+       char *title;
+
+       g_object_get (document, "title", &title, NULL);
+
+       return title;
+}
+
 int
 ev_document_get_n_pages (EvDocument  *document)
 {
@@ -134,11 +164,29 @@ ev_document_set_page_offset (EvDocument  *document,
 
 void
 ev_document_get_page_size   (EvDocument   *document,
+                            int           page,
                             int          *width,
                             int          *height)
 {
        EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
-       iface->get_page_size (document, width, height);
+       iface->get_page_size (document, page, width, height);
+}
+
+char *
+ev_document_get_text (EvDocument   *document,
+                     GdkRectangle *rect)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+       return iface->get_text (document, rect);
+}
+
+EvLink *
+ev_document_get_link (EvDocument   *document,
+                     int           x,
+                     int           y)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+       return iface->get_link (document, x, y);
 }
 
 void