Don't use wxASCII_STR() inside wxART_MAKE_XXX_ID macros
This changed the type of the art and client ID values, which broke
compatibility with existing code, notably in wxPython (see
https://github.com/wxWidgets/wxWidgets/pull/1996), and the attempts to
fix this compatibility broke it with all the existing code using
wxART_MAKE_ART_ID() or wxART_MAKE_CLIENT_ID() for their own IDs.
Keep things simple and just define the macros as they were defined
before 4552009805
(Merge branch 'pr1312-no-unsafe-wxstring-conv',
2020-07-20), except for wxART_MAKE_CLIENT_ID_FROM_STR() whose argument
and produced value was already of wxString type, and use wxASCII_STR()
at the place of use of wxART_XXX constants in wx code.
This is obviously not ideal as it will require using wxASCII_STR() in
the application code as well, but seems to be the least evil.
This commit is contained in:
@@ -28,9 +28,9 @@ typedef wxString wxArtClient;
|
|||||||
typedef wxString wxArtID;
|
typedef wxString wxArtID;
|
||||||
|
|
||||||
#define wxART_MAKE_CLIENT_ID_FROM_STR(id) ((id) + wxASCII_STR("_C"))
|
#define wxART_MAKE_CLIENT_ID_FROM_STR(id) ((id) + wxASCII_STR("_C"))
|
||||||
#define wxART_MAKE_CLIENT_ID(id) wxASCII_STR(#id "_C")
|
#define wxART_MAKE_CLIENT_ID(id) (#id "_C")
|
||||||
#define wxART_MAKE_ART_ID_FROM_STR(id) (id)
|
#define wxART_MAKE_ART_ID_FROM_STR(id) (id)
|
||||||
#define wxART_MAKE_ART_ID(id) wxASCII_STR(#id)
|
#define wxART_MAKE_ART_ID(id) (#id)
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// Art clients
|
// Art clients
|
||||||
@@ -154,13 +154,13 @@ public:
|
|||||||
// Query the providers for bitmap with given ID and return it. Return
|
// Query the providers for bitmap with given ID and return it. Return
|
||||||
// wxNullBitmap if no provider provides it.
|
// wxNullBitmap if no provider provides it.
|
||||||
static wxBitmap GetBitmap(const wxArtID& id,
|
static wxBitmap GetBitmap(const wxArtID& id,
|
||||||
const wxArtClient& client = wxART_OTHER,
|
const wxArtClient& client = wxASCII_STR(wxART_OTHER),
|
||||||
const wxSize& size = wxDefaultSize);
|
const wxSize& size = wxDefaultSize);
|
||||||
|
|
||||||
// Query the providers for icon with given ID and return it. Return
|
// Query the providers for icon with given ID and return it. Return
|
||||||
// wxNullIcon if no provider provides it.
|
// wxNullIcon if no provider provides it.
|
||||||
static wxIcon GetIcon(const wxArtID& id,
|
static wxIcon GetIcon(const wxArtID& id,
|
||||||
const wxArtClient& client = wxART_OTHER,
|
const wxArtClient& client = wxASCII_STR(wxART_OTHER),
|
||||||
const wxSize& size = wxDefaultSize);
|
const wxSize& size = wxDefaultSize);
|
||||||
|
|
||||||
// Helper used by GetMessageBoxIcon(): return the art id corresponding to
|
// Helper used by GetMessageBoxIcon(): return the art id corresponding to
|
||||||
@@ -173,13 +173,13 @@ public:
|
|||||||
// can be set)
|
// can be set)
|
||||||
static wxIcon GetMessageBoxIcon(int flags)
|
static wxIcon GetMessageBoxIcon(int flags)
|
||||||
{
|
{
|
||||||
return GetIcon(GetMessageBoxIconId(flags), wxART_MESSAGE_BOX);
|
return GetIcon(GetMessageBoxIconId(flags), wxASCII_STR(wxART_MESSAGE_BOX));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Query the providers for iconbundle with given ID and return it. Return
|
// Query the providers for iconbundle with given ID and return it. Return
|
||||||
// wxNullIconBundle if no provider provides it.
|
// wxNullIconBundle if no provider provides it.
|
||||||
static wxIconBundle GetIconBundle(const wxArtID& id,
|
static wxIconBundle GetIconBundle(const wxArtID& id,
|
||||||
const wxArtClient& client = wxART_OTHER);
|
const wxArtClient& client = wxASCII_STR(wxART_OTHER));
|
||||||
|
|
||||||
// Gets native size for given 'client' or wxDefaultSize if it doesn't
|
// Gets native size for given 'client' or wxDefaultSize if it doesn't
|
||||||
// have native equivalent
|
// have native equivalent
|
||||||
|
@@ -565,27 +565,27 @@ public:
|
|||||||
|
|
||||||
// Gets a bitmap.
|
// Gets a bitmap.
|
||||||
wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) wxOVERRIDE;
|
wxSize size = wxDefaultSize) wxOVERRIDE;
|
||||||
|
|
||||||
// Gets a bitmap from an XmlNode.
|
// Gets a bitmap from an XmlNode.
|
||||||
wxBitmap GetBitmap(const wxXmlNode* node,
|
wxBitmap GetBitmap(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) wxOVERRIDE;
|
wxSize size = wxDefaultSize) wxOVERRIDE;
|
||||||
|
|
||||||
// Gets an icon.
|
// Gets an icon.
|
||||||
wxIcon GetIcon(const wxString& param = wxT("icon"),
|
wxIcon GetIcon(const wxString& param = wxT("icon"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) wxOVERRIDE;
|
wxSize size = wxDefaultSize) wxOVERRIDE;
|
||||||
|
|
||||||
// Gets an icon from an XmlNode.
|
// Gets an icon from an XmlNode.
|
||||||
wxIcon GetIcon(const wxXmlNode* node,
|
wxIcon GetIcon(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) wxOVERRIDE;
|
wxSize size = wxDefaultSize) wxOVERRIDE;
|
||||||
|
|
||||||
// Gets an icon bundle.
|
// Gets an icon bundle.
|
||||||
wxIconBundle GetIconBundle(const wxString& param,
|
wxIconBundle GetIconBundle(const wxString& param,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER) wxOVERRIDE;
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER)) wxOVERRIDE;
|
||||||
|
|
||||||
// Gets an image list.
|
// Gets an image list.
|
||||||
wxImageList *GetImageList(const wxString& param = wxT("imagelist")) wxOVERRIDE;
|
wxImageList *GetImageList(const wxString& param = wxT("imagelist")) wxOVERRIDE;
|
||||||
|
@@ -85,19 +85,19 @@ public:
|
|||||||
virtual wxSize GetPairInts(const wxString& param) = 0;
|
virtual wxSize GetPairInts(const wxString& param) = 0;
|
||||||
virtual wxDirection GetDirection(const wxString& param, wxDirection dir = wxLEFT) = 0;
|
virtual wxDirection GetDirection(const wxString& param, wxDirection dir = wxLEFT) = 0;
|
||||||
virtual wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
virtual wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) = 0;
|
wxSize size = wxDefaultSize) = 0;
|
||||||
virtual wxBitmap GetBitmap(const wxXmlNode* node,
|
virtual wxBitmap GetBitmap(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) = 0;
|
wxSize size = wxDefaultSize) = 0;
|
||||||
virtual wxIcon GetIcon(const wxString& param = wxT("icon"),
|
virtual wxIcon GetIcon(const wxString& param = wxT("icon"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) = 0;
|
wxSize size = wxDefaultSize) = 0;
|
||||||
virtual wxIcon GetIcon(const wxXmlNode* node,
|
virtual wxIcon GetIcon(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize) = 0;
|
wxSize size = wxDefaultSize) = 0;
|
||||||
virtual wxIconBundle GetIconBundle(const wxString& param,
|
virtual wxIconBundle GetIconBundle(const wxString& param,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER) = 0;
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER)) = 0;
|
||||||
virtual wxImageList *GetImageList(const wxString& param = wxT("imagelist")) = 0;
|
virtual wxImageList *GetImageList(const wxString& param = wxT("imagelist")) = 0;
|
||||||
|
|
||||||
#if wxUSE_ANIMATIONCTRL
|
#if wxUSE_ANIMATIONCTRL
|
||||||
@@ -321,31 +321,31 @@ protected:
|
|||||||
return GetImpl()->GetDirection(param, dir);
|
return GetImpl()->GetDirection(param, dir);
|
||||||
}
|
}
|
||||||
wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize)
|
wxSize size = wxDefaultSize)
|
||||||
{
|
{
|
||||||
return GetImpl()->GetBitmap(param, defaultArtClient, size);
|
return GetImpl()->GetBitmap(param, defaultArtClient, size);
|
||||||
}
|
}
|
||||||
wxBitmap GetBitmap(const wxXmlNode* node,
|
wxBitmap GetBitmap(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize)
|
wxSize size = wxDefaultSize)
|
||||||
{
|
{
|
||||||
return GetImpl()->GetBitmap(node, defaultArtClient, size);
|
return GetImpl()->GetBitmap(node, defaultArtClient, size);
|
||||||
}
|
}
|
||||||
wxIcon GetIcon(const wxString& param = wxT("icon"),
|
wxIcon GetIcon(const wxString& param = wxT("icon"),
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize)
|
wxSize size = wxDefaultSize)
|
||||||
{
|
{
|
||||||
return GetImpl()->GetIcon(param, defaultArtClient, size);
|
return GetImpl()->GetIcon(param, defaultArtClient, size);
|
||||||
}
|
}
|
||||||
wxIcon GetIcon(const wxXmlNode* node,
|
wxIcon GetIcon(const wxXmlNode* node,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER),
|
||||||
wxSize size = wxDefaultSize)
|
wxSize size = wxDefaultSize)
|
||||||
{
|
{
|
||||||
return GetImpl()->GetIcon(node, defaultArtClient, size);
|
return GetImpl()->GetIcon(node, defaultArtClient, size);
|
||||||
}
|
}
|
||||||
wxIconBundle GetIconBundle(const wxString& param,
|
wxIconBundle GetIconBundle(const wxString& param,
|
||||||
const wxArtClient& defaultArtClient = wxART_OTHER)
|
const wxArtClient& defaultArtClient = wxASCII_STR(wxART_OTHER))
|
||||||
{
|
{
|
||||||
return GetImpl()->GetIconBundle(param, defaultArtClient);
|
return GetImpl()->GetIconBundle(param, defaultArtClient);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user