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 | 39 | |
40 | 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 | 42 | void print_all_action(GtkAction *action, GtkWidget *widget) |
157 | 43 | { |
158 | 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 | 106 | GtkPageSetup * setup = gtk_page_setup_new(); |
107 | 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 | 121 | #ifdef ENABLE_WINDOWS_REGISTRY |
110 | 122 | |
111 | 123 | HKEY registry; | ... | ... |