/////////////////////////////////////////////////////////////////////////////
-// Name: cmndata.cpp
+// Name: src/common/cmndata.cpp
// Purpose: Common GDI data
// Author: Julian Smart
// Modified by:
// headers
// ----------------------------------------------------------------------------
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
- #pragma implementation "cmndata.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#pragma hdrstop
#endif
+#include "wx/cmndata.h"
+
#ifndef WX_PRECOMP
+ #if defined(__WXMSW__)
+ #include "wx/msw/wrapcdlg.h"
+ #endif // MSW
#include <stdio.h>
#include "wx/string.h"
#include "wx/utils.h"
#include "wx/app.h"
+ #include "wx/log.h"
+ #include "wx/gdicmn.h"
#endif
-#include "wx/gdicmn.h"
-#include "wx/cmndata.h"
-#include "wx/log.h"
#include "wx/prntbase.h"
#include "wx/printdlg.h"
#endif // wxUSE_FONTDLG
#if wxUSE_PRINTING_ARCHITECTURE
- #include "wx/paper.h"
-#endif // wxUSE_PRINTING_ARCHITECTURE
-
-#if defined(__WXMSW__)
- #include <windowsx.h>
- #include "wx/msw/private.h"
- #ifndef __SMARTPHONE__ /* of WinCE */
- #include <commdlg.h>
- #endif
+#include "wx/paper.h"
- #if defined(__WATCOMC__) || defined(__SYMANTEC__) || defined(__SALFORDC__)
- #include <windowsx.h>
- #include <commdlg.h>
- #endif
-#endif // MSW
-
-#ifdef __WXMAC__
+#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)
- #endif // wxUSE_PRINTING_ARCHITECTURE
+IMPLEMENT_DYNAMIC_CLASS(wxPrintData, wxObject)
+IMPLEMENT_DYNAMIC_CLASS(wxPrintDialogData, wxObject)
+IMPLEMENT_DYNAMIC_CLASS(wxPageSetupDialogData, wxObject)
- IMPLEMENT_DYNAMIC_CLASS(wxFontData, wxObject)
- IMPLEMENT_DYNAMIC_CLASS(wxColourData, wxObject)
+#endif // wxUSE_PRINTING_ARCHITECTURE
-#ifndef DMPAPER_USER
- #define DMPAPER_USER 256
-#endif
+IMPLEMENT_DYNAMIC_CLASS(wxFontData, wxObject)
+IMPLEMENT_DYNAMIC_CLASS(wxColourData, wxObject)
// ============================================================================
// implementation
wxPrintData::wxPrintData()
{
-#ifdef __WXMAC__
- m_nativePrintData = wxNativePrintData::Create() ;
-#endif
m_bin = wxPRINTBIN_DEFAULT;
+ m_media = wxPRINTMEDIA_DEFAULT;
m_printMode = wxPRINT_MODE_PRINTER;
m_printOrientation = wxPORTRAIT;
m_printNoCopies = 1;
m_paperId = wxPAPER_A4;
m_paperSize = wxSize(210, 297);
+ m_privData = NULL;
+ m_privDataLen = 0;
+
m_nativeData = wxPrintFactory::GetFactory()->CreatePrintNativeData();
}
: wxObject()
{
m_nativeData = NULL;
+ m_privData = 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)
delete m_nativeData;
-#ifdef __WXMAC__
- delete m_nativePrintData ;
-#endif
+ if (m_privData)
+ delete [] m_privData;
}
void wxPrintData::ConvertToNative()
{
-#ifdef __WXMAC__
- m_nativePrintData->TransferFrom( this ) ;
-#else
m_nativeData->TransferFrom( *this ) ;
-#endif
}
void wxPrintData::ConvertFromNative()
{
-#ifdef __WXMAC__
- m_nativePrintData->TransferTo( this ) ;
-#else
m_nativeData->TransferTo( *this ) ;
-#endif
}
void wxPrintData::operator=(const wxPrintData& data)
m_paperId = data.m_paperId;
m_paperSize = data.m_paperSize;
m_bin = data.m_bin;
+ m_media = data.m_media;
m_printMode = data.m_printMode;
m_filename = data.m_filename;
m_nativeData = data.GetNativeData();
m_nativeData->m_ref++;
-#ifdef __WXMAC__
- m_nativePrintData->CopyFrom( data.m_nativePrintData ) ;
-#endif
+ 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 );
+ }
}
// Is this data OK for showing the print dialog?
-bool wxPrintData::Ok() const
+bool wxPrintData::IsOk() const
{
m_nativeData->TransferFrom( *this );
{
}
-#ifdef __WXMAC__
-
-void wxPrintDialogData::ConvertToNative()
-{
- m_printData.ConvertToNative();
- m_printData.m_nativePrintData->TransferFrom( this ) ;
-}
-
-void wxPrintDialogData::ConvertFromNative()
-{
- m_printData.ConvertFromNative();
- m_printData.m_nativePrintData->TransferTo( this ) ;
-}
-
-#endif
-
-
void wxPrintDialogData::operator=(const wxPrintDialogData& data)
{
m_printFromPage = data.m_printFromPage;
wxPageSetupDialogData::wxPageSetupDialogData()
{
- m_paperSize = wxSize();
+ m_paperSize = wxSize(0,0);
CalculatePaperSizeFromId();
m_minMarginTopLeft =
m_minMarginBottomRight =
m_marginTopLeft =
- m_marginBottomRight = wxPoint();
+ m_marginBottomRight = wxPoint(0,0);
// Flags
m_defaultMinMargins = false;
wxPageSetupDialogData::wxPageSetupDialogData(const wxPrintData& printData)
{
- m_paperSize = wxSize();
+ m_paperSize = wxSize(0,0);
m_minMarginTopLeft =
m_minMarginBottomRight =
m_marginTopLeft =
- m_marginBottomRight = wxPoint();
+ m_marginBottomRight = wxPoint(0,0);
// Flags
m_defaultMinMargins = false;
m_enableOrientation = data.m_enableOrientation;
m_enablePaper = data.m_enablePaper;
m_enablePrinter = data.m_enablePrinter;
- m_getDefaultInfo = data.m_getDefaultInfo;;
+ m_getDefaultInfo = data.m_getDefaultInfo;
m_enableHelp = data.m_enableHelp;
m_printData = data.m_printData;
return *this;
}
-#ifdef __WXMAC__
-void wxPageSetupDialogData::ConvertToNative()
-{
- m_printData.ConvertToNative();
- m_printData.m_nativePrintData->TransferFrom( this ) ;
-}
-
-void wxPageSetupDialogData::ConvertFromNative()
-{
- m_printData.ConvertFromNative ();
- m_paperSize = m_printData.GetPaperSize() ;
- CalculateIdFromPaperSize();
- m_printData.m_nativePrintData->TransferTo( this ) ;
- // adjust minimal values
-
- if ( m_marginTopLeft.x < m_minMarginTopLeft.x )
- m_marginTopLeft.x = m_minMarginTopLeft.x;
-
- if ( m_marginBottomRight.x < m_minMarginBottomRight.x )
- m_marginBottomRight.x = m_minMarginBottomRight.x;
-
- if ( m_marginTopLeft.y < m_minMarginTopLeft.y )
- m_marginTopLeft.y = m_minMarginTopLeft.y;
-
- if ( m_marginBottomRight.y < m_minMarginBottomRight.y )
- m_marginBottomRight.y = m_minMarginBottomRight.y;
-}
-#endif
-
-
// If a corresponding paper type is found in the paper database, will set the m_printData
// paper size id member as well.
void wxPageSetupDialogData::SetPaperSize(const wxSize& sz)