]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-jobs.h
Invert collate action in order to work as expected, fix reverse printing
[evince.git] / shell / ev-jobs.h
index 052319898c7c0223eb755f214252b616a332dc69..c6d73a1a3614453856dce2a975318ae448a83443 100644 (file)
@@ -23,6 +23,7 @@
 #include <gtk/gtk.h>
 #include "ev-document.h"
 #include "ev-window.h"
+#include "ev-selection.h"
 
 G_BEGIN_DECLS
 
@@ -44,6 +45,9 @@ typedef struct _EvJobFontsClass EvJobFontsClass;
 typedef struct _EvJobLoad EvJobLoad;
 typedef struct _EvJobLoadClass EvJobLoadClass;
 
+typedef struct _EvJobSave EvJobSave;
+typedef struct _EvJobSaveClass EvJobSaveClass;
+
 typedef struct _EvJobPrint EvJobPrint;
 typedef struct _EvJobPrintClass EvJobPrintClass;
 
@@ -77,10 +81,15 @@ typedef struct _EvJobPrintClass EvJobPrintClass;
 #define EV_JOB_LOAD_CLASS(klass)            (G_TYPE_CHECK_CLASS_CAST((klass), EV_TYPE_JOB_LOAD, EvJobLoadClass))
 #define EV_IS_JOB_LOAD(object)              (G_TYPE_CHECK_INSTANCE_TYPE((object), EV_TYPE_JOB_LOAD))
 
-#define EV_TYPE_JOB_PRINT                     (ev_job_print_get_type())
-#define EV_JOB_PRINT(object)                  (G_TYPE_CHECK_INSTANCE_CAST((object), EV_TYPE_JOB_PRINT, EvJobPrint))
-#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_SAVE                    (ev_job_save_get_type())
+#define EV_JOB_SAVE(object)                 (G_TYPE_CHECK_INSTANCE_CAST((object), EV_TYPE_JOB_SAVE, EvJobSave))
+#define EV_JOB_SAVE_CLASS(klass)            (G_TYPE_CHECK_CLASS_CAST((klass), EV_TYPE_JOB_SAVE, EvJobSaveClass))
+#define EV_IS_JOB_SAVE(object)              (G_TYPE_CHECK_INSTANCE_TYPE((object), EV_TYPE_JOB_SAVE))
+
+#define EV_TYPE_JOB_PRINT                    (ev_job_print_get_type())
+#define EV_JOB_PRINT(object)                 (G_TYPE_CHECK_INSTANCE_CAST((object), EV_TYPE_JOB_PRINT, EvJobPrint))
+#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))
 
 typedef enum {
        EV_JOB_PRIORITY_LOW,
@@ -119,6 +128,7 @@ struct _EvJobRender
        EvJob parent;
 
        EvRenderContext *rc;
+       gboolean page_ready;
        gint target_width;
        gint target_height;
        cairo_surface_t *surface;
@@ -131,6 +141,7 @@ struct _EvJobRender
        cairo_surface_t *selection;
        GdkRegion *selection_region;
        EvRectangle selection_points;
+       EvSelectionStyle selection_style;
        GdkColor base;
        GdkColor text; 
 
@@ -144,6 +155,8 @@ struct _EvJobRender
 struct _EvJobRenderClass
 {
        EvJobClass parent_class;
+
+       void    (* page_ready) (EvJobRender *job);
 };
 
 struct _EvJobThumbnail
@@ -176,6 +189,7 @@ struct _EvJobLoad
        
        EvLinkDest *dest;
        EvWindowRunMode mode;
+       gchar *search_string;
        GError *error;
        gchar *uri;
 };
@@ -185,6 +199,20 @@ struct _EvJobLoadClass
        EvJobClass parent_class;
 };
 
+struct _EvJobSave
+{
+       EvJob parent;
+
+       GError *error;
+       gchar *uri;
+       gchar *document_uri;
+};
+
+struct _EvJobSaveClass
+{
+       EvJobClass parent_class;
+};
+
 struct _EvJobPrint
 {
        EvJob parent;
@@ -196,6 +224,7 @@ struct _EvJobPrint
        gint n_ranges;
        EvPrintPageSet page_set;
        gint copies;
+       gint pages_per_sheet;
        gboolean collate;
        gboolean reverse;
        gdouble width;
@@ -223,6 +252,7 @@ EvJob          *ev_job_render_new         (EvDocument      *document,
                                           gint             width,
                                           gint             height,
                                           EvRectangle     *selection_points,
+                                          EvSelectionStyle selection_style,
                                           GdkColor        *text,
                                           GdkColor        *base,
                                           gboolean         include_forms,
@@ -247,11 +277,19 @@ void              ev_job_fonts_run          (EvJobFonts      *fonts);
 GType          ev_job_load_get_type      (void) G_GNUC_CONST;
 EvJob         *ev_job_load_new           (const gchar     *uri,
                                           EvLinkDest      *dest,
-                                          EvWindowRunMode  mode);
+                                          EvWindowRunMode  mode,
+                                          const gchar     *search_string);
 void            ev_job_load_set_uri       (EvJobLoad       *load,
                                           const gchar     *uri);
 void           ev_job_load_run           (EvJobLoad       *load);
 
+/* EvJobSave */
+GType           ev_job_save_get_type      (void) G_GNUC_CONST;
+EvJob          *ev_job_save_new           (EvDocument      *document,
+                                          const gchar     *uri,
+                                          const gchar     *document_uri);
+void            ev_job_save_run           (EvJobSave       *save);
+
 /* EvJobPrint */
 GType           ev_job_print_get_type     (void) G_GNUC_CONST;
 EvJob          *ev_job_print_new          (EvDocument      *document,
@@ -261,6 +299,7 @@ EvJob          *ev_job_print_new          (EvDocument      *document,
                                           EvPrintRange    *ranges,
                                           gint             n_ranges,
                                           EvPrintPageSet   page_set,
+                                          gint             pages_per_sheet,
                                           gint             copies,
                                           gdouble          collate,
                                           gdouble          reverse);