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:
Vadim Zeitlin
2001-06-03 02:58:56 +00:00
parent 2ec6905c69
commit 161f4f7380
13 changed files with 163 additions and 147 deletions

View File

@@ -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

View File

@@ -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; }

View File

@@ -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

View File

@@ -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;

View File

@@ -180,18 +180,18 @@ 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
#endif #endif
#endif #endif
m_printOrientation = wxPORTRAIT; m_printOrientation = wxPORTRAIT;
@@ -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;
@@ -248,8 +248,8 @@ wxPrintData::~wxPrintData()
#if TARGET_CARBON #if TARGET_CARBON
if (m_macPageFormat != kPMNoPageFormat) if (m_macPageFormat != kPMNoPageFormat)
{ {
(void)PMDisposePageFormat(m_macPageFormat); (void)PMDisposePageFormat(m_macPageFormat);
m_macPageFormat = kPMNoPageFormat; m_macPageFormat = kPMNoPageFormat;
} }
if (m_macPrintSettings != kPMNoPrintSettings) if (m_macPrintSettings != kPMNoPrintSettings)
@@ -258,8 +258,8 @@ 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
} }
@@ -303,32 +303,35 @@ static wxString wxGetPrintDlgError()
static HGLOBAL wxCreateDevNames(const wxString& driverName, const wxString& printerName, const wxString& portName) static HGLOBAL wxCreateDevNames(const wxString& driverName, const wxString& printerName, const wxString& portName)
{ {
HGLOBAL hDev = NULL; HGLOBAL hDev = NULL;
// if (!driverName.IsEmpty() && !printerName.IsEmpty() && !portName.IsEmpty()) // if (!driverName.IsEmpty() && !printerName.IsEmpty() && !portName.IsEmpty())
if (driverName.IsEmpty() && printerName.IsEmpty() && portName.IsEmpty()) if (driverName.IsEmpty() && printerName.IsEmpty() && portName.IsEmpty())
{ {
} }
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;
} }
void wxPrintData::ConvertToNative() void wxPrintData::ConvertToNative()
@@ -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
@@ -443,7 +441,7 @@ void wxPrintData::ConvertToNative()
if (m_paperId == wxPAPER_NONE) if (m_paperId == wxPAPER_NONE)
{ {
// DEVMODE is in tenths of a milimeter // DEVMODE is in tenths of a milimeter
devMode->dmPaperWidth = m_paperSize.x * 10; devMode->dmPaperWidth = m_paperSize.x * 10;
devMode->dmPaperLength = m_paperSize.y * 10; devMode->dmPaperLength = m_paperSize.y * 10;
devMode->dmPaperSize = DMPAPER_USER; devMode->dmPaperSize = DMPAPER_USER;
@@ -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
{ {
@@ -626,7 +624,7 @@ void wxPrintData::ConvertFromNative()
} }
else if ((devMode->dmFields & DM_PAPERWIDTH) && (devMode->dmFields & DM_PAPERLENGTH)) else if ((devMode->dmFields & DM_PAPERWIDTH) && (devMode->dmFields & DM_PAPERLENGTH))
{ {
// DEVMODE is in tenths of a milimeter // DEVMODE is in tenths of a milimeter
m_paperSize.x = devMode->dmPaperWidth / 10; m_paperSize.x = devMode->dmPaperWidth / 10;
m_paperSize.y = devMode->dmPaperLength / 10; m_paperSize.y = devMode->dmPaperLength / 10;
m_paperId = wxPAPER_NONE; m_paperId = wxPAPER_NONE;
@@ -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
@@ -1261,7 +1260,7 @@ void wxPageSetupDialogData::ConvertToNative()
pd->hwndOwner=(HWND)NULL; pd->hwndOwner=(HWND)NULL;
// pd->hDevNames=(HWND)NULL; // pd->hDevNames=(HWND)NULL;
pd->hInstance=(HINSTANCE)NULL; pd->hInstance=(HINSTANCE)NULL;
// PAGESETUPDLG is in hundreds of a mm // PAGESETUPDLG is in hundreds of a mm
pd->ptPaperSize.x = m_paperSize.x * 100; pd->ptPaperSize.x = m_paperSize.x * 100;
pd->ptPaperSize.y = m_paperSize.y * 100; pd->ptPaperSize.y = m_paperSize.y * 100;
@@ -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;
@@ -1338,7 +1337,7 @@ void wxPageSetupDialogData::ConvertFromNative()
m_getDefaultInfo = ((pd->Flags & PSD_RETURNDEFAULT) == PSD_RETURNDEFAULT); m_getDefaultInfo = ((pd->Flags & PSD_RETURNDEFAULT) == PSD_RETURNDEFAULT);
m_enableHelp = ((pd->Flags & PSD_SHOWHELP) == PSD_SHOWHELP); m_enableHelp = ((pd->Flags & PSD_SHOWHELP) == PSD_SHOWHELP);
// PAGESETUPDLG is in hundreds of a mm // PAGESETUPDLG is in hundreds of a mm
m_paperSize.x = pd->ptPaperSize.x / 100; m_paperSize.x = pd->ptPaperSize.x / 100;
m_paperSize.y = pd->ptPaperSize.y / 100; m_paperSize.y = pd->ptPaperSize.y / 100;
@@ -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.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_minMarginTopLeft.x = ((double) -(**m_printData.m_macPrintInfo).rPaper.left ) * pt2mm;
m_minMarginBottomRight.y = ((double)(**m_printData.m_macPrintInfo).rPaper.bottom - (**m_printData.m_macPrintInfo).prInfo.rPage.bottom ) * 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.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 )
m_marginBottomRight.x = m_minMarginBottomRight.x ;
if ( m_marginTopLeft.y < m_minMarginTopLeft.y ) if ( m_marginBottomRight.x < m_minMarginBottomRight.x )
m_marginTopLeft.y = m_minMarginTopLeft.y ; m_marginBottomRight.x = m_minMarginBottomRight.x;
if ( m_marginBottomRight.y < m_minMarginBottomRight.y ) if ( m_marginTopLeft.y < m_minMarginTopLeft.y )
m_marginBottomRight.y = m_minMarginBottomRight.y ; m_marginTopLeft.y = m_minMarginTopLeft.y;
if ( m_marginBottomRight.y < m_minMarginBottomRight.y )
m_marginBottomRight.y = m_minMarginBottomRight.y;
} }
#endif #endif

View File

@@ -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));

View 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);
} }

View File

@@ -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;

View File

@@ -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

View File

@@ -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;

View File

@@ -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

View File

@@ -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 {

View File

@@ -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);