#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();
}
(*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)
delete m_nativeData;
+
+ if (m_privData)
+ delete [] m_privData;
#ifdef __WXMAC__
delete m_nativePrintData ;
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
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
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()