Commit 0b7b696bd0e19818a87c4adbd94bd5bdef4192ca
1 parent
d3931317
Exists in
master
and in
1 other branch
Updating print dialog.
Showing
9 changed files
with
199 additions
and
439 deletions
Show diff stats
| @@ -0,0 +1,72 @@ | @@ -0,0 +1,72 @@ | ||
| 1 | +/* | ||
| 2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | ||
| 3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | ||
| 4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | ||
| 5 | + * | ||
| 6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | ||
| 7 | + * | ||
| 8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | ||
| 9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | ||
| 10 | + * Free Software Foundation. | ||
| 11 | + * | ||
| 12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | ||
| 13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | ||
| 14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | ||
| 15 | + * obter mais detalhes. | ||
| 16 | + * | ||
| 17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | ||
| 18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | ||
| 19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | ||
| 20 | + * | ||
| 21 | + * Este programa está nomeado como - e possui - linhas de código. | ||
| 22 | + * | ||
| 23 | + * Contatos: | ||
| 24 | + * | ||
| 25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | ||
| 26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | ||
| 27 | + * | ||
| 28 | + */ | ||
| 29 | + | ||
| 30 | + #include <v3270.h> | ||
| 31 | + #include <v3270/print.h> | ||
| 32 | + #include <lib3270/log.h> | ||
| 33 | + | ||
| 34 | +/*--[ Widget definition ]----------------------------------------------------------------------------*/ | ||
| 35 | + | ||
| 36 | + LIB3270_EXPORT GtkWidget * v3270_font_selection_new(const gchar *fontname) | ||
| 37 | + { | ||
| 38 | + GtkTreeModel * model = (GtkTreeModel *) gtk_list_store_new(1,G_TYPE_STRING); | ||
| 39 | + GtkWidget * widget = gtk_combo_box_new_with_model(model); | ||
| 40 | + | ||
| 41 | + GtkCellRenderer * renderer = gtk_cell_renderer_text_new(); | ||
| 42 | + gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(widget), renderer, TRUE); | ||
| 43 | + gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(widget), renderer, "text", 0, NULL); | ||
| 44 | + | ||
| 45 | + if(!(fontname && *fontname)) | ||
| 46 | + fontname = v3270_get_default_font_name(); | ||
| 47 | + | ||
| 48 | + gint n_families, i; | ||
| 49 | + PangoFontFamily **families; | ||
| 50 | + pango_context_list_families(gtk_widget_get_pango_context(widget),&families, &n_families); | ||
| 51 | + | ||
| 52 | + for(i=0; i < n_families; i++) | ||
| 53 | + { | ||
| 54 | + if(!pango_font_family_is_monospace(families[i])) | ||
| 55 | + continue; | ||
| 56 | + | ||
| 57 | + const gchar *name = pango_font_family_get_name (families[i]); | ||
| 58 | + GtkTreeIter iter; | ||
| 59 | + | ||
| 60 | + gtk_list_store_append((GtkListStore *) model,&iter); | ||
| 61 | + gtk_list_store_set((GtkListStore *) model, &iter,0, name, -1); | ||
| 62 | + | ||
| 63 | + if(!g_ascii_strcasecmp(name,fontname)) | ||
| 64 | + gtk_combo_box_set_active_iter(GTK_COMBO_BOX(widget),&iter); | ||
| 65 | + | ||
| 66 | + } | ||
| 67 | + | ||
| 68 | + g_free(families); | ||
| 69 | + | ||
| 70 | + return widget; | ||
| 71 | + } | ||
| 72 | + |
src/include/v3270.h
| @@ -220,6 +220,7 @@ | @@ -220,6 +220,7 @@ | ||
| 220 | 220 | ||
| 221 | // Misc | 221 | // Misc |
| 222 | LIB3270_EXPORT GtkIMContext * v3270_get_im_context(GtkWidget *widget); | 222 | LIB3270_EXPORT GtkIMContext * v3270_get_im_context(GtkWidget *widget); |
| 223 | + LIB3270_EXPORT const gchar * v3270_get_default_font_name(); | ||
| 223 | 224 | ||
| 224 | LIB3270_EXPORT gboolean v3270_get_toggle(GtkWidget *widget, LIB3270_TOGGLE ix); | 225 | LIB3270_EXPORT gboolean v3270_get_toggle(GtkWidget *widget, LIB3270_TOGGLE ix); |
| 225 | LIB3270_EXPORT gboolean v3270_set_toggle(GtkWidget *widget, LIB3270_TOGGLE ix, gboolean state); | 226 | LIB3270_EXPORT gboolean v3270_set_toggle(GtkWidget *widget, LIB3270_TOGGLE ix, gboolean state); |
src/include/v3270/print.h
| @@ -40,18 +40,20 @@ | @@ -40,18 +40,20 @@ | ||
| 40 | 40 | ||
| 41 | #define GTK_TYPE_V3270_PRINT_OPERATION (V3270PrintOperation_get_type()) | 41 | #define GTK_TYPE_V3270_PRINT_OPERATION (V3270PrintOperation_get_type()) |
| 42 | #define GTK_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperation)) | 42 | #define GTK_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperation)) |
| 43 | - #define GTK_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperationClass)) | 43 | + #define GTK_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperationClass)) |
| 44 | #define GTK_IS_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_V3270_PRINT_OPERATION)) | 44 | #define GTK_IS_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_V3270_PRINT_OPERATION)) |
| 45 | - #define GTK_IS_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_V3270_PRINT_OPERATION)) | ||
| 46 | - #define GTK_V3270_PRINT_OPERATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270V3270PrintOperationClass)) | 45 | + #define GTK_IS_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_V3270_PRINT_OPERATION)) |
| 46 | + #define GTK_V3270_PRINT_OPERATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270V3270PrintOperationClass)) | ||
| 47 | 47 | ||
| 48 | - typedef struct _V3270PrintOperation V3270PrintOperation; | ||
| 49 | - typedef struct _V3270PrintPrintOperation V3270PrintOperationClass; | 48 | + typedef struct _V3270PrintOperation V3270PrintOperation; |
| 49 | + typedef struct _V3270PrintOperationClass V3270PrintOperationClass; | ||
| 50 | 50 | ||
| 51 | /*--[ Prototipes ]-----------------------------------------------------------------------------------*/ | 51 | /*--[ Prototipes ]-----------------------------------------------------------------------------------*/ |
| 52 | 52 | ||
| 53 | LIB3270_EXPORT V3270PrintOperation * v3270_print_operation_new(GtkWidget *widget, LIB3270_PRINT_MODE mode); | 53 | LIB3270_EXPORT V3270PrintOperation * v3270_print_operation_new(GtkWidget *widget, LIB3270_PRINT_MODE mode); |
| 54 | 54 | ||
| 55 | + LIB3270_EXPORT GtkWidget * v3270_font_selection_new(const gchar *fontname); | ||
| 56 | + | ||
| 55 | G_END_DECLS | 57 | G_END_DECLS |
| 56 | 58 | ||
| 57 | #endif // V3270_PRINT_OPERATION_H_INCLUDED | 59 | #endif // V3270_PRINT_OPERATION_H_INCLUDED |
src/testprogram/testprogram.c
| @@ -103,6 +103,12 @@ static void color_scheme_changed(GtkWidget G_GNUC_UNUSED(*widget), const GdkRGBA | @@ -103,6 +103,12 @@ static void color_scheme_changed(GtkWidget G_GNUC_UNUSED(*widget), const GdkRGBA | ||
| 103 | 103 | ||
| 104 | } | 104 | } |
| 105 | 105 | ||
| 106 | +static void print_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *terminal) | ||
| 107 | +{ | ||
| 108 | + debug("%s",__FUNCTION__); | ||
| 109 | + v3270_print_all(terminal); | ||
| 110 | +} | ||
| 111 | + | ||
| 106 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | 112 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
| 107 | 113 | ||
| 108 | /* | 114 | /* |
| @@ -172,6 +178,9 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | @@ -172,6 +178,9 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | ||
| 172 | GtkWidget *box = gtk_box_new(GTK_ORIENTATION_VERTICAL,2); | 178 | GtkWidget *box = gtk_box_new(GTK_ORIENTATION_VERTICAL,2); |
| 173 | GtkWidget *grid = gtk_grid_new(); | 179 | GtkWidget *grid = gtk_grid_new(); |
| 174 | GtkWidget *color = v3270_color_scheme_new(); | 180 | GtkWidget *color = v3270_color_scheme_new(); |
| 181 | + GtkWidget *print = gtk_button_new_with_label("Print"); | ||
| 182 | + | ||
| 183 | + g_signal_connect(G_OBJECT(print),"clicked",G_CALLBACK(print_clicked),terminal); | ||
| 175 | 184 | ||
| 176 | gtk_widget_set_can_focus(color,FALSE); | 185 | gtk_widget_set_can_focus(color,FALSE); |
| 177 | gtk_widget_set_focus_on_click(color,FALSE); | 186 | gtk_widget_set_focus_on_click(color,FALSE); |
| @@ -179,6 +188,7 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | @@ -179,6 +188,7 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | ||
| 179 | g_signal_connect(G_OBJECT(color),"update-colors",G_CALLBACK(color_scheme_changed),terminal); | 188 | g_signal_connect(G_OBJECT(color),"update-colors",G_CALLBACK(color_scheme_changed),terminal); |
| 180 | 189 | ||
| 181 | gtk_grid_attach(GTK_GRID(grid),color,0,0,1,1); | 190 | gtk_grid_attach(GTK_GRID(grid),color,0,0,1,1); |
| 191 | + gtk_grid_attach(GTK_GRID(grid),print,1,0,1,1); | ||
| 182 | 192 | ||
| 183 | gtk_box_pack_start(GTK_BOX(box),grid,FALSE,TRUE,0); | 193 | gtk_box_pack_start(GTK_BOX(box),grid,FALSE,TRUE,0); |
| 184 | gtk_box_pack_start(GTK_BOX(box),terminal,TRUE,TRUE,0); | 194 | gtk_box_pack_start(GTK_BOX(box),terminal,TRUE,TRUE,0); |
src/trace/trace.c
| @@ -357,7 +357,7 @@ static void destroy(GtkWidget *widget) | @@ -357,7 +357,7 @@ static void destroy(GtkWidget *widget) | ||
| 357 | gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(window->scroll),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC); | 357 | gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(window->scroll),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC); |
| 358 | 358 | ||
| 359 | window->view = gtk_text_view_new(); | 359 | window->view = gtk_text_view_new(); |
| 360 | - v3270_trace_set_font_from_string(GTK_WIDGET(window),"Monospaced"); | 360 | + v3270_trace_set_font_from_string(GTK_WIDGET(window),v3270_get_default_font_name()); |
| 361 | 361 | ||
| 362 | window->text = gtk_text_view_get_buffer(GTK_TEXT_VIEW(window->view)); | 362 | window->text = gtk_text_view_get_buffer(GTK_TEXT_VIEW(window->view)); |
| 363 | gtk_text_view_set_editable(GTK_TEXT_VIEW(window->view), TRUE); | 363 | gtk_text_view_set_editable(GTK_TEXT_VIEW(window->view), TRUE); |
src/v3270/font.c
| @@ -44,6 +44,11 @@ | @@ -44,6 +44,11 @@ | ||
| 44 | 44 | ||
| 45 | /*--[ Implement ]------------------------------------------------------------------------------------*/ | 45 | /*--[ Implement ]------------------------------------------------------------------------------------*/ |
| 46 | 46 | ||
| 47 | +const gchar * v3270_get_default_font_name() | ||
| 48 | +{ | ||
| 49 | + return v3270_default_font; | ||
| 50 | +} | ||
| 51 | + | ||
| 47 | void v3270_update_font_metrics(v3270 *terminal, cairo_t *cr, int width, int height) | 52 | void v3270_update_font_metrics(v3270 *terminal, cairo_t *cr, int width, int height) |
| 48 | { | 53 | { |
| 49 | // update font metrics | 54 | // update font metrics |
src/v3270/print.c
| @@ -32,499 +32,180 @@ | @@ -32,499 +32,180 @@ | ||
| 32 | #include "private.h" | 32 | #include "private.h" |
| 33 | #include <v3270.h> | 33 | #include <v3270.h> |
| 34 | #include <v3270/colorscheme.h> | 34 | #include <v3270/colorscheme.h> |
| 35 | + #include <v3270/print.h> | ||
| 35 | #include <lib3270/selection.h> | 36 | #include <lib3270/selection.h> |
| 36 | #include <lib3270/log.h> | 37 | #include <lib3270/log.h> |
| 37 | #include <lib3270/trace.h> | 38 | #include <lib3270/trace.h> |
| 38 | 39 | ||
| 39 | - #define AUTO_FONT_SIZE 1 | 40 | +/*--[ Widget definition ]----------------------------------------------------------------------------*/ |
| 40 | 41 | ||
| 41 | -#ifdef AUTO_FONT_SIZE | ||
| 42 | - #define FONT_CONFIG "font-family" | ||
| 43 | - #define DEFAULT_FONT "Courier New" | ||
| 44 | -#else | ||
| 45 | - #define FONT_CONFIG "font" | ||
| 46 | - #define DEFAULT_FONT "Courier New 10" | ||
| 47 | -#endif // AUTO_FONT_SIZE | ||
| 48 | - | ||
| 49 | -/*--[ Structs ]--------------------------------------------------------------------------------------*/ | ||
| 50 | - | ||
| 51 | - typedef struct _print_info | ||
| 52 | - { | ||
| 53 | - GdkRGBA color[V3270_COLOR_COUNT]; | ||
| 54 | - int show_selection : 1; | ||
| 55 | - LIB3270_PRINT_MODE src; | ||
| 56 | - | ||
| 57 | - v3270 * widget; | ||
| 58 | - | ||
| 59 | - int baddr; | ||
| 60 | - int rows; | ||
| 61 | - int cols; ///< @brief Max line width. | ||
| 62 | - int pages; | ||
| 63 | - int lpp; ///< @brief Lines per page. | ||
| 64 | - | ||
| 65 | - v3270FontInfo font; | ||
| 66 | - | ||
| 67 | - double left; | ||
| 68 | - double width; ///< @brief Report width. | ||
| 69 | - double height; ///< @brief Report height (all pages). | ||
| 70 | - | ||
| 71 | - gchar **text; | ||
| 72 | - | ||
| 73 | - } PRINT_INFO; | ||
| 74 | - | ||
| 75 | - | ||
| 76 | -/*--[ Implement ]------------------------------------------------------------------------------------*/ | ||
| 77 | - | ||
| 78 | - static void begin_print(GtkPrintOperation *prt, GtkPrintContext *context, PRINT_INFO *info) | 42 | + struct _V3270PrintOperationClass |
| 79 | { | 43 | { |
| 80 | - cairo_font_extents_t extents; | ||
| 81 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | ||
| 82 | - | ||
| 83 | - // Setup font | ||
| 84 | - if(info->font.family) | ||
| 85 | - { | ||
| 86 | - PangoFontDescription * descr = pango_font_description_from_string(info->font.family); | ||
| 87 | - if(descr) | ||
| 88 | - { | ||
| 89 | - cairo_select_font_face(cr, pango_font_description_get_family(descr), | ||
| 90 | - CAIRO_FONT_SLANT_NORMAL, | ||
| 91 | - pango_font_description_get_weight(descr) == PANGO_WEIGHT_BOLD ? CAIRO_FONT_WEIGHT_BOLD : CAIRO_FONT_WEIGHT_NORMAL); | ||
| 92 | - | ||
| 93 | -#ifdef AUTO_FONT_SIZE | ||
| 94 | - { | ||
| 95 | - double width = gtk_print_context_get_width(context); | ||
| 96 | -#if GTK_CHECK_VERSION(3,0,0) | ||
| 97 | - double cols = (double) info->cols; | ||
| 98 | -#else | ||
| 99 | - double cols = (double) (info->cols+5); | ||
| 100 | -#endif // GTK(3,0,0) | ||
| 101 | - double current = width / cols; | ||
| 102 | - double valid = current; | ||
| 103 | - | ||
| 104 | - do | ||
| 105 | - { | ||
| 106 | - valid = current; | ||
| 107 | - current = valid +1.0; | ||
| 108 | - cairo_set_font_size(cr,current); | ||
| 109 | - cairo_font_extents(cr,&extents); | ||
| 110 | - } | ||
| 111 | - while( (cols * extents.max_x_advance) < width ); | ||
| 112 | - | ||
| 113 | - cairo_set_font_size(cr,valid); | ||
| 114 | - | ||
| 115 | - } | ||
| 116 | -#endif // AUTO_FONT_SIZE | ||
| 117 | - | ||
| 118 | - pango_font_description_free(descr); | ||
| 119 | - } | ||
| 120 | - } | ||
| 121 | - | ||
| 122 | - info->font.scaled = cairo_get_scaled_font(cr); | ||
| 123 | - cairo_scaled_font_reference(info->font.scaled); | ||
| 124 | - cairo_scaled_font_extents(info->font.scaled,&extents); | ||
| 125 | - | ||
| 126 | - info->font.height = extents.height; | ||
| 127 | - info->font.descent = extents.descent; | ||
| 128 | - info->font.width = extents.max_x_advance; | ||
| 129 | - | ||
| 130 | - info->width = ((double) info->cols) * extents.max_x_advance; | ||
| 131 | - info->height = ((double) info->rows) * (extents.height + extents.descent); | ||
| 132 | - | ||
| 133 | - // Center image | ||
| 134 | - info->left = (gtk_print_context_get_width(context)-info->width)/2; | ||
| 135 | - if(info->left < 2) | ||
| 136 | - info->left = 2; | ||
| 137 | - | ||
| 138 | - // Setup page size | ||
| 139 | - info->lpp = (gtk_print_context_get_height(context) / (extents.height + extents.descent)); | ||
| 140 | - info->pages = (info->rows / info->lpp)+1; | 44 | + GtkPrintOperationClass parent_class; |
| 141 | 45 | ||
| 142 | - gtk_print_operation_set_n_pages(prt,info->pages); | ||
| 143 | - } | 46 | + }; |
| 144 | 47 | ||
| 145 | - static void draw_screen(GtkPrintOperation *prt, GtkPrintContext *context, gint pg, PRINT_INFO *info) | 48 | + struct _V3270PrintOperation |
| 146 | { | 49 | { |
| 147 | - int row; | ||
| 148 | - int col; | ||
| 149 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | ||
| 150 | - int baddr = info->baddr; | ||
| 151 | - GdkRectangle rect; | 50 | + GtkPrintOperation parent; |
| 51 | + GdkRGBA color[V3270_COLOR_COUNT]; | ||
| 52 | + LIB3270_PRINT_MODE mode; | ||
| 53 | + v3270 * widget; | ||
| 54 | + H3270 * session; | ||
| 152 | 55 | ||
| 153 | - cairo_set_scaled_font(cr,info->font.scaled); | 56 | + struct { |
| 57 | + gchar * name; | ||
| 58 | + v3270FontInfo info; | ||
| 59 | + } font; | ||
| 154 | 60 | ||
| 155 | - memset(&rect,0,sizeof(rect)); | ||
| 156 | - rect.y = 2; | ||
| 157 | - rect.height = (info->font.height + info->font.descent); | ||
| 158 | - rect.width = info->font.width; | 61 | + gboolean show_selection; |
| 159 | 62 | ||
| 160 | - // Clear page | ||
| 161 | - gdk_cairo_set_source_rgba(cr,info->color+V3270_COLOR_BACKGROUND); | ||
| 162 | - cairo_rectangle(cr, info->left-2, 0, (rect.width*info->cols)+4, (rect.height*info->rows)+4); | ||
| 163 | - cairo_fill(cr); | ||
| 164 | - cairo_stroke(cr); | ||
| 165 | 63 | ||
| 166 | - rect.width++; | ||
| 167 | - rect.height++; | 64 | + }; |
| 168 | 65 | ||
| 169 | - for(row = 0; row < info->rows; row++) | ||
| 170 | - { | ||
| 171 | - rect.x = info->left; | ||
| 172 | - for(col = 0; col < info->cols; col++) | ||
| 173 | - { | ||
| 174 | - unsigned char c; | ||
| 175 | - unsigned short attr; | ||
| 176 | - | ||
| 177 | - if(!lib3270_get_element(info->widget->host,baddr++,&c,&attr) && (info->src == LIB3270_PRINT_ALL || (attr & LIB3270_ATTR_SELECTED))) | ||
| 178 | - { | ||
| 179 | - if(!info->show_selection) | ||
| 180 | - attr &= ~LIB3270_ATTR_SELECTED; | ||
| 181 | - v3270_draw_element(cr,c,attr,info->widget->host,&info->font,&rect,info->color); | ||
| 182 | - } | ||
| 183 | - | ||
| 184 | - rect.x += (rect.width-1); | ||
| 185 | - } | ||
| 186 | - rect.y += (rect.height-1); | 66 | + G_DEFINE_TYPE(V3270PrintOperation, V3270PrintOperation, GTK_TYPE_PRINT_OPERATION); |
| 187 | 67 | ||
| 188 | - } | ||
| 189 | - } | ||
| 190 | - | ||
| 191 | - /* | ||
| 192 | - static void show_print_error(GtkWidget *widget, GError *err) | ||
| 193 | - { | ||
| 194 | - GtkWidget *dialog = gtk_message_dialog_new_with_markup( GTK_WINDOW(gtk_widget_get_toplevel(widget)), | ||
| 195 | - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | ||
| 196 | - GTK_MESSAGE_ERROR,GTK_BUTTONS_CLOSE, | ||
| 197 | - "%s",_( "Print operation failed" )); | ||
| 198 | - | ||
| 199 | - g_warning("%s",err->message); | ||
| 200 | - | ||
| 201 | - gtk_window_set_title(GTK_WINDOW(dialog),_("Error")); | ||
| 202 | - | ||
| 203 | - gtk_message_dialog_format_secondary_markup(GTK_MESSAGE_DIALOG(dialog),"%s",err->message); | ||
| 204 | - | ||
| 205 | - gtk_dialog_run(GTK_DIALOG(dialog)); | ||
| 206 | - gtk_widget_destroy(dialog); | ||
| 207 | -} | ||
| 208 | -*/ | 68 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ |
| 209 | 69 | ||
| 210 | - static void done(GtkPrintOperation *prt, GtkPrintOperationResult result, PRINT_INFO *info) | 70 | + static void done(GtkPrintOperation *prt, GtkPrintOperationResult result) |
| 211 | { | 71 | { |
| 212 | - debug("%s(%p)",__FUNCTION__,info->widget); | ||
| 213 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_DONE], 0, prt, (guint) result); | 72 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); |
| 214 | 73 | ||
| 215 | debug("%s",__FUNCTION__); | 74 | debug("%s",__FUNCTION__); |
| 216 | - if(info->font.scaled) | ||
| 217 | - cairo_scaled_font_destroy(info->font.scaled); | ||
| 218 | - | ||
| 219 | - debug("%s",__FUNCTION__); | ||
| 220 | - if(info->text) | ||
| 221 | - g_strfreev(info->text); | ||
| 222 | - | ||
| 223 | - debug("%s",__FUNCTION__); | ||
| 224 | - if(info->font.family) | ||
| 225 | - g_free(info->font.family); | ||
| 226 | - | ||
| 227 | - debug("%s",__FUNCTION__); | ||
| 228 | - g_free(info); | ||
| 229 | - debug("%s",__FUNCTION__); | ||
| 230 | - } | ||
| 231 | - | ||
| 232 | -#ifndef AUTO_FONT_SIZE | ||
| 233 | - | ||
| 234 | -#if GTK_CHECK_VERSION(3,2,0) | ||
| 235 | - static gboolean filter_monospaced(const PangoFontFamily *family,const PangoFontFace *face,gpointer data) | ||
| 236 | - { | ||
| 237 | - return pango_font_family_is_monospace((PangoFontFamily *) family); | ||
| 238 | - } | ||
| 239 | -#endif // GTK(3,2,0) | ||
| 240 | - | ||
| 241 | - static void font_set(GtkFontButton *widget, PRINT_INFO *info) | ||
| 242 | - { | ||
| 243 | - if(info->font) | ||
| 244 | - g_free(info->font); | ||
| 245 | - info->font = g_strdup(gtk_font_button_get_font_name(widget)); | ||
| 246 | - } | ||
| 247 | - | ||
| 248 | -#else | ||
| 249 | - | ||
| 250 | - static void font_name_changed(GtkComboBox *combo, PRINT_INFO *info) | ||
| 251 | - { | ||
| 252 | - GValue value = { 0, }; | ||
| 253 | - GtkTreeIter iter; | ||
| 254 | - | ||
| 255 | - if(!gtk_combo_box_get_active_iter(combo,&iter)) | ||
| 256 | - return; | ||
| 257 | - | ||
| 258 | - gtk_tree_model_get_value(gtk_combo_box_get_model(combo),&iter,0,&value); | ||
| 259 | 75 | ||
| 260 | - if(info->font.family) | ||
| 261 | - g_free(info->font.family); | ||
| 262 | - | ||
| 263 | - info->font.family = g_value_dup_string(&value); | 76 | + if(operation->widget) |
| 77 | + g_signal_emit(GTK_WIDGET(operation->widget), v3270_widget_signal[SIGNAL_PRINT_DONE], 0, prt, (guint) result); | ||
| 264 | 78 | ||
| 265 | } | 79 | } |
| 266 | 80 | ||
| 267 | -#endif // !AUTO_FONT_SIZE | ||
| 268 | - | ||
| 269 | - static void toggle_show_selection(GtkToggleButton *togglebutton,PRINT_INFO *info) | 81 | +#ifndef _WIN32 |
| 82 | + static GtkWidget * create_custom_widget(GtkPrintOperation *prt) | ||
| 270 | { | 83 | { |
| 271 | - gboolean active = gtk_toggle_button_get_active(togglebutton); | ||
| 272 | - info->show_selection = active ? 1 : 0; | ||
| 273 | - } | ||
| 274 | - | ||
| 275 | - static GObject * create_custom_widget(GtkPrintOperation *prt, PRINT_INFO *info) | ||
| 276 | - { | ||
| 277 | - GtkWidget * container = gtk_table_new(3,2,FALSE); | ||
| 278 | - static const gchar * text[] = { N_( "_Font:" ), N_( "C_olor scheme:" ) }; | ||
| 279 | - GtkWidget * label[G_N_ELEMENTS(text)]; | ||
| 280 | - GtkWidget * widget; | ||
| 281 | - size_t f; | ||
| 282 | - | ||
| 283 | - for(f=0;f<G_N_ELEMENTS(label);f++) | 84 | + static const gchar * text[] = |
| 284 | { | 85 | { |
| 285 | - label[f] = gtk_label_new_with_mnemonic(gettext(text[f])); | ||
| 286 | - gtk_misc_set_alignment(GTK_MISC(label[f]),0,0.5); | ||
| 287 | - gtk_table_attach(GTK_TABLE(container),label[f],0,1,f,f+1,GTK_FILL,GTK_FILL,0,0); | ||
| 288 | - } | 86 | + N_( "_Font:" ), |
| 87 | + N_( "C_olor scheme:" ) | ||
| 88 | + }; | ||
| 289 | 89 | ||
| 290 | - // Font selection button | ||
| 291 | -#ifdef AUTO_FONT_SIZE | ||
| 292 | - { | ||
| 293 | - GtkTreeModel * model = (GtkTreeModel *) gtk_list_store_new(1,G_TYPE_STRING); | ||
| 294 | - GtkCellRenderer * renderer = gtk_cell_renderer_text_new(); | ||
| 295 | - PangoFontFamily **families; | ||
| 296 | - gint n_families, i; | ||
| 297 | - GtkTreeIter iter; | 90 | + size_t f; |
| 298 | 91 | ||
| 299 | - widget = gtk_combo_box_new_with_model(model); | 92 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); |
| 300 | 93 | ||
| 301 | - gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(widget), renderer, TRUE); | ||
| 302 | - gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(widget), renderer, "text", 0, NULL); | 94 | + if(operation->widget) |
| 95 | + g_signal_emit(operation->widget, v3270_widget_signal[SIGNAL_PRINT_SETUP], 0, prt); | ||
| 303 | 96 | ||
| 304 | - g_signal_connect(G_OBJECT(widget),"changed",G_CALLBACK(font_name_changed),info); | 97 | + // Create dialog |
| 305 | 98 | ||
| 306 | - pango_context_list_families(gtk_widget_get_pango_context(container),&families, &n_families); | 99 | + GtkGrid * grid = GTK_GRID(gtk_grid_new()); |
| 100 | + GtkWidget * font = v3270_font_selection_new(operation->font.name); | ||
| 101 | + GtkWidget * color = v3270_color_scheme_new(); | ||
| 307 | 102 | ||
| 308 | - for(i=0; i<n_families; i++) | ||
| 309 | - { | ||
| 310 | - if(pango_font_family_is_monospace(families[i])) | ||
| 311 | - { | ||
| 312 | - const gchar *name = pango_font_family_get_name (families[i]); | ||
| 313 | - gtk_list_store_append((GtkListStore *) model,&iter); | ||
| 314 | - gtk_list_store_set((GtkListStore *) model, &iter,0, name, -1); | 103 | + gtk_container_set_border_width(GTK_CONTAINER(grid),10); |
| 104 | + gtk_grid_set_row_spacing(grid,5); | ||
| 105 | + gtk_grid_set_column_spacing(grid,5); | ||
| 315 | 106 | ||
| 316 | - if(!g_ascii_strcasecmp(name,info->font.family)) | ||
| 317 | - gtk_combo_box_set_active_iter(GTK_COMBO_BOX(widget),&iter); | ||
| 318 | - } | ||
| 319 | - } | 107 | + v3270_color_scheme_set_rgba(color,operation->color); |
| 320 | 108 | ||
| 321 | - g_free(families); | ||
| 322 | - } | ||
| 323 | -#else | 109 | + for(f=0;f<G_N_ELEMENTS(text);f++) |
| 324 | { | 110 | { |
| 325 | - widget = gtk_font_button_new_with_font(info->font); | ||
| 326 | - gtk_font_button_set_show_size((GtkFontButton *) widget,TRUE); | ||
| 327 | - gtk_font_button_set_use_font((GtkFontButton *) widget,TRUE); | ||
| 328 | - gtk_label_set_mnemonic_widget(GTK_LABEL(label[0]),widget); | ||
| 329 | - g_free(info->font); | ||
| 330 | - | ||
| 331 | -#if GTK_CHECK_VERSION(3,2,0) | ||
| 332 | - gtk_font_chooser_set_filter_func((GtkFontChooser *) widget,filter_monospaced,NULL,NULL); | ||
| 333 | -#endif // GTK(3,2,0) | ||
| 334 | - | ||
| 335 | - g_signal_connect(G_OBJECT(widget),"font-set",G_CALLBACK(font_set),info); | ||
| 336 | - | 111 | + GtkWidget *label = gtk_label_new_with_mnemonic(gettext(text[f])); |
| 112 | + gtk_misc_set_alignment(GTK_MISC(label),0,0.5); | ||
| 113 | + gtk_grid_attach(grid,label,0,f,1,1); | ||
| 337 | } | 114 | } |
| 338 | -#endif | ||
| 339 | - | ||
| 340 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,0,1,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | ||
| 341 | - | ||
| 342 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_BEGIN], 0, prt); | ||
| 343 | 115 | ||
| 116 | + gtk_grid_attach(grid,font,1,0,1,1); | ||
| 117 | + gtk_grid_attach(grid,color,1,1,1,1); | ||
| 344 | 118 | ||
| 345 | - widget = v3270_color_scheme_new(); | ||
| 346 | - v3270_color_scheme_set_rgba(widget,info->color); | ||
| 347 | - gtk_label_set_mnemonic_widget(GTK_LABEL(label[1]),widget); | ||
| 348 | - | ||
| 349 | - g_object_set_data(G_OBJECT(container),"combo",widget); | ||
| 350 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,1,2,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | ||
| 351 | - | ||
| 352 | - // Selection checkbox | ||
| 353 | - widget = gtk_check_button_new_with_label( _("Print selection box") ); | 119 | + gtk_widget_show_all(GTK_WIDGET(grid)); |
| 120 | + return GTK_WIDGET(grid); | ||
| 121 | + } | ||
| 354 | 122 | ||
| 355 | - if(info->src == LIB3270_PRINT_ALL) | ||
| 356 | - { | ||
| 357 | - info->show_selection = FALSE; | ||
| 358 | - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget),info->show_selection); | ||
| 359 | - g_signal_connect(G_OBJECT(widget),"toggled",G_CALLBACK(toggle_show_selection),info); | ||
| 360 | - } | ||
| 361 | - else | ||
| 362 | - { | ||
| 363 | - gtk_widget_set_sensitive(widget,FALSE); | ||
| 364 | - } | 123 | + static void custom_widget_apply(GtkPrintOperation *prt, GtkWidget *widget) |
| 124 | + { | ||
| 125 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); | ||
| 365 | 126 | ||
| 366 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,2,3,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | 127 | + debug("%s",__FUNCTION__); |
| 367 | 128 | ||
| 368 | - // Show and return | ||
| 369 | - gtk_widget_show_all(container); | 129 | + if(operation->widget) |
| 130 | + g_signal_emit(operation->widget, v3270_widget_signal[SIGNAL_PRINT_APPLY], 0, prt); | ||
| 370 | 131 | ||
| 371 | - return G_OBJECT(container); | ||
| 372 | } | 132 | } |
| 133 | +#endif // _WIN32 | ||
| 373 | 134 | ||
| 374 | - static void custom_widget_apply(GtkPrintOperation *prt, GtkWidget *widget, PRINT_INFO *info) | 135 | + static void dispose(GObject *object) |
| 375 | { | 136 | { |
| 376 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_APPLY], 0, prt); | ||
| 377 | - | ||
| 378 | - /* | ||
| 379 | - GtkWidget * combo = g_object_get_data(G_OBJECT(widget),"combo"); | ||
| 380 | - GdkRGBA * clr = g_object_get_data(G_OBJECT(combo),"selected"); | ||
| 381 | - | ||
| 382 | - trace("%s starts combo=%p clr=%p widget=%p",__FUNCTION__,combo,clr,widget); | 137 | + debug("%s",__FUNCTION__); |
| 383 | 138 | ||
| 384 | - if(info->font.family) | ||
| 385 | - set_string_to_config("print",FONT_CONFIG,info->font.family); | 139 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(object); |
| 386 | 140 | ||
| 387 | - if(clr) | ||
| 388 | - { | ||
| 389 | - int f; | ||
| 390 | - GString *str = g_string_new(""); | ||
| 391 | - for(f=0;f<V3270_COLOR_COUNT;f++) | ||
| 392 | - { | ||
| 393 | - info->color[f] = clr[f]; | ||
| 394 | - if(f) | ||
| 395 | - g_string_append_c(str,';'); | ||
| 396 | - g_string_append_printf(str,"%s",gdk_rgba_to_string(clr+f)); | ||
| 397 | - } | ||
| 398 | - set_string_to_config("print","colors","%s",str->str); | ||
| 399 | - g_string_free(str,TRUE); | ||
| 400 | - } | ||
| 401 | - | ||
| 402 | - trace("%s ends",__FUNCTION__); | ||
| 403 | - */ | 141 | + g_free(operation->font.name); |
| 404 | 142 | ||
| 405 | } | 143 | } |
| 406 | 144 | ||
| 407 | - static GtkPrintOperation * begin_print_operation(GtkWidget *widget, PRINT_INFO **info) | 145 | + static void V3270PrintOperation_class_init(V3270PrintOperationClass *klass) |
| 408 | { | 146 | { |
| 409 | - GtkPrintOperation * print = gtk_print_operation_new(); | ||
| 410 | - GtkPrintSettings * settings = gtk_print_settings_new(); | ||
| 411 | - GtkPageSetup * setup = gtk_page_setup_new(); | ||
| 412 | - // GtkPaperSize * papersize = NULL; | ||
| 413 | - | ||
| 414 | - *info = g_new0(PRINT_INFO,1); | ||
| 415 | - (*info)->cols = 80; | ||
| 416 | - (*info)->widget = widget; | ||
| 417 | - (*info)->font.family = g_strdup(DEFAULT_FONT); | 147 | + GtkPrintOperationClass * operation = GTK_PRINT_OPERATION_CLASS(klass); |
| 418 | 148 | ||
| 419 | - debug("%s",__FUNCTION__); | ||
| 420 | - gtk_print_operation_set_custom_tab_label(print, _( "Options" ) ); | ||
| 421 | - gtk_print_operation_set_show_progress(print,TRUE); | 149 | + G_OBJECT_CLASS(klass)->dispose = dispose; |
| 150 | + operation->done = done; | ||
| 422 | 151 | ||
| 423 | - // Common signals | 152 | +#ifndef _WIN32 |
| 153 | + operation->create_custom_widget = create_custom_widget; | ||
| 154 | + operation->custom_widget_apply = custom_widget_apply; | ||
| 155 | +#endif // _WIN32 | ||
| 156 | + /* | ||
| 157 | + // Common signals | ||
| 424 | g_signal_connect(print,"done",G_CALLBACK(done),*info); | 158 | g_signal_connect(print,"done",G_CALLBACK(done),*info); |
| 425 | 159 | ||
| 426 | #if GTK_CHECK_VERSION(3,0,0) && !defined(WIN32) | 160 | #if GTK_CHECK_VERSION(3,0,0) && !defined(WIN32) |
| 427 | - g_signal_connect(print,"create-custom-widget",G_CALLBACK(create_custom_widget), *info); | ||
| 428 | - g_signal_connect(print,"custom-widget-apply",G_CALLBACK(custom_widget_apply), *info); | 161 | + g_signal_connect(print,"create-custom-widget",G_CALLBACK(create_custom_widget), *info); |
| 162 | + g_signal_connect(print,"custom-widget-apply",G_CALLBACK(custom_widget_apply), *info); | ||
| 429 | #endif // !WIN32 | 163 | #endif // !WIN32 |
| 164 | +*/ | ||
| 430 | 165 | ||
| 431 | - // Finish settings | ||
| 432 | - gtk_print_operation_set_print_settings(print,settings); | ||
| 433 | - //gtk_page_setup_set_paper_size_and_default_margins(setup,papersize); | ||
| 434 | - gtk_print_operation_set_default_page_setup(print,setup); | ||
| 435 | - | ||
| 436 | - return print; | ||
| 437 | } | 166 | } |
| 438 | 167 | ||
| 439 | - static void draw_text(GtkPrintOperation *prt, GtkPrintContext *context, gint pg, PRINT_INFO *info) | 168 | + static void V3270PrintOperation_init(V3270PrintOperation *widget) |
| 440 | { | 169 | { |
| 441 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | ||
| 442 | - GdkRectangle rect; | ||
| 443 | - int row = pg*info->lpp; | ||
| 444 | - int l; | 170 | + // Setup print operation. |
| 171 | + gtk_print_operation_set_custom_tab_label(GTK_PRINT_OPERATION(widget), _( "Options" ) ); | ||
| 172 | + gtk_print_operation_set_show_progress(GTK_PRINT_OPERATION(widget),TRUE); | ||
| 173 | + gtk_print_operation_set_print_settings(GTK_PRINT_OPERATION(widget),gtk_print_settings_new()); | ||
| 174 | + gtk_print_operation_set_default_page_setup(GTK_PRINT_OPERATION(widget),gtk_page_setup_new()); | ||
| 445 | 175 | ||
| 446 | - cairo_set_scaled_font(cr,info->font.scaled); | ||
| 447 | 176 | ||
| 448 | - memset(&rect,0,sizeof(rect)); | ||
| 449 | - rect.y = 2; | ||
| 450 | - rect.height = (info->font.height + info->font.descent)+1; | ||
| 451 | - rect.width = info->font.width+1; | 177 | + // Setup defaults |
| 178 | + widget->mode = LIB3270_PRINT_ALL; | ||
| 179 | + widget->show_selection = FALSE; | ||
| 180 | + widget->font.name = g_strdup(v3270_default_font); | ||
| 452 | 181 | ||
| 453 | - for(l=0;l<info->lpp && row < info->rows;l++) | ||
| 454 | - { | ||
| 455 | - cairo_move_to(cr,2,rect.y+rect.height); | ||
| 456 | - cairo_show_text(cr, info->text[row]); | ||
| 457 | - cairo_stroke(cr); | ||
| 458 | - row++; | ||
| 459 | - rect.y += (rect.height-1); | ||
| 460 | - } | 182 | + v3270_set_mono_color_table(widget->color,"#000000","#FFFFFF"); |
| 461 | 183 | ||
| 462 | } | 184 | } |
| 463 | 185 | ||
| 464 | - static void print_operation(GtkWidget *widget, GtkPrintOperationAction oper, LIB3270_PRINT_MODE mode) | ||
| 465 | - { | ||
| 466 | - PRINT_INFO * info = NULL; | ||
| 467 | - GtkPrintOperation * print; | ||
| 468 | - gchar * text; | ||
| 469 | - GError * err = NULL; | ||
| 470 | - | ||
| 471 | - g_return_if_fail(GTK_IS_V3270(widget)); | ||
| 472 | - | ||
| 473 | - print = begin_print_operation(widget,&info); | ||
| 474 | - if(!print) | ||
| 475 | - return; | ||
| 476 | - | ||
| 477 | - lib3270_get_screen_size(info->widget->host,&info->rows,&info->cols); | 186 | +V3270PrintOperation * v3270_print_operation_new(GtkWidget *widget, LIB3270_PRINT_MODE mode) |
| 187 | +{ | ||
| 188 | + g_return_val_if_fail(GTK_IS_V3270(widget),NULL); | ||
| 478 | 189 | ||
| 479 | - info->src = mode; | ||
| 480 | - | ||
| 481 | - g_signal_connect(print,"begin_print",G_CALLBACK(begin_print),info); | ||
| 482 | - | ||
| 483 | - switch(mode) | ||
| 484 | - { | ||
| 485 | - case LIB3270_PRINT_ALL: | ||
| 486 | - case LIB3270_PRINT_SELECTED: | ||
| 487 | - g_signal_connect(print,"draw_page",G_CALLBACK(draw_screen),info); | ||
| 488 | - break; | 190 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(g_object_new(GTK_TYPE_V3270_PRINT_OPERATION, NULL)); |
| 489 | 191 | ||
| 490 | - case LIB3270_PRINT_COPY: | 192 | + operation->mode = mode; |
| 193 | + operation->widget = GTK_V3270(widget); | ||
| 194 | + operation->session = v3270_get_session(widget); | ||
| 491 | 195 | ||
| 492 | - text = v3270_get_copy(widget); | ||
| 493 | - | ||
| 494 | - if(text) | ||
| 495 | - { | ||
| 496 | - int r; | ||
| 497 | - | ||
| 498 | - info->text = g_strsplit(text,"\n",-1); | ||
| 499 | - info->rows = g_strv_length(info->text); | ||
| 500 | - | ||
| 501 | - for(r=0;r < info->rows;r++) | ||
| 502 | - { | ||
| 503 | - size_t sz = strlen(info->text[r]); | ||
| 504 | - if(sz > info->cols) | ||
| 505 | - info->cols = sz; | ||
| 506 | - } | ||
| 507 | - g_free(text); | ||
| 508 | - } | ||
| 509 | - g_signal_connect(print,"draw_page",G_CALLBACK(draw_text),info); | ||
| 510 | - break; | ||
| 511 | - | ||
| 512 | - | ||
| 513 | - } | ||
| 514 | - | ||
| 515 | - // Run Print dialog | ||
| 516 | - gtk_print_operation_run(print,oper,GTK_WINDOW(gtk_widget_get_toplevel(widget)),&err); | ||
| 517 | - | ||
| 518 | - if(err) | ||
| 519 | - g_error_free(err); | ||
| 520 | - | ||
| 521 | - g_object_unref(print); | 196 | + return operation; |
| 197 | +} | ||
| 522 | 198 | ||
| 523 | - } | 199 | +/*--[ Convenience ]----------------------------------------------------------------------------------*/ |
| 524 | 200 | ||
| 525 | void v3270_print(GtkWidget *widget, LIB3270_PRINT_MODE mode) | 201 | void v3270_print(GtkWidget *widget, LIB3270_PRINT_MODE mode) |
| 526 | { | 202 | { |
| 527 | - print_operation(widget,GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG, mode); | 203 | + g_autoptr(GError) err = NULL; |
| 204 | + | ||
| 205 | + V3270PrintOperation * operation = v3270_print_operation_new(widget, mode); | ||
| 206 | + gtk_print_operation_run(GTK_PRINT_OPERATION(operation),GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG,GTK_WINDOW(gtk_widget_get_toplevel(widget)),&err); | ||
| 207 | + g_object_unref(operation); | ||
| 208 | + | ||
| 528 | } | 209 | } |
| 529 | 210 | ||
| 530 | void v3270_print_all(GtkWidget *widget) | 211 | void v3270_print_all(GtkWidget *widget) |
src/v3270/private.h
| @@ -79,7 +79,7 @@ G_BEGIN_DECLS | @@ -79,7 +79,7 @@ G_BEGIN_DECLS | ||
| 79 | SIGNAL_CHANGED, | 79 | SIGNAL_CHANGED, |
| 80 | SIGNAL_MESSAGE, | 80 | SIGNAL_MESSAGE, |
| 81 | SIGNAL_FIELD, | 81 | SIGNAL_FIELD, |
| 82 | - SIGNAL_PRINT_BEGIN, | 82 | + SIGNAL_PRINT_SETUP, |
| 83 | SIGNAL_PRINT_APPLY, | 83 | SIGNAL_PRINT_APPLY, |
| 84 | SIGNAL_PRINT_DONE, | 84 | SIGNAL_PRINT_DONE, |
| 85 | 85 |
src/v3270/widget.c
| @@ -497,18 +497,7 @@ static void v3270_class_init(v3270Class *klass) | @@ -497,18 +497,7 @@ static void v3270_class_init(v3270Class *klass) | ||
| 497 | G_TYPE_BOOLEAN, 3, G_TYPE_BOOLEAN, G_TYPE_UINT, G_TYPE_POINTER); | 497 | G_TYPE_BOOLEAN, 3, G_TYPE_BOOLEAN, G_TYPE_UINT, G_TYPE_POINTER); |
| 498 | 498 | ||
| 499 | 499 | ||
| 500 | - /* | ||
| 501 | - v3270_widget_signal[SIGNAL_PRINT] = | ||
| 502 | - g_signal_new( "print", | ||
| 503 | - G_OBJECT_CLASS_TYPE (gobject_class), | ||
| 504 | - G_SIGNAL_RUN_FIRST, | ||
| 505 | - 0, | ||
| 506 | - NULL, NULL, | ||
| 507 | - v3270_VOID__VOID, | ||
| 508 | - G_TYPE_NONE, 0); | ||
| 509 | - */ | ||
| 510 | - | ||
| 511 | - v3270_widget_signal[SIGNAL_PRINT_BEGIN] = | 500 | + v3270_widget_signal[SIGNAL_PRINT_SETUP] = |
| 512 | g_signal_new( "print-begin", | 501 | g_signal_new( "print-begin", |
| 513 | G_OBJECT_CLASS_TYPE (gobject_class), | 502 | G_OBJECT_CLASS_TYPE (gobject_class), |
| 514 | G_SIGNAL_RUN_FIRST, | 503 | G_SIGNAL_RUN_FIRST, |