]> git.saurik.com Git - wxWidgets.git/commitdiff
Revert "Set up pages range in the wxMSW print dialog correctly."
authorVadim Zeitlin <vadim@wxwidgets.org>
Sat, 29 Jan 2011 13:55:40 +0000 (13:55 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Sat, 29 Jan 2011 13:55:40 +0000 (13:55 +0000)
This patch changed the relative order of calls to wxPrintout::GetPageInfo()
and OnPreparePrinting(), breaking the existing code and the documentation
promise about OnPreparePrinting() being called first, so revert it.

Reverts r66549.
See #12819.
Closes #12911.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@66813 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/msw/printwin.cpp

index dd8c25b4204c349e8416a4710aa5f74f8831ff2e..9018f7de7031374093ceeb7ce31959bd100d4023 100644 (file)
@@ -91,16 +91,10 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt
         return false;
     }
 
-    // Get some parameters from the printout, if defined
-    int fromPage, toPage;
-    int minPage, maxPage;
-    printout->GetPageInfo(&minPage, &maxPage, &fromPage, &toPage);
-
-    m_printDialogData.SetFromPage(fromPage);
-    m_printDialogData.SetToPage(toPage);
-    m_printDialogData.SetMinPage(minPage);
-    m_printDialogData.SetMaxPage(maxPage);
-    m_printDialogData.SetAllPages((fromPage == minPage) && (toPage == maxPage));
+    if (m_printDialogData.GetMinPage() < 1)
+        m_printDialogData.SetMinPage(1);
+    if (m_printDialogData.GetMaxPage() < 1)
+        m_printDialogData.SetMaxPage(9999);
 
     // Create a suitable device context
     wxPrinterDC *dc wxDUMMY_INITIALIZE(NULL);
@@ -157,6 +151,11 @@ bool wxWindowsPrinter::Print(wxWindow *parent, wxPrintout *printout, bool prompt
 
     printout->OnPreparePrinting();
 
+    // Get some parameters from the printout, if defined
+    int fromPage, toPage;
+    int minPage, maxPage;
+    printout->GetPageInfo(&minPage, &maxPage, &fromPage, &toPage);
+
     if (maxPage == 0)
     {
         sm_lastError = wxPRINTER_ERROR;