X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/39bc0347fda3505f7fb43447f21efd84b9e00b3c..0a12e013f55022e684508316ad0079511e3b4fe7:/include/wx/stattext.h diff --git a/include/wx/stattext.h b/include/wx/stattext.h index 8795777ea8..2a6c054b0e 100644 --- a/include/wx/stattext.h +++ b/include/wx/stattext.h @@ -23,15 +23,13 @@ */ #define wxST_NO_AUTORESIZE 0x0001 #define wxST_MARKUP 0x0002 - #define wxST_ELLIPSIZE_START 0x0004 #define wxST_ELLIPSIZE_MIDDLE 0x0008 #define wxST_ELLIPSIZE_END 0x0010 +extern WXDLLIMPEXP_DATA_CORE(const char) wxStaticTextNameStr[]; -extern WXDLLEXPORT_DATA(const wxChar) wxStaticTextNameStr[]; - -class WXDLLEXPORT wxStaticTextBase : public wxControl +class WXDLLIMPEXP_CORE wxStaticTextBase : public wxControl { public: wxStaticTextBase() { } @@ -53,23 +51,43 @@ public: } // get the string without mnemonic characters ('&') and without markup - // (if wxST_MARKUP is being used) + // (if the wxST_MARKUP style is set) virtual wxString GetLabelText() const; - // public utilities (symmetric to those in wxControl about mnemonics): + // set label text (mnemonics and markup, if the wxST_MARKUP style is set, + // will be escaped) + virtual void SetLabelText(const wxString& text); + + + // static utilities for markup handling + // (symmetric to those in wxControl about mnemonics) + // ------------------------------------------------- + + // get the string without mnemonic characters ('&') and without markup + // (note that markup is always removed; this function is static and cannot + // check for wxST_MARKUP style presence/absence!) + static wxString GetLabelText(const wxString& label); - // removes the markup accepted by wxStaticText when wxST_MARKUP is used, - // and then returns the cleaned string + // removes the markup recognized by wxStaticText and returns the cleaned string static wxString RemoveMarkup(const wxString& str); - // escapes the alls special symbols (<>"'&) present inside the given string + // escapes all special symbols (<>"'&) present in the given string // using the corresponding entities (< > " ' &) static wxString EscapeMarkup(const wxString& str); - protected: // functions required for wxST_ELLIPSIZE_* support - // just calls RemoveMarkup & Ellipsize on the original label. + // choose the default border for this window + virtual wxBorder GetDefaultBorder() const { return wxBORDER_NONE; } + + // calls only RemoveMarkup() on the original label + // if the wxST_MARKUP style is set + // (but unlike GetLabelText won't remove mnemonics) + virtual wxString GetLabelWithoutMarkup() const; + + // just calls RemoveMarkup() & Ellipsize() on the original label + // if the wxST_MARKUP & wxST_ELLIPSIZE_* styles are set + // (but unlike GetLabelText won't remove mnemonics) virtual wxString GetEllipsizedLabelWithoutMarkup() const; // replaces parts of the string with ellipsis if needed @@ -81,19 +99,23 @@ protected: // functions required for wxST_ELLIPSIZE_* support // These functions are platform-specific and must be overridden in ports // which do not natively support ellipsization and they must be implemented - // in a way so that the m_label member of wxControl is not touched: + // in a way so that the m_labelOrig member of wxControl is not touched: // returns the real label currently displayed inside the control. virtual wxString DoGetLabel() const { return wxEmptyString; } // sets the real label currently displayed inside the control, - // _without_ invalidating the size. The text passed is always markup-free. + // _without_ invalidating the size. The text passed is always markup-free + // but may contain the mnemonic characters. virtual void DoSetLabel(const wxString& WXUNUSED(str)) { } private: - DECLARE_NO_COPY_CLASS(wxStaticTextBase) + wxDECLARE_NO_COPY_CLASS(wxStaticTextBase); }; +// see wx/generic/stattextg.h for the explanation +#ifndef wxNO_PORT_STATTEXT_INCLUDE + #if defined(__WXUNIVERSAL__) #include "wx/univ/stattext.h" #elif defined(__WXMSW__) @@ -105,7 +127,7 @@ private: #elif defined(__WXGTK__) #include "wx/gtk1/stattext.h" #elif defined(__WXMAC__) - #include "wx/mac/stattext.h" + #include "wx/osx/stattext.h" #elif defined(__WXCOCOA__) #include "wx/cocoa/stattext.h" #elif defined(__WXPM__) @@ -114,7 +136,8 @@ private: #include "wx/palmos/stattext.h" #endif +#endif // !wxNO_PORT_STATTEXT_INCLUDE + #endif // wxUSE_STATTEXT -#endif - // _WX_STATTEXT_H_BASE_ +#endif // _WX_STATTEXT_H_BASE_