-#ifdef __WXMSW__
- PRINTDLG *pd = (PRINTDLG *) m_printDlgData;
- if ( pd && pd->hDevMode )
- GlobalFree(pd->hDevMode);
- if ( pd )
- delete pd;
-#endif
-}
-
-#ifdef __WXMSW__
-void wxPrintDialogData::ConvertToNative()
-{
- m_printData.ConvertToNative();
-
- PRINTDLG *pd = (PRINTDLG*) m_printDlgData;
-
- if (!pd)
- {
- pd = new PRINTDLG;
- m_printDlgData = (void*) pd;
-
- // GNU-WIN32 has the wrong size PRINTDLG - can't work out why.
-#ifdef __GNUWIN32__
- pd->lStructSize = 66 ;
-#else
-#endif
- pd->lStructSize = sizeof(PRINTDLG);
- pd->hwndOwner = (HWND)NULL;
- pd->hDevMode = NULL; // Will be created by PrintDlg
- pd->hDevNames = NULL; // Ditto
-
- pd->Flags = PD_RETURNDEFAULT;
- pd->nCopies = 1;
- }
-
- // Pass the devmode data to the PRINTDLG structure, since it'll
- // be needed when PrintDlg is called.
- if (pd->hDevMode)
- {
- GlobalFree(pd->hDevMode);
- }
-
- pd->hDevMode = (HGLOBAL) m_printData.GetNativeData();
-
- m_printData.SetNativeData((void*) NULL);
-
- wxASSERT_MSG( (pd->hDevMode), "hDevMode must be non-NULL in ConvertToNative!");
-
- pd->hDC = (HDC) NULL;
- pd->nFromPage = (UINT)m_printFromPage;
- pd->nToPage = (UINT)m_printToPage;
- pd->nMinPage = (UINT)m_printMinPage;
- pd->nMaxPage = (UINT)m_printMaxPage;
- pd->nCopies = (UINT)m_printNoCopies;
-
- pd->Flags = PD_RETURNDC ;
-
-#ifdef __GNUWIN32__
- pd->lStructSize = 66 ;
-#else
- pd->lStructSize = sizeof( PRINTDLG );
-#endif
-
- pd->hwndOwner=(HWND)NULL;
- pd->hDevNames=(HANDLE)NULL;
- pd->hInstance=(HINSTANCE)NULL;
- pd->lCustData = (LPARAM) NULL;
- pd->lpfnPrintHook = NULL;
- pd->lpfnSetupHook = NULL;
- pd->lpPrintTemplateName = NULL;
- pd->lpSetupTemplateName = NULL;
- pd->hPrintTemplate = (HGLOBAL) NULL;
- pd->hSetupTemplate = (HGLOBAL) NULL;
-
- if ( m_printAllPages )
- pd->Flags |= PD_ALLPAGES;
- if ( m_printCollate )
- pd->Flags |= PD_COLLATE;
- if ( m_printToFile )
- pd->Flags |= PD_PRINTTOFILE;
- if ( !m_printEnablePrintToFile )
- pd->Flags |= PD_DISABLEPRINTTOFILE;
- if ( !m_printEnableSelection )
- pd->Flags |= PD_NOSELECTION;
- if ( !m_printEnablePageNumbers )
- pd->Flags |= PD_NOPAGENUMS;
- if ( m_printEnableHelp )
- pd->Flags |= PD_SHOWHELP;
- if ( m_printSetupDialog )
- pd->Flags |= PD_PRINTSETUP;
-}
-
-void wxPrintDialogData::ConvertFromNative()
-{
- PRINTDLG *pd = (PRINTDLG*) m_printDlgData;
- if ( pd == NULL )
- return;
-
- // Pass the devmode data back to the wxPrintData structure where it really belongs.
- if (pd->hDevMode)
- {
- if (m_printData.GetNativeData())
- {
- // Make sure we don't leak memory
- GlobalFree((HGLOBAL) m_printData.GetNativeData());
- }
- m_printData.SetNativeData((void*) pd->hDevMode);
- pd->hDevMode = NULL;
- }
-
- // Now convert the DEVMODE object, passed down from the PRINTDLG object,
- // into wxWindows form.
- m_printData.ConvertFromNative();
-
- m_printFromPage = pd->nFromPage ;
- m_printToPage = pd->nToPage ;
- m_printMinPage = pd->nMinPage ;
- m_printMaxPage = pd->nMaxPage ;
- m_printNoCopies = pd->nCopies ;
-
- m_printAllPages = ((pd->Flags & PD_ALLPAGES) == PD_ALLPAGES);
- m_printCollate = ((pd->Flags & PD_COLLATE) == PD_COLLATE);
- m_printToFile = ((pd->Flags & PD_PRINTTOFILE) == PD_PRINTTOFILE);
- m_printEnablePrintToFile = ((pd->Flags & PD_DISABLEPRINTTOFILE) != PD_DISABLEPRINTTOFILE);
- m_printEnableSelection = ((pd->Flags & PD_NOSELECTION) != PD_NOSELECTION);
- m_printEnablePageNumbers = ((pd->Flags & PD_NOPAGENUMS) != PD_NOPAGENUMS);
- m_printEnableHelp = ((pd->Flags & PD_SHOWHELP) == PD_SHOWHELP);
- m_printSetupDialog = ((pd->Flags & PD_PRINTSETUP) == PD_PRINTSETUP);
-
-/* port is obsolete in WIN32
- // Get the port name
- if (pd->hDevNames)
- {
- LPDEVNAMES lpDevNames = (LPDEVNAMES)GlobalLock(pd->hDevNames);
- if (lpDevNames) {
- m_printData.SetPortName((LPSTR)lpDevNames + lpDevNames->wDriverOffset);
- wxString devName = (LPSTR)lpDevNames + lpDevNames->wDeviceOffset;
- GlobalUnlock(pd->hDevNames);
-
-// wxASSERT_MSG( (m_printerName == "" || (devName == m_printerName)), "Printer name obtained from DEVMODE and DEVNAMES were different!");
- }
- }
-*/
-}
-
-void wxPrintDialogData::SetOwnerWindow(wxWindow* win)
-{
- if ( m_printDlgData == NULL )
- ConvertToNative();
-
- if ( m_printDlgData != NULL && win != NULL)
- {
- PRINTDLG *pd = (PRINTDLG *) m_printDlgData ;
- pd->hwndOwner=(HWND) win->GetHWND();
- }