X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=backend%2Fev-document.c;h=6f6a687eef0686f4345e88b9661b079f9e70423c;hb=a0ed55c37314448eaa19c4c11198e32ddb899bbc;hp=2f50dcc832d05bdbdc14254f00d47f8c12b2ea93;hpb=110ec8e1d24701cae441a5fe511611aaa478fd3b;p=evince.git diff --git a/backend/ev-document.c b/backend/ev-document.c index 2f50dcc8..6f6a687e 100644 --- a/backend/ev-document.c +++ b/backend/ev-document.c @@ -21,9 +21,17 @@ #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); +static void ev_document_class_init (gpointer g_class); + +enum +{ + CHANGED, + LAST_SIGNAL +}; + +static guint signals[LAST_SIGNAL] = { 0 }; GType ev_document_get_type (void) @@ -35,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, @@ -47,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) { - g_signal_new ("found", + 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, found), + G_STRUCT_OFFSET (EvDocumentIface, changed), NULL, NULL, - _ev_backend_marshal_VOID__POINTER_INT_DOUBLE, - G_TYPE_NONE, 3, - G_TYPE_POINTER, - G_TYPE_INT, - G_TYPE_DOUBLE); - - initialized = TRUE; - } + 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 @@ -77,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) { @@ -133,41 +171,36 @@ ev_document_get_page_size (EvDocument *document, iface->get_page_size (document, width, height); } -void -ev_document_render (EvDocument *document, - int clip_x, - int clip_y, - int clip_width, - int clip_height) +char * +ev_document_get_text (EvDocument *document, + GdkRectangle *rect) { EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document); - iface->render (document, clip_x, clip_y, clip_width, clip_height); + return iface->get_text (document, rect); } -void -ev_document_begin_find (EvDocument *document, - const char *search_string, - gboolean case_sensitive) +EvLink * +ev_document_get_link (EvDocument *document, + int x, + int y) { EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document); - iface->begin_find (document, search_string, case_sensitive); + return iface->get_link (document, x, y); } void -ev_document_end_find (EvDocument *document) +ev_document_render (EvDocument *document, + int clip_x, + int clip_y, + int clip_width, + int clip_height) { EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document); - iface->end_find (document); + iface->render (document, clip_x, clip_y, clip_width, clip_height); } void -ev_document_found (EvDocument *document, - const EvFindResult *results, - int n_results, - double percent_complete) +ev_document_changed (EvDocument *document) { - g_signal_emit_by_name (document, - "found", - results, n_results, percent_complete); -} - + g_signal_emit (G_OBJECT (document), signals[CHANGED], 0); +}