applied Unicode fixes for mingw32 (patch 429654)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@10414 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -66,7 +66,7 @@ WXDLLEXPORT_DATA(extern const wxChar*) wxEmptyString;
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
// Microsoft compiler loves underscores, feed them to it
|
// Microsoft compiler loves underscores, feed them to it
|
||||||
#ifdef __VISUALC__
|
#if defined( __VISUALC__ ) || defined( __GNUWIN32__ )
|
||||||
// functions
|
// functions
|
||||||
#define wxClose _close
|
#define wxClose _close
|
||||||
#define wxRead _read
|
#define wxRead _read
|
||||||
|
@@ -60,7 +60,7 @@ public:
|
|||||||
virtual ~wxPrinterBase();
|
virtual ~wxPrinterBase();
|
||||||
|
|
||||||
virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPrintout *printout);
|
virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPrintout *printout);
|
||||||
virtual void ReportError(wxWindow *parent, wxPrintout *printout, char *message);
|
virtual void ReportError(wxWindow *parent, wxPrintout *printout, const wxString& message);
|
||||||
|
|
||||||
wxPrintDialogData& GetPrintDialogData() const
|
wxPrintDialogData& GetPrintDialogData() const
|
||||||
{ return (wxPrintDialogData&) m_printDialogData; }
|
{ return (wxPrintDialogData&) m_printDialogData; }
|
||||||
|
@@ -144,7 +144,7 @@ static const int wxTREE_HITTEST_ONITEM = wxTREE_HITTEST_ONITEMICON |
|
|||||||
wxTREE_HITTEST_ONITEMLABEL;
|
wxTREE_HITTEST_ONITEMLABEL;
|
||||||
|
|
||||||
// tree ctrl default name
|
// tree ctrl default name
|
||||||
WXDLLEXPORT_DATA(extern const char*) wxTreeCtrlNameStr;
|
WXDLLEXPORT_DATA(extern const wxChar*) wxTreeCtrlNameStr;
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxTreeItemAttr: a structure containing the visual attributes of an item
|
// wxTreeItemAttr: a structure containing the visual attributes of an item
|
||||||
|
@@ -63,6 +63,11 @@
|
|||||||
#define wxHAVE_TCHAR_FUNCTIONS
|
#define wxHAVE_TCHAR_FUNCTIONS
|
||||||
#elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x520)
|
#elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x520)
|
||||||
#define wxHAVE_TCHAR_FUNCTIONS
|
#define wxHAVE_TCHAR_FUNCTIONS
|
||||||
|
#elif defined(__GNUWIN32__) && wxCHECK_W32API_VERSION( 0, 6 )
|
||||||
|
#define wxHAVE_TCHAR_FUNCTIONS
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <ctype.h>
|
||||||
#endif
|
#endif
|
||||||
#elif defined(__VISAGECPP__) && (__IBMCPP__ >= 400)
|
#elif defined(__VISAGECPP__) && (__IBMCPP__ >= 400)
|
||||||
// VisualAge 4.0+ supports TCHAR
|
// VisualAge 4.0+ supports TCHAR
|
||||||
@@ -116,6 +121,12 @@
|
|||||||
# include <tchar.h>
|
# include <tchar.h>
|
||||||
|
|
||||||
# if wxUSE_UNICODE // temporary - preserve binary compatibility
|
# if wxUSE_UNICODE // temporary - preserve binary compatibility
|
||||||
|
#if defined(__GNUWIN32__)
|
||||||
|
#define _TCHAR TCHAR
|
||||||
|
#define _TSCHAR TCHAR
|
||||||
|
#define _TUCHAR TCHAR
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef _TCHAR wxChar;
|
typedef _TCHAR wxChar;
|
||||||
typedef _TSCHAR wxSChar;
|
typedef _TSCHAR wxSChar;
|
||||||
typedef _TUCHAR wxUChar;
|
typedef _TUCHAR wxUChar;
|
||||||
|
@@ -180,15 +180,15 @@ wxPrintData::wxPrintData()
|
|||||||
m_macPageFormat = kPMNoPageFormat;
|
m_macPageFormat = kPMNoPageFormat;
|
||||||
m_macPrintSettings = kPMNoPrintSettings;
|
m_macPrintSettings = kPMNoPrintSettings;
|
||||||
#else
|
#else
|
||||||
m_macPrintInfo = (THPrint) NewHandleClear( sizeof( TPrint ) ) ;
|
m_macPrintInfo = (THPrint) NewHandleClear( sizeof( TPrint ) );
|
||||||
(**m_macPrintInfo).iPrVersion = 0; // something invalid
|
(**m_macPrintInfo).iPrVersion = 0; // something invalid
|
||||||
|
|
||||||
(**m_macPrintInfo).prInfo.iHRes = 72;
|
(**m_macPrintInfo).prInfo.iHRes = 72;
|
||||||
(**m_macPrintInfo).prInfo.iVRes = 72;
|
(**m_macPrintInfo).prInfo.iVRes = 72;
|
||||||
Rect r1 = { 0, 0, 8*72 - 2 * 18, 11*72 - 2 * 36 } ;
|
Rect r1 = { 0, 0, 8*72 - 2 * 18, 11*72 - 2 * 36 };
|
||||||
(**m_macPrintInfo).prInfo.rPage = r1;// must have its top left & (0,0)
|
(**m_macPrintInfo).prInfo.rPage = r1;// must have its top left & (0,0)
|
||||||
|
|
||||||
Rect r2 = { -18, -36, 8*72 - 18, 11*72 - 36 } ;
|
Rect r2 = { -18, -36, 8*72 - 18, 11*72 - 36 };
|
||||||
(**m_macPrintInfo).rPaper = r2;
|
(**m_macPrintInfo).rPaper = r2;
|
||||||
(**m_macPrintInfo).prStl.iPageV = 11 * 120 ; // 11 inches in 120th of an inch
|
(**m_macPrintInfo).prStl.iPageV = 11 * 120 ; // 11 inches in 120th of an inch
|
||||||
(**m_macPrintInfo).prStl.iPageH = 8 * 120 ; // 8 inches in 120th of an inch
|
(**m_macPrintInfo).prStl.iPageH = 8 * 120 ; // 8 inches in 120th of an inch
|
||||||
@@ -229,7 +229,7 @@ wxPrintData::wxPrintData(const wxPrintData& printData)
|
|||||||
m_macPageFormat = kPMNoPageFormat;
|
m_macPageFormat = kPMNoPageFormat;
|
||||||
m_macPrintSettings = kPMNoPrintSettings;
|
m_macPrintSettings = kPMNoPrintSettings;
|
||||||
#else
|
#else
|
||||||
m_macPrintInfo = NULL ;
|
m_macPrintInfo = NULL;
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
(*this) = printData;
|
(*this) = printData;
|
||||||
@@ -258,7 +258,7 @@ wxPrintData::~wxPrintData()
|
|||||||
m_macPrintSettings = kPMNoPrintSettings;
|
m_macPrintSettings = kPMNoPrintSettings;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
wxASSERT( m_macPrintInfo ) ;
|
wxASSERT( m_macPrintInfo );
|
||||||
// we should perhaps delete
|
// we should perhaps delete
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
@@ -311,23 +311,26 @@ static HGLOBAL wxCreateDevNames(const wxString& driverName, const wxString& prin
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
hDev = GlobalAlloc(GPTR, 4*sizeof(WORD)+
|
hDev = GlobalAlloc(GPTR, 4*sizeof(WORD)+
|
||||||
driverName.Length() + 1 +
|
( driverName.Length() + 1 +
|
||||||
printerName.Length() + 1 +
|
printerName.Length() + 1 +
|
||||||
portName.Length()+1);
|
portName.Length()+1 ) * sizeof(wxChar) );
|
||||||
LPDEVNAMES lpDev = (LPDEVNAMES)GlobalLock(hDev);
|
LPDEVNAMES lpDev = (LPDEVNAMES)GlobalLock(hDev);
|
||||||
lpDev->wDriverOffset = sizeof(WORD)*4;
|
lpDev->wDriverOffset = sizeof(WORD)*4;
|
||||||
wxStrcpy((wxChar*)lpDev + lpDev->wDriverOffset, driverName);
|
wxStrcpy((wxChar*)((char*)lpDev + lpDev->wDriverOffset ), driverName);
|
||||||
|
|
||||||
lpDev->wDeviceOffset = (WORD)(lpDev->wDriverOffset + driverName.Length()+1);
|
lpDev->wDeviceOffset = (WORD)( lpDev->wDriverOffset +
|
||||||
wxStrcpy((wxChar*)lpDev + lpDev->wDeviceOffset, printerName);
|
sizeof(wxChar) * ( driverName.Length() + 1 ) );
|
||||||
|
wxStrcpy((wxChar*)((char*)lpDev + lpDev->wDeviceOffset ), printerName);
|
||||||
|
|
||||||
lpDev->wOutputOffset = (WORD)(lpDev->wDeviceOffset + printerName.Length()+1);
|
lpDev->wOutputOffset = (WORD)( lpDev->wDeviceOffset +
|
||||||
wxStrcpy((wxChar*)lpDev + lpDev->wOutputOffset, portName);
|
sizeof(wxChar) * ( printerName.Length() + 1 ) );
|
||||||
|
wxStrcpy((wxChar*)((char*) lpDev + lpDev->wOutputOffset ), portName);
|
||||||
|
|
||||||
lpDev->wDefault = 0;
|
lpDev->wDefault = 0;
|
||||||
|
|
||||||
GlobalUnlock(hDev);
|
GlobalUnlock(hDev);
|
||||||
}
|
}
|
||||||
|
|
||||||
return hDev;
|
return hDev;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -338,35 +341,35 @@ void wxPrintData::ConvertToNative()
|
|||||||
if (!hDevMode)
|
if (!hDevMode)
|
||||||
{
|
{
|
||||||
// Use PRINTDLG as a way of creating a DEVMODE object
|
// Use PRINTDLG as a way of creating a DEVMODE object
|
||||||
PRINTDLG *pd = new PRINTDLG;
|
PRINTDLG pd;
|
||||||
|
|
||||||
// GNU-WIN32 has the wrong size PRINTDLG - can't work out why.
|
// GNU-WIN32 has the wrong size PRINTDLG - can't work out why.
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
memset(pd, 0, 66);
|
memset(&pd, 0, 66);
|
||||||
pd->lStructSize = 66 ;
|
pd.lStructSize = 66;
|
||||||
#else
|
#else
|
||||||
memset(pd, 0, sizeof(PRINTDLG));
|
memset(&pd, 0, sizeof(PRINTDLG));
|
||||||
pd->lStructSize = sizeof(PRINTDLG);
|
pd.lStructSize = sizeof(PRINTDLG);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
pd->hwndOwner = (HWND)NULL;
|
pd.hwndOwner = (HWND)NULL;
|
||||||
pd->hDevMode = NULL; // Will be created by PrintDlg
|
pd.hDevMode = NULL; // Will be created by PrintDlg
|
||||||
pd->hDevNames = NULL; // Ditto
|
pd.hDevNames = NULL; // Ditto
|
||||||
pd->hInstance = (HINSTANCE) wxGetInstance();
|
//pd.hInstance = (HINSTANCE) wxGetInstance();
|
||||||
|
|
||||||
pd->Flags = PD_RETURNDEFAULT;
|
pd.Flags = PD_RETURNDEFAULT;
|
||||||
pd->nCopies = 1;
|
pd.nCopies = 1;
|
||||||
|
|
||||||
// Fill out the DEVMODE structure
|
// Fill out the DEVMODE structure
|
||||||
// so we can use it as input in the 'real' PrintDlg
|
// so we can use it as input in the 'real' PrintDlg
|
||||||
if (!PrintDlg(pd))
|
if (!PrintDlg(&pd))
|
||||||
{
|
{
|
||||||
if ( pd->hDevMode )
|
if ( pd.hDevMode )
|
||||||
GlobalFree(pd->hDevMode);
|
GlobalFree(pd.hDevMode);
|
||||||
if ( pd->hDevNames )
|
if ( pd.hDevNames )
|
||||||
GlobalFree(pd->hDevNames);
|
GlobalFree(pd.hDevNames);
|
||||||
pd->hDevMode = NULL;
|
pd.hDevMode = NULL;
|
||||||
pd->hDevNames = NULL;
|
pd.hDevNames = NULL;
|
||||||
|
|
||||||
#if defined(__WXDEBUG__) && defined(__WIN32__)
|
#if defined(__WXDEBUG__) && defined(__WIN32__)
|
||||||
wxString str(wxT("Printing error: "));
|
wxString str(wxT("Printing error: "));
|
||||||
@@ -376,22 +379,20 @@ void wxPrintData::ConvertToNative()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hDevMode = pd->hDevMode;
|
hDevMode = pd.hDevMode;
|
||||||
m_devMode = (void*)(long) hDevMode;
|
m_devMode = (void*)(long) hDevMode;
|
||||||
pd->hDevMode = NULL;
|
pd.hDevMode = NULL;
|
||||||
|
|
||||||
// We'll create a new DEVNAMEs structure below.
|
// We'll create a new DEVNAMEs structure below.
|
||||||
if ( pd->hDevNames )
|
if ( pd.hDevNames )
|
||||||
GlobalFree(pd->hDevNames);
|
GlobalFree(pd.hDevNames);
|
||||||
pd->hDevNames = NULL;
|
pd.hDevNames = NULL;
|
||||||
|
|
||||||
// hDevNames = pd->hDevNames;
|
// hDevNames = pd->hDevNames;
|
||||||
// m_devNames = (void*)(long) hDevNames;
|
// m_devNames = (void*)(long) hDevNames;
|
||||||
// pd->hDevnames = NULL;
|
// pd->hDevnames = NULL;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
delete pd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( hDevMode )
|
if ( hDevMode )
|
||||||
@@ -421,12 +422,9 @@ void wxPrintData::ConvertToNative()
|
|||||||
|
|
||||||
if (m_printerName != wxT(""))
|
if (m_printerName != wxT(""))
|
||||||
{
|
{
|
||||||
// TODO: make this Unicode compatible
|
//int len = wxMin(31, m_printerName.Len());
|
||||||
int len = wxMin(31, m_printerName.Len());
|
wxStrncpy((wxChar*)devMode->dmDeviceName,m_printerName.c_str(),31);
|
||||||
int i;
|
devMode->dmDeviceName[31] = wxT('\0');
|
||||||
for (i = 0; i < len; i++)
|
|
||||||
devMode->dmDeviceName[i] = m_printerName.GetChar(i);
|
|
||||||
devMode->dmDeviceName[i] = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//// Colour
|
//// Colour
|
||||||
@@ -516,7 +514,7 @@ void wxPrintData::ConvertToNative()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: I hope it's OK to pass some empty strings to DEVNAMES.
|
// TODO: I hope it's OK to pass some empty strings to DEVNAMES.
|
||||||
m_devNames = (void*) (long) wxCreateDevNames("", m_printerName, "");
|
m_devNames = (void*) (long) wxCreateDevNames(wxT(""), m_printerName, wxT(""));
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxPrintData::ConvertFromNative()
|
void wxPrintData::ConvertFromNative()
|
||||||
@@ -601,8 +599,8 @@ void wxPrintData::ConvertFromNative()
|
|||||||
if (paper)
|
if (paper)
|
||||||
{
|
{
|
||||||
m_paperId = paper->GetId();
|
m_paperId = paper->GetId();
|
||||||
m_paperSize.x = paper->GetWidth() / 10 ;
|
m_paperSize.x = paper->GetWidth() / 10;
|
||||||
m_paperSize.y = paper->GetHeight() / 10 ;
|
m_paperSize.y = paper->GetHeight() / 10;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -709,7 +707,7 @@ void wxPrintData::ConvertFromNative()
|
|||||||
// m_printData.SetPortName((LPSTR)lpDevNames + lpDevNames->wDriverOffset);
|
// m_printData.SetPortName((LPSTR)lpDevNames + lpDevNames->wDriverOffset);
|
||||||
|
|
||||||
// Get the printer name
|
// Get the printer name
|
||||||
wxString printerName = (LPSTR)lpDevNames + lpDevNames->wDeviceOffset;
|
wxString printerName = (LPTSTR)lpDevNames + lpDevNames->wDeviceOffset;
|
||||||
|
|
||||||
// Not sure if we should check for this mismatch
|
// Not sure if we should check for this mismatch
|
||||||
// wxASSERT_MSG( (m_printerName == "" || (devName == m_printerName)), "Printer name obtained from DEVMODE and DEVNAMES were different!");
|
// wxASSERT_MSG( (m_printerName == "" || (devName == m_printerName)), "Printer name obtained from DEVMODE and DEVNAMES were different!");
|
||||||
@@ -729,7 +727,7 @@ void wxPrintData::ConvertToNative()
|
|||||||
{
|
{
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
(**m_macPrintInfo).prJob.iCopies = m_printNoCopies ;
|
(**m_macPrintInfo).prJob.iCopies = m_printNoCopies;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -737,7 +735,7 @@ void wxPrintData::ConvertFromNative()
|
|||||||
{
|
{
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
m_printNoCopies = (**m_macPrintInfo).prJob.iCopies ;
|
m_printNoCopies = (**m_macPrintInfo).prJob.iCopies;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -747,8 +745,8 @@ void wxPrintData::operator=(const wxPrintData& data)
|
|||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
m_macPrintInfo = data.m_macPrintInfo ;
|
m_macPrintInfo = data.m_macPrintInfo;
|
||||||
HandToHand( (Handle*) &m_macPrintInfo ) ;
|
HandToHand( (Handle*) &m_macPrintInfo );
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
m_printNoCopies = data.m_printNoCopies;
|
m_printNoCopies = data.m_printNoCopies;
|
||||||
@@ -878,11 +876,12 @@ void wxPrintDialogData::ConvertToNative()
|
|||||||
if (!pd)
|
if (!pd)
|
||||||
{
|
{
|
||||||
pd = new PRINTDLG;
|
pd = new PRINTDLG;
|
||||||
|
memset( pd, 0, sizeof(PRINTDLG) );
|
||||||
m_printDlgData = (void*) pd;
|
m_printDlgData = (void*) pd;
|
||||||
|
|
||||||
// GNU-WIN32 has the wrong size PRINTDLG - can't work out why.
|
// GNU-WIN32 has the wrong size PRINTDLG - can't work out why.
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
pd->lStructSize = 66 ;
|
pd->lStructSize = 66;
|
||||||
#else
|
#else
|
||||||
pd->lStructSize = sizeof(PRINTDLG);
|
pd->lStructSize = sizeof(PRINTDLG);
|
||||||
#endif
|
#endif
|
||||||
@@ -925,10 +924,10 @@ void wxPrintDialogData::ConvertToNative()
|
|||||||
pd->nMaxPage = (WORD)m_printMaxPage;
|
pd->nMaxPage = (WORD)m_printMaxPage;
|
||||||
pd->nCopies = (WORD)m_printNoCopies;
|
pd->nCopies = (WORD)m_printNoCopies;
|
||||||
|
|
||||||
pd->Flags = PD_RETURNDC ;
|
pd->Flags = PD_RETURNDC;
|
||||||
|
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
pd->lStructSize = 66 ;
|
pd->lStructSize = 66;
|
||||||
#else
|
#else
|
||||||
pd->lStructSize = sizeof( PRINTDLG );
|
pd->lStructSize = sizeof( PRINTDLG );
|
||||||
#endif
|
#endif
|
||||||
@@ -998,11 +997,11 @@ void wxPrintDialogData::ConvertFromNative()
|
|||||||
// into wxWindows form.
|
// into wxWindows form.
|
||||||
m_printData.ConvertFromNative();
|
m_printData.ConvertFromNative();
|
||||||
|
|
||||||
m_printFromPage = pd->nFromPage ;
|
m_printFromPage = pd->nFromPage;
|
||||||
m_printToPage = pd->nToPage ;
|
m_printToPage = pd->nToPage;
|
||||||
m_printMinPage = pd->nMinPage ;
|
m_printMinPage = pd->nMinPage;
|
||||||
m_printMaxPage = pd->nMaxPage ;
|
m_printMaxPage = pd->nMaxPage;
|
||||||
m_printNoCopies = pd->nCopies ;
|
m_printNoCopies = pd->nCopies;
|
||||||
|
|
||||||
m_printAllPages = ((pd->Flags & PD_ALLPAGES) == PD_ALLPAGES);
|
m_printAllPages = ((pd->Flags & PD_ALLPAGES) == PD_ALLPAGES);
|
||||||
m_printSelection = ((pd->Flags & PD_SELECTION) == PD_SELECTION);
|
m_printSelection = ((pd->Flags & PD_SELECTION) == PD_SELECTION);
|
||||||
@@ -1037,7 +1036,7 @@ void wxPrintDialogData::SetOwnerWindow(wxWindow* win)
|
|||||||
|
|
||||||
if ( m_printDlgData != NULL && win != NULL)
|
if ( m_printDlgData != NULL && win != NULL)
|
||||||
{
|
{
|
||||||
PRINTDLG *pd = (PRINTDLG *) m_printDlgData ;
|
PRINTDLG *pd = (PRINTDLG *) m_printDlgData;
|
||||||
pd->hwndOwner=(HWND) win->GetHWND();
|
pd->hwndOwner=(HWND) win->GetHWND();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1048,9 +1047,9 @@ void wxPrintDialogData::ConvertToNative()
|
|||||||
{
|
{
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
(**m_printData.m_macPrintInfo).prJob.iFstPage = m_printFromPage ;
|
(**m_printData.m_macPrintInfo).prJob.iFstPage = m_printFromPage;
|
||||||
(**m_printData.m_macPrintInfo).prJob.iLstPage = m_printToPage ;
|
(**m_printData.m_macPrintInfo).prJob.iLstPage = m_printToPage;
|
||||||
m_printData.ConvertToNative() ;
|
m_printData.ConvertToNative();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1058,9 +1057,9 @@ void wxPrintDialogData::ConvertFromNative()
|
|||||||
{
|
{
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
m_printData.ConvertFromNative() ;
|
m_printData.ConvertFromNative();
|
||||||
m_printFromPage = (**m_printData.m_macPrintInfo).prJob.iFstPage ;
|
m_printFromPage = (**m_printData.m_macPrintInfo).prJob.iFstPage;
|
||||||
m_printToPage = (**m_printData.m_macPrintInfo).prJob.iLstPage ;
|
m_printToPage = (**m_printData.m_macPrintInfo).prJob.iLstPage;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -1296,7 +1295,7 @@ void wxPageSetupDialogData::ConvertToNative()
|
|||||||
|
|
||||||
void wxPageSetupDialogData::ConvertFromNative()
|
void wxPageSetupDialogData::ConvertFromNative()
|
||||||
{
|
{
|
||||||
PAGESETUPDLG *pd = (PAGESETUPDLG *) m_pageSetupData ;
|
PAGESETUPDLG *pd = (PAGESETUPDLG *) m_pageSetupData;
|
||||||
if ( !pd )
|
if ( !pd )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -1347,10 +1346,10 @@ void wxPageSetupDialogData::ConvertFromNative()
|
|||||||
m_minMarginBottomRight.x = pd->rtMinMargin.right / 100;
|
m_minMarginBottomRight.x = pd->rtMinMargin.right / 100;
|
||||||
m_minMarginBottomRight.y = pd->rtMinMargin.bottom / 100;
|
m_minMarginBottomRight.y = pd->rtMinMargin.bottom / 100;
|
||||||
|
|
||||||
m_marginTopLeft.x = pd->rtMargin.left / 100 ;
|
m_marginTopLeft.x = pd->rtMargin.left / 100;
|
||||||
m_marginTopLeft.y = pd->rtMargin.top / 100 ;
|
m_marginTopLeft.y = pd->rtMargin.top / 100;
|
||||||
m_marginBottomRight.x = pd->rtMargin.right / 100 ;
|
m_marginBottomRight.x = pd->rtMargin.right / 100;
|
||||||
m_marginBottomRight.y = pd->rtMargin.bottom / 100 ;
|
m_marginBottomRight.y = pd->rtMargin.bottom / 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxPageSetupDialogData::SetOwnerWindow(wxWindow* win)
|
void wxPageSetupDialogData::SetOwnerWindow(wxWindow* win)
|
||||||
@@ -1360,7 +1359,7 @@ void wxPageSetupDialogData::SetOwnerWindow(wxWindow* win)
|
|||||||
|
|
||||||
if ( m_pageSetupData != NULL && win != NULL)
|
if ( m_pageSetupData != NULL && win != NULL)
|
||||||
{
|
{
|
||||||
PAGESETUPDLG *pd = (PAGESETUPDLG *) m_pageSetupData ;
|
PAGESETUPDLG *pd = (PAGESETUPDLG *) m_pageSetupData;
|
||||||
pd->hwndOwner=(HWND) win->GetHWND();
|
pd->hwndOwner=(HWND) win->GetHWND();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1369,52 +1368,52 @@ void wxPageSetupDialogData::SetOwnerWindow(wxWindow* win)
|
|||||||
#ifdef __WXMAC__
|
#ifdef __WXMAC__
|
||||||
void wxPageSetupDialogData::ConvertToNative()
|
void wxPageSetupDialogData::ConvertToNative()
|
||||||
{
|
{
|
||||||
m_printData.ConvertToNative() ;
|
m_printData.ConvertToNative();
|
||||||
// on mac the paper rect has a negative top left corner, because the page rect (printable area) is at 0,0
|
// on mac the paper rect has a negative top left corner, because the page rect (printable area) is at 0,0
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
(**m_printData.m_macPrintInfo).rPaper.left = int( ((double) m_minMarginTopLeft.x)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).rPaper.left = int( ((double) m_minMarginTopLeft.x)*mm2pt );
|
||||||
(**m_printData.m_macPrintInfo).rPaper.top = int( ((double) m_minMarginTopLeft.y)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).rPaper.top = int( ((double) m_minMarginTopLeft.y)*mm2pt );
|
||||||
|
|
||||||
(**m_printData.m_macPrintInfo).rPaper.right = int( ((double) m_paperSize.x - m_minMarginTopLeft.x)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).rPaper.right = int( ((double) m_paperSize.x - m_minMarginTopLeft.x)*mm2pt );
|
||||||
(**m_printData.m_macPrintInfo).rPaper.bottom = int( ((double) m_paperSize.y - m_minMarginTopLeft.y)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).rPaper.bottom = int( ((double) m_paperSize.y - m_minMarginTopLeft.y)*mm2pt );
|
||||||
|
|
||||||
(**m_printData.m_macPrintInfo).prInfo.rPage.left = 0 ;
|
(**m_printData.m_macPrintInfo).prInfo.rPage.left = 0;
|
||||||
(**m_printData.m_macPrintInfo).prInfo.rPage.top = 0 ;
|
(**m_printData.m_macPrintInfo).prInfo.rPage.top = 0;
|
||||||
(**m_printData.m_macPrintInfo).prInfo.rPage.right = int( ((double) m_paperSize.x - m_minMarginTopLeft.x - m_minMarginBottomRight.x)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).prInfo.rPage.right = int( ((double) m_paperSize.x - m_minMarginTopLeft.x - m_minMarginBottomRight.x)*mm2pt );
|
||||||
(**m_printData.m_macPrintInfo).prInfo.rPage.bottom = int( ((double) m_paperSize.y - m_minMarginTopLeft.y - m_minMarginBottomRight.y)*mm2pt ) ;
|
(**m_printData.m_macPrintInfo).prInfo.rPage.bottom = int( ((double) m_paperSize.y - m_minMarginTopLeft.y - m_minMarginBottomRight.y)*mm2pt );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxPageSetupDialogData::ConvertFromNative()
|
void wxPageSetupDialogData::ConvertFromNative()
|
||||||
{
|
{
|
||||||
m_printData.ConvertFromNative () ;
|
m_printData.ConvertFromNative ();
|
||||||
|
|
||||||
#ifdef TARGET_CARBON
|
#ifdef TARGET_CARBON
|
||||||
#else
|
#else
|
||||||
m_paperSize.x = ((double) (**m_printData.m_macPrintInfo).rPaper.right - (**m_printData.m_macPrintInfo).rPaper.left ) * pt2mm ;
|
m_paperSize.x = ((double) (**m_printData.m_macPrintInfo).rPaper.right - (**m_printData.m_macPrintInfo).rPaper.left ) * pt2mm;
|
||||||
m_paperSize.y = ((double) (**m_printData.m_macPrintInfo).rPaper.bottom - (**m_printData.m_macPrintInfo).rPaper.top ) * pt2mm ;
|
m_paperSize.y = ((double) (**m_printData.m_macPrintInfo).rPaper.bottom - (**m_printData.m_macPrintInfo).rPaper.top ) * pt2mm;
|
||||||
|
|
||||||
m_minMarginTopLeft.x = ((double) -(**m_printData.m_macPrintInfo).rPaper.left ) * pt2mm ;
|
m_minMarginTopLeft.x = ((double) -(**m_printData.m_macPrintInfo).rPaper.left ) * pt2mm;
|
||||||
m_minMarginTopLeft.y = ((double) -(**m_printData.m_macPrintInfo).rPaper.top ) * pt2mm ;
|
m_minMarginTopLeft.y = ((double) -(**m_printData.m_macPrintInfo).rPaper.top ) * pt2mm;
|
||||||
|
|
||||||
m_minMarginBottomRight.x = ((double) (**m_printData.m_macPrintInfo).rPaper.right - (**m_printData.m_macPrintInfo).prInfo.rPage.right ) * pt2mm ;
|
m_minMarginBottomRight.x = ((double) (**m_printData.m_macPrintInfo).rPaper.right - (**m_printData.m_macPrintInfo).prInfo.rPage.right ) * pt2mm;
|
||||||
m_minMarginBottomRight.y = ((double)(**m_printData.m_macPrintInfo).rPaper.bottom - (**m_printData.m_macPrintInfo).prInfo.rPage.bottom ) * pt2mm ;
|
m_minMarginBottomRight.y = ((double)(**m_printData.m_macPrintInfo).rPaper.bottom - (**m_printData.m_macPrintInfo).prInfo.rPage.bottom ) * pt2mm;
|
||||||
#endif
|
#endif
|
||||||
// adjust minimal values
|
// adjust minimal values
|
||||||
//TODO add custom fields in dialog for margins
|
//TODO add custom fields in dialog for margins
|
||||||
|
|
||||||
if ( m_marginTopLeft.x < m_minMarginTopLeft.x )
|
if ( m_marginTopLeft.x < m_minMarginTopLeft.x )
|
||||||
m_marginTopLeft.x = m_minMarginTopLeft.x ;
|
m_marginTopLeft.x = m_minMarginTopLeft.x;
|
||||||
|
|
||||||
if ( m_marginBottomRight.x < m_minMarginBottomRight.x )
|
if ( m_marginBottomRight.x < m_minMarginBottomRight.x )
|
||||||
m_marginBottomRight.x = m_minMarginBottomRight.x ;
|
m_marginBottomRight.x = m_minMarginBottomRight.x;
|
||||||
|
|
||||||
if ( m_marginTopLeft.y < m_minMarginTopLeft.y )
|
if ( m_marginTopLeft.y < m_minMarginTopLeft.y )
|
||||||
m_marginTopLeft.y = m_minMarginTopLeft.y ;
|
m_marginTopLeft.y = m_minMarginTopLeft.y;
|
||||||
|
|
||||||
if ( m_marginBottomRight.y < m_minMarginBottomRight.y )
|
if ( m_marginBottomRight.y < m_minMarginBottomRight.y )
|
||||||
m_marginBottomRight.y = m_minMarginBottomRight.y ;
|
m_marginBottomRight.y = m_minMarginBottomRight.y;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -78,6 +78,7 @@
|
|||||||
#endif // native Win compiler
|
#endif // native Win compiler
|
||||||
|
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
|
#include <wchar.h>
|
||||||
#ifndef __TWIN32__
|
#ifndef __TWIN32__
|
||||||
#include <sys/unistd.h>
|
#include <sys/unistd.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -1113,7 +1114,10 @@ wxRenameFile (const wxString& file1, const wxString& file2)
|
|||||||
|
|
||||||
bool wxRemoveFile(const wxString& file)
|
bool wxRemoveFile(const wxString& file)
|
||||||
{
|
{
|
||||||
#if defined(__VISUALC__) || defined(__BORLANDC__) || defined(__WATCOMC__)
|
#if defined(__VISUALC__) \
|
||||||
|
|| defined(__BORLANDC__) \
|
||||||
|
|| defined(__WATCOMC__) \
|
||||||
|
|| defined(__GNUWIN32__)
|
||||||
int res = wxRemove(file);
|
int res = wxRemove(file);
|
||||||
#else
|
#else
|
||||||
int res = unlink(OS_FILENAME(file));
|
int res = unlink(OS_FILENAME(file));
|
||||||
|
@@ -115,7 +115,7 @@ wxWindow *wxPrinterBase::CreateAbortWindow(wxWindow *parent, wxPrintout *WXUNUSE
|
|||||||
return dialog;
|
return dialog;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxPrinterBase::ReportError(wxWindow *parent, wxPrintout *WXUNUSED(printout), char *message)
|
void wxPrinterBase::ReportError(wxWindow *parent, wxPrintout *WXUNUSED(printout), const wxString& message)
|
||||||
{
|
{
|
||||||
wxMessageBox(message, _("Printing Error"), wxOK, parent);
|
wxMessageBox(message, _("Printing Error"), wxOK, parent);
|
||||||
}
|
}
|
||||||
|
@@ -265,7 +265,7 @@ bool wxGridCellEnumEditor::EndEdit(int row, int col, wxGrid* grid)
|
|||||||
if (grid->GetTable()->CanSetValueAs(row, col, wxGRID_VALUE_NUMBER))
|
if (grid->GetTable()->CanSetValueAs(row, col, wxGRID_VALUE_NUMBER))
|
||||||
grid->GetTable()->SetValueAsLong(row, col, pos);
|
grid->GetTable()->SetValueAsLong(row, col, pos);
|
||||||
else
|
else
|
||||||
grid->GetTable()->SetValue(row, col,wxString::Format("%i",pos));
|
grid->GetTable()->SetValue(row, col,wxString::Format(wxT("%i"),pos));
|
||||||
}
|
}
|
||||||
|
|
||||||
return changed;
|
return changed;
|
||||||
|
@@ -215,7 +215,7 @@ bool wxHtmlTag::HasParam(const wxString& par) const
|
|||||||
{
|
{
|
||||||
const wxChar *st = m_Params, *p = par;
|
const wxChar *st = m_Params, *p = par;
|
||||||
const wxChar *st2, *p2;
|
const wxChar *st2, *p2;
|
||||||
const wxChar invalid = wxT(1);
|
const wxChar invalid = wxT('\1');
|
||||||
|
|
||||||
if (*st == 0) return FALSE;
|
if (*st == 0) return FALSE;
|
||||||
if (*p == 0) return FALSE;
|
if (*p == 0) return FALSE;
|
||||||
@@ -249,7 +249,7 @@ wxString wxHtmlTag::GetParam(const wxString& par, bool with_commas) const
|
|||||||
{
|
{
|
||||||
const wxChar *st = m_Params, *p = par;
|
const wxChar *st = m_Params, *p = par;
|
||||||
const wxChar *st2, *p2;
|
const wxChar *st2, *p2;
|
||||||
const wxChar invalid = wxT(1);
|
const wxChar invalid = wxT('\1');
|
||||||
bool comma;
|
bool comma;
|
||||||
wxChar comma_char;
|
wxChar comma_char;
|
||||||
|
|
||||||
@@ -315,7 +315,7 @@ wxString wxHtmlTag::GetParam(const wxString& par, bool with_commas) const
|
|||||||
int wxHtmlTag::ScanParam(const wxString& par, wxChar *format, void *param) const
|
int wxHtmlTag::ScanParam(const wxString& par, wxChar *format, void *param) const
|
||||||
{
|
{
|
||||||
wxString parval = GetParam(par);
|
wxString parval = GetParam(par);
|
||||||
return wxSscanf((const wxChar*)parval, format, param);
|
return wxSscanf(parval, format, param);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -224,16 +224,18 @@ static bool wxGetDefaultDeviceName(wxString& deviceName, wxString& portName)
|
|||||||
deviceName.clear();
|
deviceName.clear();
|
||||||
|
|
||||||
LPDEVNAMES lpDevNames;
|
LPDEVNAMES lpDevNames;
|
||||||
LPSTR lpszDriverName;
|
LPTSTR lpszDriverName;
|
||||||
LPSTR lpszDeviceName;
|
LPTSTR lpszDeviceName;
|
||||||
LPSTR lpszPortName;
|
LPTSTR lpszPortName;
|
||||||
|
|
||||||
PRINTDLG pd;
|
PRINTDLG pd;
|
||||||
|
|
||||||
// Cygwin has trouble believing PRINTDLG is 66 bytes - thinks it is 68
|
// Cygwin has trouble believing PRINTDLG is 66 bytes - thinks it is 68
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
|
memset(&pd, 0, 66);
|
||||||
pd.lStructSize = 66; // sizeof(PRINTDLG);
|
pd.lStructSize = 66; // sizeof(PRINTDLG);
|
||||||
#else
|
#else
|
||||||
|
memset(&pd, 0, sizeof(PRINTDLG));
|
||||||
pd.lStructSize = sizeof(PRINTDLG);
|
pd.lStructSize = sizeof(PRINTDLG);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -256,9 +258,9 @@ static bool wxGetDefaultDeviceName(wxString& deviceName, wxString& portName)
|
|||||||
if (pd.hDevNames)
|
if (pd.hDevNames)
|
||||||
{
|
{
|
||||||
lpDevNames = (LPDEVNAMES)GlobalLock(pd.hDevNames);
|
lpDevNames = (LPDEVNAMES)GlobalLock(pd.hDevNames);
|
||||||
lpszDriverName = (LPSTR)lpDevNames + lpDevNames->wDriverOffset;
|
lpszDriverName = (LPTSTR)lpDevNames + lpDevNames->wDriverOffset;
|
||||||
lpszDeviceName = (LPSTR)lpDevNames + lpDevNames->wDeviceOffset;
|
lpszDeviceName = (LPTSTR)lpDevNames + lpDevNames->wDeviceOffset;
|
||||||
lpszPortName = (LPSTR)lpDevNames + lpDevNames->wOutputOffset;
|
lpszPortName = (LPTSTR)lpDevNames + lpDevNames->wOutputOffset;
|
||||||
|
|
||||||
deviceName = lpszDeviceName;
|
deviceName = lpszDeviceName;
|
||||||
portName = lpszPortName;
|
portName = lpszPortName;
|
||||||
|
@@ -135,7 +135,7 @@ bool wxFontEnumeratorHelper::SetEncoding(wxFontEncoding encoding)
|
|||||||
|
|
||||||
#if defined(__GNUWIN32__)
|
#if defined(__GNUWIN32__)
|
||||||
#if wxUSE_NORLANDER_HEADERS
|
#if wxUSE_NORLANDER_HEADERS
|
||||||
#define wxFONTENUMPROC int(*)(const LOGFONTA *, const TEXTMETRICA *, long unsigned int, LPARAM)
|
#define wxFONTENUMPROC int(*)(const LOGFONT *, const TEXTMETRIC *, long unsigned int, LPARAM)
|
||||||
#else
|
#else
|
||||||
#define wxFONTENUMPROC int(*)(ENUMLOGFONTEX *, NEWTEXTMETRICEX*, int, LPARAM)
|
#define wxFONTENUMPROC int(*)(ENUMLOGFONTEX *, NEWTEXTMETRICEX*, int, LPARAM)
|
||||||
#endif
|
#endif
|
||||||
|
@@ -222,7 +222,7 @@ wxDragResult wxDropSource::DoDragDrop(bool bAllowMove)
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if ( FAILED(hr) ) {
|
if ( FAILED(hr) ) {
|
||||||
wxLogApiError("DoDragDrop", hr);
|
wxLogApiError(wxT("DoDragDrop"), hr);
|
||||||
wxLogError(wxT("Drag & drop operation failed."));
|
wxLogError(wxT("Drag & drop operation failed."));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@@ -305,7 +305,7 @@ bool wxDropTarget::Register(WXHWND hwnd)
|
|||||||
{
|
{
|
||||||
HRESULT hr = ::CoLockObjectExternal(m_pIDropTarget, TRUE, FALSE);
|
HRESULT hr = ::CoLockObjectExternal(m_pIDropTarget, TRUE, FALSE);
|
||||||
if ( FAILED(hr) ) {
|
if ( FAILED(hr) ) {
|
||||||
wxLogApiError("CoLockObjectExternal", hr);
|
wxLogApiError(wxT("CoLockObjectExternal"), hr);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -313,7 +313,7 @@ bool wxDropTarget::Register(WXHWND hwnd)
|
|||||||
if ( FAILED(hr) ) {
|
if ( FAILED(hr) ) {
|
||||||
::CoLockObjectExternal(m_pIDropTarget, FALSE, FALSE);
|
::CoLockObjectExternal(m_pIDropTarget, FALSE, FALSE);
|
||||||
|
|
||||||
wxLogApiError("RegisterDragDrop", hr);
|
wxLogApiError(wxT("RegisterDragDrop"), hr);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -328,7 +328,7 @@ void wxDropTarget::Revoke(WXHWND hwnd)
|
|||||||
HRESULT hr = ::RevokeDragDrop((HWND) hwnd);
|
HRESULT hr = ::RevokeDragDrop((HWND) hwnd);
|
||||||
|
|
||||||
if ( FAILED(hr) ) {
|
if ( FAILED(hr) ) {
|
||||||
wxLogApiError("RevokeDragDrop", hr);
|
wxLogApiError(wxT("RevokeDragDrop"), hr);
|
||||||
}
|
}
|
||||||
|
|
||||||
::CoLockObjectExternal(m_pIDropTarget, FALSE, TRUE);
|
::CoLockObjectExternal(m_pIDropTarget, FALSE, TRUE);
|
||||||
|
Reference in New Issue
Block a user