X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/14f355c2b5c71fc7c3d680aea366582d2ac60f7b..5c250a10332dc17263c66deb629b5fa8c4320f8a:/src/msw/printwin.cpp?ds=sidebyside diff --git a/src/msw/printwin.cpp b/src/msw/printwin.cpp index 34ce8201a4..64c0572ac5 100644 --- a/src/msw/printwin.cpp +++ b/src/msw/printwin.cpp @@ -30,7 +30,9 @@ #include "wx/defs.h" -#if wxUSE_PRINTING_ARCHITECTURE +// Don't use the Windows printer if we're in wxUniv mode and using +// the PostScript architecture +#if wxUSE_PRINTING_ARCHITECTURE && (!defined(__WXUNIVERSAL__) || !wxUSE_POSTSCRIPT_ARCHITECTURE_IN_MSW) #ifndef WX_PRECOMP #include "wx/window.h" @@ -88,7 +90,7 @@ wxWindowsPrinter::wxWindowsPrinter(wxPrintDialogData *data) wxWindowsPrinter::~wxWindowsPrinter() { // avoids warning about statement with no effect (FreeProcInstance - // doesn't do anything under Win32) + // doesn't do anything under Win32) #if !defined(__WIN32__) && !defined(__NT__) FreeProcInstance((FARPROC) m_lpAbortProc); #endif @@ -96,16 +98,16 @@ wxWindowsPrinter::~wxWindowsPrinter() bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt) { - sm_abortIt = FALSE; + sm_abortIt = false; sm_abortWindow = NULL; if (!printout) { sm_lastError = wxPRINTER_ERROR; - return FALSE; + return false; } - printout->SetIsPreview(FALSE); + printout->SetIsPreview(false); if (m_printDialogData.GetMinPage() < 1) m_printDialogData.SetMinPage(1); @@ -118,7 +120,7 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt { dc = PrintDialog(parent); if (!dc) - return FALSE; + return false; } else { @@ -129,7 +131,7 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt if (!dc || !dc->Ok()) { if (dc) delete dc; - return FALSE; + return false; } int logPPIScreenX = 0; @@ -148,7 +150,7 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt { delete dc; sm_lastError = wxPRINTER_ERROR; - return FALSE; + return false; } printout->SetPPIScreen(logPPIScreenX, logPPIScreenY); @@ -178,7 +180,7 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt { sm_lastError = wxPRINTER_ERROR; wxEndBusyCursor(); - return FALSE; + return false; } // Only set min and max, because from and to have been @@ -217,19 +219,27 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt delete dc; } sm_abortWindow = win; - sm_abortWindow->Show(TRUE); + sm_abortWindow->Show(); wxSafeYield(); printout->OnBeginPrinting(); sm_lastError = wxPRINTER_NO_ERROR; + int minPageNum = minPage, maxPageNum = maxPage; + + if ( !m_printDialogData.GetAllPages() ) + { + minPageNum = m_printDialogData.GetFromPage(); + maxPageNum = m_printDialogData.GetToPage(); + } + int copyCount; for ( copyCount = 1; copyCount <= m_printDialogData.GetNoCopies(); copyCount++ ) { - if (!printout->OnBeginDocument(m_printDialogData.GetFromPage(), m_printDialogData.GetToPage())) + if ( !printout->OnBeginDocument(minPageNum, maxPageNum) ) { wxEndBusyCursor(); wxLogError(_("Could not start printing.")); @@ -243,8 +253,9 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt } int pn; - for ( pn = m_printDialogData.GetFromPage(); - pn <= m_printDialogData.GetToPage() && printout->HasPage(pn); + + for ( pn = minPageNum; + pn <= maxPageNum && printout->HasPage(pn); pn++ ) { if ( sm_abortIt ) @@ -271,7 +282,7 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt if (sm_abortWindow) { - sm_abortWindow->Show(FALSE); + sm_abortWindow->Show(false); delete sm_abortWindow; sm_abortWindow = NULL; } @@ -308,7 +319,7 @@ wxDC* wxWindowsPrinter::PrintDialog(wxWindow *parent) bool wxWindowsPrinter::Setup(wxWindow *parent) { wxPrintDialog dialog(parent, & m_printDialogData); - dialog.GetPrintDialogData().SetSetupDialog(TRUE); + dialog.GetPrintDialogData().SetSetupDialog(true); int ret = dialog.ShowModal(); @@ -347,7 +358,7 @@ wxWindowsPrintPreview::~wxWindowsPrintPreview() bool wxWindowsPrintPreview::Print(bool interactive) { if (!m_printPrintout) - return FALSE; + return false; wxWindowsPrinter printer(&m_printDialogData); return printer.Print(m_previewFrame, m_printPrintout, interactive); } @@ -386,10 +397,10 @@ void wxWindowsPrintPreview::DetermineScaling() m_previewPrintout->SetPageSizeMM(printerWidth, printerHeight); if (logPPIPrinterX == 0 || logPPIPrinterY == 0 || printerWidth == 0 || printerHeight == 0) - m_isOk = FALSE; + m_isOk = false; } else - m_isOk = FALSE; + m_isOk = false; m_pageWidth = printerXRes; m_pageHeight = printerYRes;