#include "wx/paper.h"
#endif // wxUSE_PRINTING_ARCHITECTURE
-#if defined(__WXMSW__) && !defined(__PALMOS__)
+#if defined(__WXMSW__)
#include <windowsx.h>
#include "wx/msw/private.h"
#endif
#endif // MSW
-#ifdef __WXMAC__
+ #if wxUSE_PRINTING_ARCHITECTURE
+
+#if defined(__WXMAC__)
#include "wx/mac/private/print.h"
#endif
- #if wxUSE_PRINTING_ARCHITECTURE
IMPLEMENT_DYNAMIC_CLASS(wxPrintData, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxPrintDialogData, wxObject)
IMPLEMENT_DYNAMIC_CLASS(wxPageSetupDialogData, wxObject)
m_printCollate = false;
// New, 24/3/99
- m_printerName = wxT("");
+ m_printerName = wxEmptyString;
m_colour = true;
m_duplexMode = wxDUPLEX_SIMPLEX;
m_printQuality = wxPRINT_QUALITY_HIGH;
m_paperId = wxPAPER_A4;
m_paperSize = wxSize(210, 297);
+ m_privData = NULL;
+ m_privDataLen = 0;
+
m_nativeData = wxPrintFactory::GetFactory()->CreatePrintNativeData();
}
wxPrintData::wxPrintData(const wxPrintData& printData)
: wxObject()
{
+ m_nativeData = NULL;
(*this) = printData;
}
+void wxPrintData::SetPrivData( char *privData, int len )
+{
+ if (m_privData)
+ {
+ delete [] m_privData;
+ m_privData = NULL;
+ }
+ m_privDataLen = len;
+ if (m_privDataLen > 0)
+ {
+ m_privData = new char[m_privDataLen];
+ memcpy( m_privData, privData, m_privDataLen );
+ }
+}
+
wxPrintData::~wxPrintData()
{
m_nativeData->m_ref--;
- if (m_nativeData->m_ref == 0)
+ if (m_nativeData->m_ref == 0)
delete m_nativeData;
+ if (m_privData)
+ delete [] m_privData;
+
#ifdef __WXMAC__
delete m_nativePrintData ;
#endif
m_paperSize = data.m_paperSize;
m_bin = data.m_bin;
m_printMode = data.m_printMode;
- m_filename = data.m_filename;
+ m_filename = data.m_filename;
- // UnRef old m_nativeData
- m_nativeData->m_ref--;
- if (m_nativeData->m_ref == 0)
- delete m_nativeData;
+ // UnRef old m_nativeData
+ if (m_nativeData)
+ {
+ m_nativeData->m_ref--;
+ if (m_nativeData->m_ref == 0)
+ delete m_nativeData;
+ }
// Set Ref new one
m_nativeData = data.GetNativeData();
m_nativeData->m_ref++;
-
+
+ if (m_privData)
+ {
+ delete [] m_privData;
+ m_privData = NULL;
+ }
+ m_privDataLen = data.GetPrivDataLen();
+ if (m_privDataLen > 0)
+ {
+ m_privData = new char[m_privDataLen];
+ memcpy( m_privData, data.GetPrivData(), m_privDataLen );
+ }
+
#ifdef __WXMAC__
m_nativePrintData->CopyFrom( data.m_nativePrintData ) ;
#endif
return m_nativeData->Ok();
}
-#if WXWIN_COMPATIBILITY_2_4
+// What should happen here? wxPostScriptPrintNativeData is not
+// defined unless all this is true on MSW.
+#if WXWIN_COMPATIBILITY_2_4 && wxUSE_PRINTING_ARCHITECTURE && (!defined(__WXMSW__) || wxUSE_POSTSCRIPT_ARCHITECTURE_IN_MSW)
#include "wx/generic/prntdlgg.h"
if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterCommand();
#endif
- return wxT("");
+ return wxEmptyString;
}
wxString wxPrintData::GetPrinterOptions() const
if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterOptions();
#endif
- return wxT("");
+ return wxEmptyString;
}
wxString wxPrintData::GetPreviewCommand() const
if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPreviewCommand();
#endif
- return wxT("");
+ return wxEmptyString;
}
wxString wxPrintData::GetFontMetricPath() const
if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
return ((wxPostScriptPrintNativeData*)m_nativeData)->GetFontMetricPath();
#endif
- return wxT("");
+ return wxEmptyString;
}
double wxPrintData::GetPrinterScaleX() const
m_printSelection = false;
m_printEnableSelection = false;
m_printEnablePageNumbers = true;
-
+
wxPrintFactory* factory = wxPrintFactory::GetFactory();
m_printEnablePrintToFile = ! factory->HasOwnPrintToFile();
-
+
m_printEnableHelp = false;
#if WXWIN_COMPATIBILITY_2_4
m_printSetupDialog = false;
wxPageSetupDialogData::wxPageSetupDialogData()
{
- m_paperSize = wxSize(0, 0);
+ m_paperSize = wxSize(0,0);
CalculatePaperSizeFromId();
- m_minMarginTopLeft = wxPoint(0, 0);
- m_minMarginBottomRight = wxPoint(0, 0);
- m_marginTopLeft = wxPoint(0, 0);
- m_marginBottomRight = wxPoint(0, 0);
+ m_minMarginTopLeft =
+ m_minMarginBottomRight =
+ m_marginTopLeft =
+ m_marginBottomRight = wxPoint(0,0);
// Flags
m_defaultMinMargins = false;
wxPageSetupDialogData::wxPageSetupDialogData(const wxPrintData& printData)
{
- m_paperSize = wxSize(0, 0);
- m_minMarginTopLeft = wxPoint(0, 0);
- m_minMarginBottomRight = wxPoint(0, 0);
- m_marginTopLeft = wxPoint(0, 0);
- m_marginBottomRight = wxPoint(0, 0);
+ m_paperSize = wxSize(0,0);
+ m_minMarginTopLeft =
+ m_minMarginBottomRight =
+ m_marginTopLeft =
+ m_marginBottomRight = wxPoint(0,0);
// Flags
m_defaultMinMargins = false;
wxPageSetupDialogData& wxPageSetupDialogData::operator=(const wxPrintData& data)
{
m_printData = data;
+ CalculatePaperSizeFromId();
return *this;
}
CalculatePaperSizeFromId();
}
+void wxPageSetupDialogData::SetPrintData(const wxPrintData& printData)
+{
+ m_printData = printData;
+ CalculatePaperSizeFromId();
+}
+
// Use paper size defined in this object to set the wxPrintData
// paper id
void wxPageSetupDialogData::CalculateIdFromPaperSize()