// wxWindowsPrintNativeData
//----------------------------------------------------------------------------
-#ifdef __WXDEBUG__
+#if wxDEBUG_LEVEL
+
static wxString wxGetPrintDlgError()
{
DWORD err = CommDlgExtendedError();
}
return msg;
}
-#endif // __WXDEBUG__
+
+#endif // wxDEBUG_LEVEL
+
static HGLOBAL
wxCreateDevNames(const wxString& driverName,
pd.hDevMode = NULL;
pd.hDevNames = NULL;
-#ifdef __WXDEBUG__
- wxString str(wxT("Printing error: "));
- str += wxGetPrintDlgError();
- wxLogDebug(str);
-#endif // __WXDEBUG__
+#if wxDEBUG_LEVEL
+ wxLogDebug(wxT("Printing error: ") + wxGetPrintDlgError());
+#endif // wxDEBUG_LEVEL
}
else
{
{
// NB: the cast is needed in the ANSI build, strangely enough
// dmDeviceName is BYTE[] and not char[] there
- wxStrncpy(reinterpret_cast<wxChar *>(devMode->dmDeviceName),
+ wxStrlcpy(reinterpret_cast<wxChar *>(devMode->dmDeviceName),
name.wx_str(),
- WXSIZEOF(devMode->dmDeviceName) - 1);
- devMode->dmDeviceName[WXSIZEOF(devMode->dmDeviceName) - 1] = wxT('\0');
+ WXSIZEOF(devMode->dmDeviceName));
}
//// Colour
devMode->dmPaperLength = (short)(paperSize.y * 10);
devMode->dmFields |= DM_PAPERWIDTH;
devMode->dmFields |= DM_PAPERLENGTH;
+
+ // A printer driver may or may not also want DM_PAPERSIZE to
+ // be specified. Also, if the printer driver doesn't implement the DMPAPER_USER
+ // size, then this won't work, and even if you found the correct id by
+ // enumerating the driver's paper sizes, it probably won't change the actual size,
+ // it'll just select that custom paper type with its own current setting.
+ // For a discussion on this, see http://www.codeguru.com/forum/showthread.php?threadid=458617
+ // Although m_customWindowsPaperId is intended to work around this, it's
+ // unclear how it can help you set the custom paper size programmatically.
}
//else: neither paper type nor size specified, don't fill DEVMODE
// at all so that the system defaults are used