]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-jobs.h
Rename error as mdvi_error to avoid symbol conflicts with the libc error.
[evince.git] / shell / ev-jobs.h
index e89f64649ff2072dc49380573720a6c3adbbe344..188759e928972098d833f49fc4150b4861557ecf 100644 (file)
@@ -57,6 +57,9 @@ typedef struct _EvJobSaveClass EvJobSaveClass;
 typedef struct _EvJobPrint EvJobPrint;
 typedef struct _EvJobPrintClass EvJobPrintClass;
 
+typedef struct _EvJobFind EvJobFind;
+typedef struct _EvJobFindClass EvJobFindClass;
+
 #define EV_TYPE_JOB                         (ev_job_get_type())
 #define EV_JOB(object)                      (G_TYPE_CHECK_INSTANCE_CAST((object), EV_TYPE_JOB, EvJob))
 #define EV_JOB_CLASS(klass)                 (G_TYPE_CHECK_CLASS_CAST((klass), EV_TYPE_JOB, EvJobClass))
@@ -103,6 +106,11 @@ typedef struct _EvJobPrintClass EvJobPrintClass;
 #define EV_JOB_PRINT_CLASS(klass)            (G_TYPE_CHECK_CLASS_CAST((klass), EV_TYPE_JOB_PRINT, EvJobPrintClass))
 #define EV_IS_JOB_PRINT(object)              (G_TYPE_CHECK_INSTANCE_TYPE((object), EV_TYPE_JOB_PRINT))
 
+#define EV_TYPE_JOB_FIND                    (ev_job_find_get_type())
+#define EV_JOB_FIND(object)                 (G_TYPE_CHECK_INSTANCE_CAST((object), EV_TYPE_JOB_FIND, EvJobFind))
+#define EV_JOB_FIND_CLASS(klass)            (G_TYPE_CHECK_CLASS_CAST((klass), EV_TYPE_JOB_FIND, EvJobFindClass))
+#define EV_IS_JOB_FIND(object)              (G_TYPE_CHECK_INSTANCE_TYPE((object), EV_TYPE_JOB_FIND))
+
 typedef enum {
        EV_JOB_RUN_THREAD,
        EV_JOB_RUN_MAIN_LOOP
@@ -235,7 +243,8 @@ struct _EvJobFontsClass
         EvJobClass parent_class;
 
        /* Signals */
-       void (* updated)  (EvJobFonts *job);
+       void (* updated)  (EvJobFonts *job,
+                          gdouble     progress);
 };
 
 struct _EvJobLoad
@@ -289,6 +298,28 @@ struct _EvJobPrintClass
        EvJobClass parent_class;
 };
 
+struct _EvJobFind
+{
+       EvJob parent;
+
+       gint start_page;
+       gint current_page;
+       gint n_pages;
+       GList **pages;
+       gchar *text;
+       gboolean case_sensitive;
+       gboolean has_results;
+};
+
+struct _EvJobFindClass
+{
+       EvJobClass parent_class;
+
+       /* Signals */
+       void (* updated)  (EvJobFind *job,
+                          gint       page);
+};
+
 /* Base job class */
 GType           ev_job_get_type           (void) G_GNUC_CONST;
 gboolean        ev_job_run                (EvJob          *job);
@@ -370,6 +401,18 @@ EvJob          *ev_job_print_new          (EvDocument      *document,
                                           gint             copies,
                                           gdouble          collate,
                                           gdouble          reverse);
+/* EvJobFind */
+GType           ev_job_find_get_type      (void) G_GNUC_CONST;
+EvJob          *ev_job_find_new           (EvDocument      *document,
+                                          gint             start_page,
+                                          gint             n_pages,
+                                          const gchar     *text,
+                                          gboolean         case_sensitive);
+gint            ev_job_find_get_n_results (EvJobFind       *job,
+                                          gint             pages);
+gdouble         ev_job_find_get_progress  (EvJobFind       *job);
+gboolean        ev_job_find_has_results   (EvJobFind       *job);
+GList         **ev_job_find_get_results   (EvJobFind       *job);
 
 G_END_DECLS