Commit 2f933768fefd8028c0f5a9e8dd37bfce5d307f75
1 parent
7c328e71
Exists in
master
and in
5 other branches
Fixing windows print dialog.
Showing
2 changed files
with
12 additions
and
114 deletions
Show diff stats
src/pw3270/print.c
@@ -39,120 +39,6 @@ | @@ -39,120 +39,6 @@ | ||
39 | 39 | ||
40 | /*--[ Implement ]------------------------------------------------------------------------------------*/ | 40 | /*--[ Implement ]------------------------------------------------------------------------------------*/ |
41 | 41 | ||
42 | -/* | ||
43 | - static void show_print_error(GtkWidget *widget, GError *err) | ||
44 | - { | ||
45 | - g_warning("Print operation has failed: %s",err->message); | ||
46 | - | ||
47 | - GtkWidget *dialog = gtk_message_dialog_new_with_markup( GTK_WINDOW(gtk_widget_get_toplevel(widget)), | ||
48 | - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | ||
49 | - GTK_MESSAGE_ERROR,GTK_BUTTONS_CLOSE, | ||
50 | - "%s",_( "Unable to complete print job" )); | ||
51 | - | ||
52 | - gtk_window_set_title(GTK_WINDOW(dialog),_("Operation has failed")); | ||
53 | - | ||
54 | - gtk_message_dialog_format_secondary_markup(GTK_MESSAGE_DIALOG(dialog),"%s",err->message); | ||
55 | - | ||
56 | - gtk_dialog_run(GTK_DIALOG(dialog)); | ||
57 | - gtk_widget_destroy(dialog); | ||
58 | -} | ||
59 | -*/ | ||
60 | - | ||
61 | - /* | ||
62 | - static void done(GtkPrintOperation *prt, GtkPrintOperationResult result, PRINT_INFO *info) | ||
63 | - { | ||
64 | - if(result == GTK_PRINT_OPERATION_RESULT_ERROR) | ||
65 | - { | ||
66 | - GError * err = NULL; | ||
67 | - | ||
68 | - gtk_print_operation_get_error(prt,&err); | ||
69 | - show_print_error(info->widget,err); | ||
70 | - g_error_free(err); | ||
71 | - | ||
72 | - } | ||
73 | - else | ||
74 | - { | ||
75 | - // Save settings | ||
76 | - GtkPrintSettings * settings = gtk_print_operation_get_print_settings(prt); | ||
77 | - GtkPageSetup * pgsetup = gtk_print_operation_get_default_page_setup(prt); | ||
78 | - GtkPaperSize * papersize = gtk_page_setup_get_paper_size(pgsetup); | ||
79 | - | ||
80 | - trace("Saving settings PrintSettings=%p page_setup=%p",settings,pgsetup); | ||
81 | - | ||
82 | -#ifdef ENABLE_WINDOWS_REGISTRY | ||
83 | - HKEY registry; | ||
84 | - | ||
85 | - if(get_registry_handle("print",®istry,KEY_SET_VALUE)) | ||
86 | - { | ||
87 | - HKEY hKey; | ||
88 | - DWORD disp; | ||
89 | - | ||
90 | - if(RegCreateKeyEx(registry,"settings",0,NULL,REG_OPTION_NON_VOLATILE,KEY_SET_VALUE,NULL,&hKey,&disp) == ERROR_SUCCESS) | ||
91 | - { | ||
92 | - gtk_print_settings_foreach( settings,(GtkPrintSettingsFunc) save_settings, hKey ); | ||
93 | - RegCloseKey(hKey); | ||
94 | - } | ||
95 | - | ||
96 | - if(RegCreateKeyEx(registry,"page",0,NULL,REG_OPTION_NON_VOLATILE,KEY_SET_VALUE,NULL,&hKey,&disp) == ERROR_SUCCESS) | ||
97 | - { | ||
98 | - gchar * orientation = enum_to_string(GTK_TYPE_PAGE_ORIENTATION,gtk_page_setup_get_orientation(pgsetup)); | ||
99 | - | ||
100 | - // From http://git.gnome.org/browse/gtk+/tree/gtk/gtkpagesetup.c | ||
101 | - save_double(hKey, "MarginTop", gtk_page_setup_get_top_margin(pgsetup, GTK_UNIT_MM)); | ||
102 | - save_double(hKey, "MarginBottom", gtk_page_setup_get_bottom_margin(pgsetup, GTK_UNIT_MM)); | ||
103 | - save_double(hKey, "MarginLeft", gtk_page_setup_get_left_margin(pgsetup, GTK_UNIT_MM)); | ||
104 | - save_double(hKey, "MarginRight", gtk_page_setup_get_right_margin(pgsetup, GTK_UNIT_MM)); | ||
105 | - save_string(hKey, "Orientation", orientation); | ||
106 | - | ||
107 | - g_free (orientation); | ||
108 | - | ||
109 | - RegCloseKey(hKey); | ||
110 | - } | ||
111 | - | ||
112 | - if(papersize && RegCreateKeyEx(registry,"paper",0,NULL,REG_OPTION_NON_VOLATILE,KEY_SET_VALUE,NULL,&hKey,&disp) == ERROR_SUCCESS) | ||
113 | - { | ||
114 | - // From http://git.gnome.org/browse/gtk+/tree/gtk/gtkpapersize.c | ||
115 | - static const struct _papersettings | ||
116 | - { | ||
117 | - const gchar * name; | ||
118 | - const gchar * (*get)(GtkPaperSize *); | ||
119 | - } papersettings[] = | ||
120 | - { | ||
121 | - { "PPDName", gtk_paper_size_get_ppd_name }, | ||
122 | - { "Name", gtk_paper_size_get_name }, | ||
123 | - { "DisplayName", gtk_paper_size_get_display_name } | ||
124 | - }; | ||
125 | - | ||
126 | - int f; | ||
127 | - | ||
128 | - for(f=0;f<G_N_ELEMENTS(papersettings);f++) | ||
129 | - { | ||
130 | - const gchar *ptr = papersettings[f].get(papersize); | ||
131 | - if(ptr) | ||
132 | - save_string(hKey,papersettings[f].name,ptr); | ||
133 | - } | ||
134 | - | ||
135 | - save_double(hKey, "Width", gtk_paper_size_get_width (papersize, GTK_UNIT_MM)); | ||
136 | - save_double(hKey, "Height", gtk_paper_size_get_height (papersize, GTK_UNIT_MM)); | ||
137 | - | ||
138 | - RegCloseKey(hKey); | ||
139 | - } | ||
140 | - | ||
141 | - | ||
142 | - RegCloseKey(registry); | ||
143 | - } | ||
144 | -#else | ||
145 | - GKeyFile * conf = get_application_keyfile(); | ||
146 | - gtk_print_settings_to_key_file(settings,conf,"print_settings"); | ||
147 | - gtk_page_setup_to_key_file(pgsetup,conf,"page_setup"); | ||
148 | - gtk_paper_size_to_key_file(papersize,conf,"paper_size"); | ||
149 | -#endif | ||
150 | - | ||
151 | - } | ||
152 | - | ||
153 | - } | ||
154 | - */ | ||
155 | - | ||
156 | void print_all_action(GtkAction *action, GtkWidget *widget) | 42 | void print_all_action(GtkAction *action, GtkWidget *widget) |
157 | { | 43 | { |
158 | pw3270_print(widget,G_OBJECT(action),GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG, LIB3270_CONTENT_ALL); | 44 | pw3270_print(widget,G_OBJECT(action),GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG, LIB3270_CONTENT_ALL); |
src/pw3270/windows/print.c
@@ -106,6 +106,18 @@ static gchar * enum_to_string(GType type, guint enum_value) | @@ -106,6 +106,18 @@ static gchar * enum_to_string(GType type, guint enum_value) | ||
106 | GtkPageSetup * setup = gtk_page_setup_new(); | 106 | GtkPageSetup * setup = gtk_page_setup_new(); |
107 | GtkPaperSize * papersize = NULL; | 107 | GtkPaperSize * papersize = NULL; |
108 | 108 | ||
109 | + // Load settings. | ||
110 | + { | ||
111 | + g_autofree gchar * font_family = get_string_from_config("print",FONT_CONFIG,DEFAULT_FONT); | ||
112 | + if(font_family && *font_family) | ||
113 | + v3270_print_operation_set_font_family(operation,font_family); | ||
114 | + | ||
115 | + g_autofree gchar * color_scheme = get_string_from_config("print","colors",""); | ||
116 | + if(color_scheme && *color_scheme) | ||
117 | + v3270_print_operation_set_color_scheme(operation,color_scheme); | ||
118 | + } | ||
119 | + | ||
120 | + | ||
109 | #ifdef ENABLE_WINDOWS_REGISTRY | 121 | #ifdef ENABLE_WINDOWS_REGISTRY |
110 | 122 | ||
111 | HKEY registry; | 123 | HKEY registry; |