extern WXDLLIMPEXP_DATA_BASE(HINSTANCE) wxhInstance;
+extern "C"
+{
+ WXDLLIMPEXP_BASE HINSTANCE wxGetInstance();
+}
+
+WXDLLIMPEXP_BASE void wxSetInstance(HINSTANCE hInst);
+
// ---------------------------------------------------------------------------
// define things missing from some compilers' headers
// ---------------------------------------------------------------------------
void DoInit(HGDIOBJ hgdiobj) { m_hgdiobj = ::SelectObject(m_hdc, hgdiobj); }
public:
- SelectInHDC() : m_hdc(NULL) { }
+ SelectInHDC() : m_hdc(NULL), m_hgdiobj(NULL) { }
SelectInHDC(HDC hdc, HGDIOBJ hgdiobj) : m_hdc(hdc) { DoInit(hgdiobj); }
void Init(HDC hdc, HGDIOBJ hgdiobj)
class AutoHBITMAP : private AutoGDIObject
{
public:
+ AutoHBITMAP()
+ : AutoGDIObject() { }
+
AutoHBITMAP(HBITMAP hbmp) : AutoGDIObject(hbmp) { }
+ void Init(HBITMAP hbmp) { InitGdiobj(hbmp); }
+
operator HBITMAP() const { return (HBITMAP)GetObject(); }
};
wxDECLARE_NO_COPY_CLASS(GlobalPtrLock);
};
-// smart pointer like class using OpenPrinter and ClosePrinter
-class WinPrinter
-{
-public:
- // default ctor
- WinPrinter()
- {
- m_hPrinter = (HANDLE)NULL;
- }
-
- WinPrinter( const wxString& printerName )
- {
- Open( printerName );
- }
-
- ~WinPrinter()
- {
- Close();
- }
-
- BOOL Open( const wxString& printerName, LPPRINTER_DEFAULTS pDefault=(LPPRINTER_DEFAULTS)NULL )
- {
- Close();
- return OpenPrinter( (LPTSTR)printerName.wx_str(), &m_hPrinter, pDefault );
- }
-
- BOOL Close()
- {
- BOOL result = TRUE;
- if( m_hPrinter )
- {
- result = ClosePrinter( m_hPrinter );
- m_hPrinter = (HANDLE)NULL;
- }
- return result;
- }
-
- operator HANDLE() { return m_hPrinter; }
- operator bool() { return m_hPrinter != (HANDLE)NULL; }
-
-private:
- HANDLE m_hPrinter;
-
- wxDECLARE_NO_COPY_CLASS(WinPrinter);
-};
-
// register the class when it is first needed and unregister it in dtor
class ClassRegistrar
{
{
if ( IsRegistered() )
{
- if ( !::UnregisterClass(m_clsname.wx_str(), wxhInstance) )
+ if ( !::UnregisterClass(m_clsname.wx_str(), wxGetInstance()) )
{
wxLogLastError(wxT("UnregisterClass"));
}
// global functions
// ---------------------------------------------------------------------------
-extern "C"
-{
- WXDLLIMPEXP_BASE HINSTANCE wxGetInstance();
-}
-
-WXDLLIMPEXP_BASE void wxSetInstance(HINSTANCE hInst);
-
// return the full path of the given module
inline wxString wxGetFullModuleName(HMODULE hmod)
{
// 0x0400 Windows 95, NT4
// 0x0410 Windows 98
// 0x0500 Windows ME, 2000
-// 0x0501 Windows XP
-// 0x0502 Windows 2003
-// 0x0600 Longhorn
+// 0x0501 Windows XP, 2003
+// 0x0502 Windows XP SP2, 2003 SP1
+// 0x0600 Windows Vista, 2008
+// 0x0601 Windows 7
//
// for the other Windows versions 0 is currently returned
enum wxWinVersion
wxWinVersion_NT5 = wxWinVersion_5,
wxWinVersion_2000 = wxWinVersion_5,
wxWinVersion_XP = 0x0501,
- wxWinVersion_2003 = 0x0502,
+ wxWinVersion_2003 = 0x0501,
+ wxWinVersion_XP_SP2 = 0x0502,
+ wxWinVersion_2003_SP1 = 0x0502,
wxWinVersion_6 = 0x0600,
wxWinVersion_Vista = wxWinVersion_6,
- wxWinVersion_NT6 = wxWinVersion_6
+ wxWinVersion_NT6 = wxWinVersion_6,
+
+ wxWinVersion_7 = 0x601
};
WXDLLIMPEXP_BASE wxWinVersion wxGetWinVersion();
extern HCURSOR wxGetCurrentBusyCursor(); // from msw/utils.cpp
extern const wxCursor *wxGetGlobalCursor(); // from msw/cursor.cpp
+// GetCursorPos can fail without populating the POINT. This falls back to GetMessagePos.
+WXDLLIMPEXP_CORE void wxGetCursorPosMSW(POINT* pt);
+
WXDLLIMPEXP_CORE void wxGetCharSize(WXHWND wnd, int *x, int *y, const wxFont& the_font);
WXDLLIMPEXP_CORE void wxFillLogFont(LOGFONT *logFont, const wxFont *font);
WXDLLIMPEXP_CORE wxFont wxCreateFontFromLogFont(const LOGFONT *logFont);
// and returns either that window if it does or NULL otherwise
extern WXDLLIMPEXP_CORE wxWindow* wxFindWinFromHandle(HWND hwnd);
-// without STRICT WXHWND is the same as HWND anyhow
-inline wxWindow* wxFindWinFromHandle(WXHWND hWnd)
-{
- return wxFindWinFromHandle(static_cast<HWND>(hWnd));
-}
-
// find the window for HWND which is part of some wxWindow, i.e. unlike
// wxFindWinFromHandle() above it will also work for "sub controls" of a
// wxWindow.