X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/23e00c551b1d9b109a0f82ae2906dea0cd4718c2..058f225a44d83d42ba9d773efc705badbf0e5e3c:/include/wx/msgdlg.h diff --git a/include/wx/msgdlg.h b/include/wx/msgdlg.h index be89f2ce34..8645691499 100644 --- a/include/wx/msgdlg.h +++ b/include/wx/msgdlg.h @@ -17,12 +17,73 @@ #if wxUSE_MSGDLG #include "wx/dialog.h" +#include "wx/stockitem.h" WXDLLIMPEXP_DATA_CORE(extern const char) wxMessageBoxCaptionStr[]; +// ---------------------------------------------------------------------------- +// wxMessageDialogBase: base class defining wxMessageDialog interface +// ---------------------------------------------------------------------------- + class WXDLLIMPEXP_CORE wxMessageDialogBase : public wxDialog { public: + // helper class for SetXXXLabels() methods: it makes it possible to pass + // either a stock id (wxID_CLOSE) or a string ("&Close") to them + class ButtonLabel + { + public: + // ctors are not explicit, objects of this class can be implicitly + // constructed from either stock ids or strings + ButtonLabel(int stockId) + : m_stockId(stockId) + { + wxASSERT_MSG( wxIsStockID(stockId), "invalid stock id" ); + } + + ButtonLabel(const wxString& label) + : m_label(label), m_stockId(wxID_NONE) + { + } + + ButtonLabel(const char *label) + : m_label(label), m_stockId(wxID_NONE) + { + } + + ButtonLabel(const wchar_t *label) + : m_label(label), m_stockId(wxID_NONE) + { + } + + ButtonLabel(const wxCStrData& label) + : m_label(label), m_stockId(wxID_NONE) + { + } + + // default copy ctor and dtor are ok + + // get the string label, whether it was originally specified directly + // or as a stock id -- this is only useful for platforms without native + // stock items id support + wxString GetAsString() const + { + return m_stockId == wxID_NONE ? m_label + : wxGetStockLabel(m_stockId); + } + + // return the stock id or wxID_NONE if this is not a stock label + int GetStockId() const { return m_stockId; } + + private: + // the label if explicitly given or empty if this is a stock item + const wxString m_label; + + // the stock item id or wxID_NONE if m_label should be used + const int m_stockId; + }; + + // ctors wxMessageDialogBase() { m_dialogStyle = 0; } wxMessageDialogBase(wxWindow *parent, @@ -42,26 +103,26 @@ public: // methods for setting up more custom message dialogs -- all functions // return false if they're not implemented - virtual bool SetYesNoLabels(const wxString& WXUNUSED(yes), - const wxString& WXUNUSED(no)) + virtual bool SetYesNoLabels(const ButtonLabel& WXUNUSED(yes), + const ButtonLabel& WXUNUSED(no)) { return false; } - virtual bool SetYesNoCancelLabels(const wxString& WXUNUSED(yes), - const wxString& WXUNUSED(no), - const wxString& WXUNUSED(cancel)) + virtual bool SetYesNoCancelLabels(const ButtonLabel& WXUNUSED(yes), + const ButtonLabel& WXUNUSED(no), + const ButtonLabel& WXUNUSED(cancel)) { return false; } - virtual bool SetOKLabel(const wxString& WXUNUSED(ok)) + virtual bool SetOKLabel(const ButtonLabel& WXUNUSED(ok)) { return false; } - virtual bool SetOKCancelLabels(const wxString& WXUNUSED(ok), - const wxString& WXUNUSED(cancel)) + virtual bool SetOKCancelLabels(const ButtonLabel& WXUNUSED(ok), + const ButtonLabel& WXUNUSED(cancel)) { return false; } @@ -76,19 +137,36 @@ public: m_extendedMessage = extendedMessage; } -protected: - // common validation of wxMessageDialog style + // change the dialog style flag void SetMessageDialogStyle(long style) { - wxASSERT_MSG( ((style & wxYES_NO) == wxYES_NO) || ((style & wxYES_NO) == 0), - _T("wxYES and wxNO may only be used together in wxMessageDialog") ); +#ifdef __WXDEBUG__ + wxASSERT_MSG( ((style & wxYES_NO) == wxYES_NO) || !(style & wxYES_NO), + "wxYES and wxNO may only be used together" ); + + wxASSERT_MSG( !(style & wxYES) || !(style & wxOK), + "wxOK and wxYES/wxNO can't be used together" ); + + wxASSERT_MSG( (style & wxYES) || (style & wxOK), + "one of wxOK and wxYES/wxNO must be used" ); wxASSERT_MSG( (style & wxID_OK) != wxID_OK, - _T("wxMessageBox: Did you mean wxOK (and not wxID_OK)?") ); + "wxMessageBox: Did you mean wxOK (and not wxID_OK)?" ); + + if ((style & wxNO_DEFAULT) != 0 && (style & wxNO) == 0) + wxFAIL_MSG("wxNO_DEFAULT is invalid without wxNO"); + + if ((style & wxCANCEL_DEFAULT) != 0 && (style & wxCANCEL) == 0) + wxFAIL_MSG("wxCANCEL_DEFAULT is invalid without wxCANCEL"); + + if ((style & wxCANCEL_DEFAULT) != 0 && (style & wxNO_DEFAULT) != 0) + wxFAIL_MSG("only one default button can be specified"); +#endif m_dialogStyle = style; } +protected: long GetMessageDialogStyle() const { return m_dialogStyle; } @@ -117,7 +195,10 @@ protected: // functions for setting these labels immediately and we also don't need to // store them at all if custom labels are not supported, which is why we do // this in a separate class and not wxMessageDialogBase itself) -#if defined(__WXCOCOA__) || defined(__WXMAC__) || defined(__WXMSW__) +#if defined(__WXCOCOA__) || \ + defined(__WXGTK20__) || \ + defined(__WXMAC__) || \ + defined(__WXMSW__) class WXDLLIMPEXP_CORE wxMessageDialogWithCustomLabels : public wxMessageDialogBase @@ -134,16 +215,16 @@ public: } // customization of the message box buttons - virtual bool SetYesNoLabels(const wxString& yes,const wxString& no) + virtual bool SetYesNoLabels(const ButtonLabel& yes,const ButtonLabel& no) { DoSetCustomLabel(m_yes, yes); DoSetCustomLabel(m_no, no); return true; } - virtual bool SetYesNoCancelLabels(const wxString& yes, - const wxString& no, - const wxString& cancel) + virtual bool SetYesNoCancelLabels(const ButtonLabel& yes, + const ButtonLabel& no, + const ButtonLabel& cancel) { DoSetCustomLabel(m_yes, yes); DoSetCustomLabel(m_no, no); @@ -151,13 +232,14 @@ public: return true; } - virtual bool SetOKLabel(const wxString& ok) + virtual bool SetOKLabel(const ButtonLabel& ok) { DoSetCustomLabel(m_ok, ok); return true; } - virtual bool SetOKCancelLabels(const wxString& ok, const wxString& cancel) + virtual bool SetOKCancelLabels(const ButtonLabel& ok, + const ButtonLabel& cancel) { DoSetCustomLabel(m_ok, ok); DoSetCustomLabel(m_cancel, cancel); @@ -175,21 +257,32 @@ protected: // these functions return the label to be used for the button which is // either a custom label explicitly set by the user or the default label, // i.e. they always return a valid string - wxString GetYesLabel() const { return m_yes.empty() ? _("Yes") : m_yes; } - wxString GetNoLabel() const { return m_no.empty() ? _("No") : m_no; } - wxString GetOKLabel() const { return m_ok.empty() ? _("OK") : m_ok; } + wxString GetYesLabel() const + { return m_yes.empty() ? GetDefaultYesLabel() : m_yes; } + wxString GetNoLabel() const + { return m_no.empty() ? GetDefaultNoLabel() : m_no; } + wxString GetOKLabel() const + { return m_ok.empty() ? GetDefaultOKLabel() : m_ok; } wxString GetCancelLabel() const - { return m_cancel.empty() ? _("Cancel") : m_cancel; } + { return m_cancel.empty() ? GetDefaultCancelLabel() : m_cancel; } -private: // this function is called by our public SetXXXLabels() and should assign // the value to var with possibly some transformation (e.g. Cocoa version - // currently uses this to remove any accelerators from the button strings) - virtual void DoSetCustomLabel(wxString& var, const wxString& value) + // currently uses this to remove any accelerators from the button strings + // while GTK+ one handles stock items specifically here) + virtual void DoSetCustomLabel(wxString& var, const ButtonLabel& label) { - var = value; + var = label.GetAsString(); } +private: + // these functions may be overridden to provide different defaults for the + // default button labels (this is used by wxGTK) + virtual wxString GetDefaultYesLabel() const { return _("Yes"); } + virtual wxString GetDefaultNoLabel() const { return _("No"); } + virtual wxString GetDefaultOKLabel() const { return _("OK"); } + virtual wxString GetDefaultCancelLabel() const { return _("Cancel"); } + // labels for the buttons, initially empty meaning that the defaults should // be used, use GetYes/No/OK/CancelLabel() to access them wxString m_yes,