mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-06 02:40:07 +00:00
Merge branch 'WindowsPrintDriverPreferencesMaster' into 'master'
Fixed bug that prevented GTK from storing printer driver preferences in the… See merge request GNOME/gtk!397
This commit is contained in:
commit
5c594fc46a
@ -713,6 +713,10 @@ devmode_to_settings (GtkPrintSettings *settings,
|
|||||||
g_free (extra);
|
g_free (extra);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *devmode_name = g_utf16_to_utf8 (devmode->dmDeviceName, -1, NULL, NULL, NULL);
|
||||||
|
gtk_print_settings_set (settings, "win32-devmode-name", devmode_name);
|
||||||
|
g_free (devmode_name);
|
||||||
|
|
||||||
if (devmode->dmFields & DM_ORIENTATION)
|
if (devmode->dmFields & DM_ORIENTATION)
|
||||||
gtk_print_settings_set_orientation (settings,
|
gtk_print_settings_set_orientation (settings,
|
||||||
orientation_from_win32 (devmode->dmOrientation));
|
orientation_from_win32 (devmode->dmOrientation));
|
||||||
@ -956,9 +960,10 @@ dialog_to_print_settings (GtkPrintOperation *op,
|
|||||||
|
|
||||||
static HANDLE
|
static HANDLE
|
||||||
devmode_from_settings (GtkPrintSettings *settings,
|
devmode_from_settings (GtkPrintSettings *settings,
|
||||||
GtkPageSetup *page_setup)
|
GtkPageSetup *page_setup,
|
||||||
|
HANDLE hDevModeParam)
|
||||||
{
|
{
|
||||||
HANDLE hDevMode;
|
HANDLE hDevMode = hDevModeParam;
|
||||||
LPDEVMODEW devmode;
|
LPDEVMODEW devmode;
|
||||||
guchar *extras;
|
guchar *extras;
|
||||||
GtkPaperSize *paper_size;
|
GtkPaperSize *paper_size;
|
||||||
@ -966,31 +971,47 @@ devmode_from_settings (GtkPrintSettings *settings,
|
|||||||
gsize extras_len;
|
gsize extras_len;
|
||||||
const char *val;
|
const char *val;
|
||||||
|
|
||||||
extras = NULL;
|
/* If we already provided a valid hDevMode, don't initialize a new one; just lock the one we have */
|
||||||
extras_len = 0;
|
if (hDevMode)
|
||||||
extras_base64 = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_EXTRA);
|
|
||||||
if (extras_base64)
|
|
||||||
extras = g_base64_decode (extras_base64, &extras_len);
|
|
||||||
|
|
||||||
hDevMode = GlobalAlloc (GMEM_MOVEABLE,
|
|
||||||
sizeof (DEVMODEW) + extras_len);
|
|
||||||
|
|
||||||
devmode = GlobalLock (hDevMode);
|
|
||||||
|
|
||||||
memset (devmode, 0, sizeof (DEVMODEW));
|
|
||||||
|
|
||||||
devmode->dmSpecVersion = DM_SPECVERSION;
|
|
||||||
devmode->dmSize = sizeof (DEVMODEW);
|
|
||||||
|
|
||||||
devmode->dmDriverExtra = 0;
|
|
||||||
if (extras && extras_len > 0)
|
|
||||||
{
|
{
|
||||||
devmode->dmDriverExtra = extras_len;
|
devmode = GlobalLock (hDevMode);
|
||||||
memcpy (((char *)devmode) + sizeof (DEVMODEW), extras, extras_len);
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
extras = NULL;
|
||||||
|
extras_len = 0;
|
||||||
|
extras_base64 = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_EXTRA);
|
||||||
|
if (extras_base64)
|
||||||
|
extras = g_base64_decode (extras_base64, &extras_len);
|
||||||
|
|
||||||
|
hDevMode = GlobalAlloc (GMEM_MOVEABLE,
|
||||||
|
sizeof (DEVMODEW) + extras_len);
|
||||||
|
|
||||||
|
devmode = GlobalLock (hDevMode);
|
||||||
|
|
||||||
|
memset (devmode, 0, sizeof (DEVMODEW));
|
||||||
|
|
||||||
|
devmode->dmSpecVersion = DM_SPECVERSION;
|
||||||
|
devmode->dmSize = sizeof (DEVMODEW);
|
||||||
|
|
||||||
|
gunichar2 *device_name = g_utf8_to_utf16 (gtk_print_settings_get (settings, "win32-devmode-name"), -1, NULL, NULL, NULL);
|
||||||
|
memcpy (devmode->dmDeviceName, device_name, CCHDEVICENAME);
|
||||||
|
g_free (device_name);
|
||||||
|
|
||||||
|
|
||||||
|
devmode->dmDriverExtra = 0;
|
||||||
|
if (extras && extras_len > 0)
|
||||||
|
{
|
||||||
|
devmode->dmDriverExtra = extras_len;
|
||||||
|
memcpy (((char *)devmode) + sizeof (DEVMODEW), extras, extras_len);
|
||||||
|
}
|
||||||
|
g_free (extras);
|
||||||
|
|
||||||
|
if (gtk_print_settings_has_key (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_VERSION))
|
||||||
|
{
|
||||||
|
devmode->dmDriverVersion = gtk_print_settings_get_int (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_VERSION);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
g_free (extras);
|
|
||||||
if (gtk_print_settings_has_key (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_VERSION))
|
|
||||||
devmode->dmDriverVersion = gtk_print_settings_get_int (settings, GTK_PRINT_SETTINGS_WIN32_DRIVER_VERSION);
|
|
||||||
|
|
||||||
if (page_setup ||
|
if (page_setup ||
|
||||||
gtk_print_settings_has_key (settings, GTK_PRINT_SETTINGS_ORIENTATION))
|
gtk_print_settings_has_key (settings, GTK_PRINT_SETTINGS_ORIENTATION))
|
||||||
@ -1245,12 +1266,25 @@ dialog_from_print_settings (GtkPrintOperation *op,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* If we have a printer saved, restore our settings */
|
||||||
printer = gtk_print_settings_get_printer (settings);
|
printer = gtk_print_settings_get_printer (settings);
|
||||||
if (printer)
|
if (printer)
|
||||||
printdlgex->hDevNames = gtk_print_win32_devnames_to_win32_from_printer_name (printer);
|
{
|
||||||
|
printdlgex->hDevNames = gtk_print_win32_devnames_to_win32_from_printer_name (printer);
|
||||||
|
|
||||||
printdlgex->hDevMode = devmode_from_settings (settings,
|
printdlgex->hDevMode = devmode_from_settings (settings,
|
||||||
op->priv->default_page_setup);
|
op->priv->default_page_setup, NULL);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Otherwise, use the default settings */
|
||||||
|
DWORD FlagsCopy = printdlgex->Flags;
|
||||||
|
printdlgex->Flags |= PD_RETURNDEFAULT;
|
||||||
|
PrintDlgExW (printdlgex);
|
||||||
|
printdlgex->Flags = FlagsCopy;
|
||||||
|
|
||||||
|
devmode_from_settings (settings, op->priv->default_page_setup, printdlgex->hDevMode);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -1424,7 +1458,7 @@ pageDlgProc (HWND wnd, UINT message, WPARAM wparam, LPARAM lparam)
|
|||||||
if (message == WM_SIZE)
|
if (message == WM_SIZE)
|
||||||
{
|
{
|
||||||
gtk_widget_queue_resize (op_win32->embed_widget);
|
gtk_widget_queue_resize (op_win32->embed_widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -1580,7 +1614,7 @@ gtk_print_operation_run_without_dialog (GtkPrintOperation *op,
|
|||||||
}
|
}
|
||||||
|
|
||||||
hDevNames = gtk_print_win32_devnames_to_win32_from_printer_name (printer);
|
hDevNames = gtk_print_win32_devnames_to_win32_from_printer_name (printer);
|
||||||
hDevMode = devmode_from_settings (settings, op->priv->default_page_setup);
|
hDevMode = devmode_from_settings (settings, op->priv->default_page_setup, NULL);
|
||||||
|
|
||||||
/* Create a printer DC for the print settings and page setup provided. */
|
/* Create a printer DC for the print settings and page setup provided. */
|
||||||
pdn = GlobalLock (hDevNames);
|
pdn = GlobalLock (hDevNames);
|
||||||
@ -2078,7 +2112,7 @@ gtk_print_run_page_setup_dialog (GtkWindow *parent,
|
|||||||
pagesetupdlg->hwndOwner = NULL;
|
pagesetupdlg->hwndOwner = NULL;
|
||||||
|
|
||||||
pagesetupdlg->Flags = PSD_DEFAULTMINMARGINS;
|
pagesetupdlg->Flags = PSD_DEFAULTMINMARGINS;
|
||||||
pagesetupdlg->hDevMode = devmode_from_settings (settings, page_setup);
|
pagesetupdlg->hDevMode = devmode_from_settings (settings, page_setup, NULL);
|
||||||
pagesetupdlg->hDevNames = NULL;
|
pagesetupdlg->hDevNames = NULL;
|
||||||
printer = gtk_print_settings_get_printer (settings);
|
printer = gtk_print_settings_get_printer (settings);
|
||||||
if (printer)
|
if (printer)
|
||||||
|
Loading…
Reference in New Issue
Block a user