#include "wx/msw/printdlg.h"
#include "wx/msw/dcprint.h"
#include "wx/paper.h"
+#include "wx/modalhook.h"
#include <stdlib.h>
BOOL Open( const wxString& printerName, LPPRINTER_DEFAULTS pDefault=(LPPRINTER_DEFAULTS)NULL )
{
Close();
- return OpenPrinter( (LPTSTR)printerName.wx_str(), &m_hPrinter, pDefault );
+ return OpenPrinter( wxMSW_CONV_LPTSTR(printerName), &m_hPrinter, pDefault );
}
BOOL Close()
if (m_devMode)
return;
- LPTSTR szPrinterName = (LPTSTR)printerName.wx_str();
+ LPTSTR szPrinterName = wxMSW_CONV_LPTSTR(printerName);
// From MSDN: How To Modify Printer Settings with the DocumentProperties() Function
// The purpose of this is to fill the DEVMODE with privdata from printer driver.
- // If we have a printer name and OpenPrinter sucessfully returns
+ // If we have a printer name and OpenPrinter successfully returns
// this replaces the PrintDlg function which creates the DEVMODE filled only with data from default printer.
if ( !m_devMode && !printerName.IsEmpty() )
{
bool wxWindowsPrintNativeData::TransferFrom( const wxPrintData &data )
{
WinPrinter printer;
- LPTSTR szPrinterName = (LPTSTR)data.GetPrinterName().wx_str();
+ LPTSTR szPrinterName = wxMSW_CONV_LPTSTR(data.GetPrinterName());
if (!m_devMode)
InitializeDevMode(data.GetPrinterName(), &printer);
// NB: the cast is needed in the ANSI build, strangely enough
// dmDeviceName is BYTE[] and not char[] there
wxStrlcpy(reinterpret_cast<wxChar *>(devMode->dmDeviceName),
- name.wx_str(),
+ name.t_str(),
WXSIZEOF(devMode->dmDeviceName));
}
int wxWindowsPrintDialog::ShowModal()
{
+ WX_HOOK_MODAL_DIALOG();
+
ConvertToNative( m_printDialogData );
PRINTDLG *pd = (PRINTDLG*) m_printDlg;
int wxWindowsPageSetupDialog::ShowModal()
{
+ WX_HOOK_MODAL_DIALOG();
+
ConvertToNative( m_pageSetupData );
PAGESETUPDLG *pd = (PAGESETUPDLG *) m_pageDlg;
return false;
pd = new PAGESETUPDLG;
- pd->hDevMode = NULL;
- pd->hDevNames = NULL;
m_pageDlg = (void *)pd;
- // Pass the devmode data (created in m_printData.ConvertToNative)
- // to the PRINTDLG structure, since it'll
- // be needed when PrintDlg is called.
-
- if (pd->hDevMode)
+ // We must not set hDevMode and hDevNames when using PSD_RETURNDEFAULT,
+ // otherwise the call to PageSetupDlg() would fail.
+ if ( data.GetDefaultInfo() )
{
- GlobalFree(pd->hDevMode);
pd->hDevMode = NULL;
+ pd->hDevNames = NULL;
}
- pd->hDevMode = (HGLOBAL) native_data->GetDevMode();
- native_data->SetDevMode(NULL);
+ else
+ {
+ // Pass the devmode data (created in m_printData.ConvertToNative)
+ // to the PRINTDLG structure, since it'll
+ // be needed when PrintDlg is called.
- // Shouldn't assert; we should be able to test Ok-ness at a higher level
- //wxASSERT_MSG( (pd->hDevMode), wxT("hDevMode must be non-NULL in ConvertToNative!"));
+ pd->hDevMode = (HGLOBAL) native_data->GetDevMode();
+ native_data->SetDevMode(NULL);
- // Pass the devnames data (created in m_printData.ConvertToNative)
- // to the PRINTDLG structure, since it'll
- // be needed when PrintDlg is called.
+ // Shouldn't assert; we should be able to test Ok-ness at a higher level
+ //wxASSERT_MSG( (pd->hDevMode), wxT("hDevMode must be non-NULL in ConvertToNative!"));
- if (pd->hDevNames)
- {
- GlobalFree(pd->hDevNames);
- pd->hDevNames = NULL;
- }
- pd->hDevNames = (HGLOBAL) native_data->GetDevNames();
- native_data->SetDevNames(NULL);
+ // Pass the devnames data (created in m_printData.ConvertToNative)
+ // to the PRINTDLG structure, since it'll
+ // be needed when PrintDlg is called.
-// pd->hDevMode = GlobalAlloc(GMEM_MOVEABLE, sizeof(DEVMODE));
+ pd->hDevNames = (HGLOBAL) native_data->GetDevNames();
+ native_data->SetDevNames(NULL);
+ }
pd->Flags = PSD_MARGINS|PSD_MINMARGINS;
pd->hPageSetupTemplate = NULL;
pd->lpPageSetupTemplateName = NULL;
-/*
- if ( pd->hDevMode )
- {
- DEVMODE *devMode = (DEVMODE*) GlobalLock(pd->hDevMode);
- memset(devMode, 0, sizeof(DEVMODE));
- devMode->dmSize = sizeof(DEVMODE);
- devMode->dmOrientation = m_orientation;
- devMode->dmFields = DM_ORIENTATION;
- GlobalUnlock(pd->hDevMode);
- }
-*/
return true;
}