X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e9576ca53db96b462ed4c0b4bdf47d64c40203e4..9d5507f7a2701395e1d5c121bd877bb9066ee6ea:/src/mac/carbon/gdiobj.cpp diff --git a/src/mac/carbon/gdiobj.cpp b/src/mac/carbon/gdiobj.cpp index 63697c8354..76156134e0 100644 --- a/src/mac/carbon/gdiobj.cpp +++ b/src/mac/carbon/gdiobj.cpp @@ -1,22 +1,75 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: gdiobj.cpp +// Name: src/mac/carbon/gdiobj.cpp // Purpose: wxGDIObject class -// Author: AUTHOR +// Author: Stefan Csomor // Modified by: -// Created: ??/??/98 +// Created: 1998-01-01 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) Stefan Csomor +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "gdiobj.h" -#endif +#include "wx/wxprec.h" #include "wx/gdiobj.h" -#if !USE_SHARED_LIBRARIES -IMPLEMENT_DYNAMIC_CLASS(wxGDIObject, wxObject) +#ifndef WX_PRECOMP + #include "wx/gdicmn.h" + #include "wx/module.h" #endif -// TODO: Nothing to do, unless you want to. +#include "wx/link.h" +#include "wx/mac/private.h" + +// Linker will discard entire object file without this +wxFORCE_LINK_THIS_MODULE(gdiobj) + +class wxStockGDIMac: public wxStockGDI, public wxModule +{ +public: + virtual const wxFont* GetFont(Item item); + + virtual bool OnInit(); + virtual void OnExit(); + +private: + typedef wxStockGDI super; + DECLARE_DYNAMIC_CLASS(wxStockGDIMac) +}; + +IMPLEMENT_DYNAMIC_CLASS(wxStockGDIMac, wxModule) + +bool wxStockGDIMac::OnInit() +{ + // Override default instance + ms_instance = this; + return true; +} + +void wxStockGDIMac::OnExit() +{ +} + +const wxFont* wxStockGDIMac::GetFont(Item item) +{ + wxFont* font = static_cast(ms_stockObject[item]); + if (font == NULL) + { + switch (item) + { + case FONT_NORMAL: + font = new wxFont; + font->MacCreateFromThemeFont(kThemeSystemFont); + break; + case FONT_SMALL: + font = new wxFont; + font->MacCreateFromThemeFont(kThemeSmallSystemFont); + break; + default: + font = const_cast(super::GetFont(item)); + break; + } + ms_stockObject[item] = font; + } + return font; +}