Moved xrc out of contrib and into the core source dir, just like in
C++. It will now always be built. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@29280 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
189
wxPython/src/_xml.i
Normal file
189
wxPython/src/_xml.i
Normal file
@@ -0,0 +1,189 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: _xml.i
|
||||
// Purpose: SWIG interface for other wxXml classes
|
||||
//
|
||||
// Author: Robin Dunn
|
||||
//
|
||||
// Created: 4-June-2001
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2003 by Total Control Software
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Not a %module
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
%newgroup
|
||||
|
||||
|
||||
// In order to provide wrappers for wxXmlResourceHandler we need to also
|
||||
// provide the classes for representing and parsing XML.
|
||||
|
||||
|
||||
// Represents XML node type.
|
||||
enum wxXmlNodeType
|
||||
{
|
||||
// note: values are synchronized with xmlElementType from libxml
|
||||
wxXML_ELEMENT_NODE,
|
||||
wxXML_ATTRIBUTE_NODE,
|
||||
wxXML_TEXT_NODE,
|
||||
wxXML_CDATA_SECTION_NODE,
|
||||
wxXML_ENTITY_REF_NODE,
|
||||
wxXML_ENTITY_NODE,
|
||||
wxXML_PI_NODE,
|
||||
wxXML_COMMENT_NODE,
|
||||
wxXML_DOCUMENT_NODE,
|
||||
wxXML_DOCUMENT_TYPE_NODE,
|
||||
wxXML_DOCUMENT_FRAG_NODE,
|
||||
wxXML_NOTATION_NODE,
|
||||
wxXML_HTML_DOCUMENT_NODE
|
||||
};
|
||||
|
||||
|
||||
|
||||
// Represents node property(ies).
|
||||
// Example: in <img src="hello.gif" id="3"/> "src" is property with value
|
||||
// "hello.gif" and "id" is property with value "3".
|
||||
class wxXmlProperty
|
||||
{
|
||||
public:
|
||||
wxXmlProperty(const wxString& name = wxPyEmptyString,
|
||||
const wxString& value = wxPyEmptyString,
|
||||
wxXmlProperty *next = NULL);
|
||||
|
||||
wxString GetName() const;
|
||||
wxString GetValue() const;
|
||||
wxXmlProperty *GetNext() const;
|
||||
|
||||
void SetName(const wxString& name);
|
||||
void SetValue(const wxString& value);
|
||||
void SetNext(wxXmlProperty *next);
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
// Represents node in XML document. Node has name and may have content
|
||||
// and properties. Most common node types are wxXML_TEXT_NODE (name and props
|
||||
// are irrelevant) and wxXML_ELEMENT_NODE (e.g. in <title>hi</title> there is
|
||||
// element with name="title", irrelevant content and one child (wxXML_TEXT_NODE
|
||||
// with content="hi").
|
||||
//
|
||||
// If wxUSE_UNICODE is 0, all strings are encoded in the encoding given to Load
|
||||
// (default is UTF-8).
|
||||
class wxXmlNode
|
||||
{
|
||||
public:
|
||||
wxXmlNode(wxXmlNode *parent = NULL,
|
||||
wxXmlNodeType type = 0,
|
||||
const wxString& name = wxPyEmptyString,
|
||||
const wxString& content = wxPyEmptyString,
|
||||
wxXmlProperty *props = NULL,
|
||||
wxXmlNode *next = NULL);
|
||||
~wxXmlNode();
|
||||
|
||||
|
||||
// user-friendly creation:
|
||||
%name(XmlNodeEasy) wxXmlNode(wxXmlNodeType type, const wxString& name,
|
||||
const wxString& content = wxPyEmptyString);
|
||||
|
||||
void AddChild(wxXmlNode *child);
|
||||
void InsertChild(wxXmlNode *child, wxXmlNode *before_node);
|
||||
bool RemoveChild(wxXmlNode *child);
|
||||
void AddProperty(wxXmlProperty *prop);
|
||||
%name(AddPropertyName) void AddProperty(const wxString& name, const wxString& value);
|
||||
bool DeleteProperty(const wxString& name);
|
||||
|
||||
// access methods:
|
||||
wxXmlNodeType GetType() const;
|
||||
wxString GetName() const;
|
||||
wxString GetContent() const;
|
||||
|
||||
wxXmlNode *GetParent() const;
|
||||
wxXmlNode *GetNext() const;
|
||||
wxXmlNode *GetChildren() const;
|
||||
|
||||
wxXmlProperty *GetProperties() const;
|
||||
wxString GetPropVal(const wxString& propName,
|
||||
const wxString& defaultVal) const;
|
||||
bool HasProp(const wxString& propName) const;
|
||||
|
||||
void SetType(wxXmlNodeType type);
|
||||
void SetName(const wxString& name);
|
||||
void SetContent(const wxString& con);
|
||||
|
||||
void SetParent(wxXmlNode *parent);
|
||||
void SetNext(wxXmlNode *next);
|
||||
void SetChildren(wxXmlNode *child);
|
||||
|
||||
void SetProperties(wxXmlProperty *prop);
|
||||
};
|
||||
|
||||
|
||||
|
||||
// This class holds XML data/document as parsed by XML parser.
|
||||
class wxXmlDocument : public wxObject
|
||||
{
|
||||
public:
|
||||
wxXmlDocument(const wxString& filename,
|
||||
const wxString& encoding = wxPyUTF8String);
|
||||
%name(XmlDocumentFromStream) wxXmlDocument(wxInputStream& stream,
|
||||
const wxString& encoding = wxPyUTF8String);
|
||||
%name(EmptyXmlDocument) wxXmlDocument();
|
||||
|
||||
~wxXmlDocument();
|
||||
|
||||
|
||||
// Parses .xml file and loads data. Returns True on success, False
|
||||
// otherwise.
|
||||
bool Load(const wxString& filename,
|
||||
const wxString& encoding = wxPyUTF8String);
|
||||
%name(LoadFromStream)bool Load(wxInputStream& stream,
|
||||
const wxString& encoding = wxPyUTF8String);
|
||||
|
||||
// Saves document as .xml file.
|
||||
bool Save(const wxString& filename) const;
|
||||
%name(SaveToStream)bool Save(wxOutputStream& stream) const;
|
||||
|
||||
bool IsOk() const;
|
||||
|
||||
// Returns root node of the document.
|
||||
wxXmlNode *GetRoot() const;
|
||||
|
||||
// Returns version of document (may be empty).
|
||||
wxString GetVersion() const;
|
||||
|
||||
// Returns encoding of document (may be empty).
|
||||
// Note: this is the encoding original file was saved in, *not* the
|
||||
// encoding of in-memory representation!
|
||||
wxString GetFileEncoding() const;
|
||||
|
||||
// Write-access methods:
|
||||
void SetRoot(wxXmlNode *node);
|
||||
void SetVersion(const wxString& version);
|
||||
void SetFileEncoding(const wxString& encoding);
|
||||
|
||||
// %extend {
|
||||
// // Returns encoding of in-memory representation of the document (same
|
||||
// // as passed to Load or ctor, defaults to UTF-8). NB: this is
|
||||
// // meaningless in Unicode build where data are stored as wchar_t*
|
||||
// wxString GetEncoding() {
|
||||
// %#if wxUSE_UNICODE
|
||||
// return wxPyEmptyString;
|
||||
// %#else
|
||||
// return self->GetEncoding();
|
||||
// %#endif
|
||||
// }
|
||||
// void SetEncoding(const wxString& enc) {
|
||||
// %#if wxUSE_UNICODE
|
||||
// // do nothing
|
||||
// %#else
|
||||
// self->SetEncoding(enc);
|
||||
// %#endif
|
||||
// }
|
||||
// }
|
||||
};
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//---------------------------------------------------------------------------
|
266
wxPython/src/_xmlhandler.i
Normal file
266
wxPython/src/_xmlhandler.i
Normal file
@@ -0,0 +1,266 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: _xml.i
|
||||
// Purpose: SWIG interface for other wxXml classes
|
||||
//
|
||||
// Author: Robin Dunn
|
||||
//
|
||||
// Created: 4-June-2001
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2003 by Total Control Software
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Not a %module
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
%newgroup
|
||||
|
||||
|
||||
|
||||
%{ // C++ version of Python aware wxXmlResourceHandler, for the pure virtual
|
||||
// callbacks, as well as to make some protected things public so they can
|
||||
// be wrapped.
|
||||
class wxPyXmlResourceHandler : public wxXmlResourceHandler {
|
||||
public:
|
||||
wxPyXmlResourceHandler() : wxXmlResourceHandler() {}
|
||||
//~wxPyXmlResourceHandler();
|
||||
|
||||
// Base class virtuals
|
||||
|
||||
DEC_PYCALLBACK_OBJECT__pure(DoCreateResource);
|
||||
DEC_PYCALLBACK_BOOL_NODE_pure(CanHandle);
|
||||
|
||||
|
||||
// accessors for protected members
|
||||
|
||||
wxXmlResource* GetResource() { return m_resource; }
|
||||
wxXmlNode* GetNode() { return m_node; }
|
||||
wxString GetClass() { return m_class; }
|
||||
wxObject* GetParent() { return m_parent; }
|
||||
wxObject* GetInstance() { return m_instance; }
|
||||
wxWindow* GetParentAsWindow() { return m_parentAsWindow; }
|
||||
wxWindow* GetInstanceAsWindow() { return m_instanceAsWindow; }
|
||||
|
||||
|
||||
// turn some protected methods into public via delegation
|
||||
|
||||
bool IsOfClass(wxXmlNode *node, const wxString& classname)
|
||||
{ return wxXmlResourceHandler::IsOfClass(node, classname); }
|
||||
|
||||
wxString GetNodeContent(wxXmlNode *node)
|
||||
{ return wxXmlResourceHandler::GetNodeContent(node); }
|
||||
|
||||
bool HasParam(const wxString& param)
|
||||
{ return wxXmlResourceHandler::HasParam(param); }
|
||||
|
||||
wxXmlNode *GetParamNode(const wxString& param)
|
||||
{ return wxXmlResourceHandler::GetParamNode(param); }
|
||||
|
||||
wxString GetParamValue(const wxString& param)
|
||||
{ return wxXmlResourceHandler::GetParamValue(param); }
|
||||
|
||||
void AddStyle(const wxString& name, int value)
|
||||
{ wxXmlResourceHandler::AddStyle(name, value); }
|
||||
|
||||
void AddWindowStyles()
|
||||
{ wxXmlResourceHandler::AddWindowStyles(); }
|
||||
|
||||
int GetStyle(const wxString& param = wxT("style"), int defaults = 0)
|
||||
{ return wxXmlResourceHandler::GetStyle(param, defaults); }
|
||||
|
||||
wxString GetText(const wxString& param, bool translate = True)
|
||||
{ return wxXmlResourceHandler::GetText(param, translate); }
|
||||
|
||||
int GetID()
|
||||
{ return wxXmlResourceHandler::GetID(); }
|
||||
|
||||
wxString GetName()
|
||||
{ return wxXmlResourceHandler::GetName(); }
|
||||
|
||||
bool GetBool(const wxString& param, bool defaultv = False)
|
||||
{ return wxXmlResourceHandler::GetBool(param, defaultv); }
|
||||
|
||||
long GetLong( const wxString& param, long defaultv = 0 )
|
||||
{ return wxXmlResourceHandler::GetLong(param, defaultv); }
|
||||
|
||||
wxColour GetColour(const wxString& param)
|
||||
{ return wxXmlResourceHandler::GetColour(param); }
|
||||
|
||||
wxSize GetSize(const wxString& param = wxT("size"))
|
||||
{ return wxXmlResourceHandler::GetSize(param); }
|
||||
|
||||
wxPoint GetPosition(const wxString& param = wxT("pos"))
|
||||
{ return wxXmlResourceHandler::GetPosition(param); }
|
||||
|
||||
wxCoord GetDimension(const wxString& param, wxCoord defaultv = 0)
|
||||
{ return wxXmlResourceHandler::GetDimension(param, defaultv); }
|
||||
|
||||
wxBitmap GetBitmap(const wxString& param = wxT("bitmap"),
|
||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
||||
wxSize size = wxDefaultSize)
|
||||
{ return wxXmlResourceHandler::GetBitmap(param, defaultArtClient, size); }
|
||||
|
||||
wxIcon GetIcon(const wxString& param = wxT("icon"),
|
||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
||||
wxSize size = wxDefaultSize)
|
||||
{ return wxXmlResourceHandler::GetIcon(param, defaultArtClient, size); }
|
||||
|
||||
wxFont GetFont(const wxString& param = wxT("font"))
|
||||
{ return wxXmlResourceHandler::GetFont(param); }
|
||||
|
||||
void SetupWindow(wxWindow *wnd)
|
||||
{ wxXmlResourceHandler::SetupWindow(wnd); }
|
||||
|
||||
void CreateChildren(wxObject *parent, bool this_hnd_only = False)
|
||||
{ wxXmlResourceHandler::CreateChildren(parent, this_hnd_only); }
|
||||
|
||||
void CreateChildrenPrivately(wxObject *parent, wxXmlNode *rootnode = NULL)
|
||||
{ wxXmlResourceHandler::CreateChildrenPrivately(parent, rootnode); }
|
||||
|
||||
wxObject *CreateResFromNode(wxXmlNode *node,
|
||||
wxObject *parent, wxObject *instance = NULL)
|
||||
{ return wxXmlResourceHandler::CreateResFromNode(node, parent, instance); }
|
||||
|
||||
wxFileSystem& GetCurFileSystem()
|
||||
{ return wxXmlResourceHandler::GetCurFileSystem(); }
|
||||
|
||||
|
||||
PYPRIVATE;
|
||||
};
|
||||
|
||||
IMP_PYCALLBACK_OBJECT__pure(wxPyXmlResourceHandler, wxXmlResourceHandler, DoCreateResource);
|
||||
IMP_PYCALLBACK_BOOL_NODE_pure(wxPyXmlResourceHandler, wxXmlResourceHandler, CanHandle);
|
||||
|
||||
%}
|
||||
|
||||
|
||||
// Now the version that will be SWIGged.
|
||||
|
||||
|
||||
%name(XmlResourceHandler) class wxPyXmlResourceHandler : public wxObject {
|
||||
public:
|
||||
%pythonAppend wxPyXmlResourceHandler "self._setCallbackInfo(self, XmlResourceHandler)"
|
||||
wxPyXmlResourceHandler() : wxXmlResourceHandler() {}
|
||||
//~wxPyXmlResourceHandler();
|
||||
|
||||
void _setCallbackInfo(PyObject* self, PyObject* _class);
|
||||
|
||||
|
||||
// Creates an object (menu, dialog, control, ...) from an XML node.
|
||||
// Should check for validity.
|
||||
// parent is a higher-level object (usually window, dialog or panel)
|
||||
// that is often neccessary to create the resource.
|
||||
// If instance is non-NULL it should not create a new instance via 'new' but
|
||||
// should rather use this one, and call its Create method.
|
||||
wxObject *CreateResource(wxXmlNode *node, wxObject *parent,
|
||||
wxObject *instance);
|
||||
|
||||
// Sets the parent resource.
|
||||
void SetParentResource(wxXmlResource *res);
|
||||
|
||||
|
||||
wxXmlResource* GetResource() { return m_resource; }
|
||||
wxXmlNode* GetNode() { return m_node; }
|
||||
wxString GetClass() { return m_class; }
|
||||
wxObject* GetParent() { return m_parent; }
|
||||
wxObject* GetInstance() { return m_instance; }
|
||||
wxWindow* GetParentAsWindow() { return m_parentAsWindow; }
|
||||
wxWindow* GetInstanceAsWindow() { return m_instanceAsWindow; }
|
||||
|
||||
|
||||
// Returns true if the node has a property class equal to classname,
|
||||
// e.g. <object class="wxDialog">.
|
||||
bool IsOfClass(wxXmlNode *node, const wxString& classname);
|
||||
|
||||
// Gets node content from wxXML_ENTITY_NODE
|
||||
// The problem is, <tag>content<tag> is represented as
|
||||
// wxXML_ENTITY_NODE name="tag", content=""
|
||||
// |-- wxXML_TEXT_NODE or
|
||||
// wxXML_CDATA_SECTION_NODE name="" content="content"
|
||||
wxString GetNodeContent(wxXmlNode *node);
|
||||
|
||||
// Check to see if a parameter exists.
|
||||
bool HasParam(const wxString& param);
|
||||
|
||||
// Finds the node or returns NULL.
|
||||
wxXmlNode *GetParamNode(const wxString& param);
|
||||
|
||||
// Finds the parameter value or returns the empty string.
|
||||
wxString GetParamValue(const wxString& param);
|
||||
|
||||
// Add a style flag (e.g. wxMB_DOCKABLE) to the list of flags
|
||||
// understood by this handler.
|
||||
void AddStyle(const wxString& name, int value);
|
||||
|
||||
// Add styles common to all wxWindow-derived classes.
|
||||
void AddWindowStyles();
|
||||
|
||||
// Gets style flags from text in form "flag | flag2| flag3 |..."
|
||||
// Only understads flags added with AddStyle
|
||||
int GetStyle(const wxString& param = wxPyStyleString, int defaults = 0);
|
||||
|
||||
// Gets text from param and does some conversions:
|
||||
// - replaces \n, \r, \t by respective chars (according to C syntax)
|
||||
// - replaces _ by & and __ by _ (needed for _File => &File because of XML)
|
||||
// - calls wxGetTranslations (unless disabled in wxXmlResource)
|
||||
wxString GetText(const wxString& param, bool translate = True);
|
||||
|
||||
// Returns the XRCID.
|
||||
int GetID();
|
||||
|
||||
// Returns the resource name.
|
||||
wxString GetName();
|
||||
|
||||
// Gets a bool flag (1, t, yes, on, true are True, everything else is False).
|
||||
bool GetBool(const wxString& param, bool defaultv = False);
|
||||
|
||||
// Gets the integer value from the parameter.
|
||||
long GetLong( const wxString& param, long defaultv = 0 );
|
||||
|
||||
// Gets colour in HTML syntax (#RRGGBB).
|
||||
wxColour GetColour(const wxString& param);
|
||||
|
||||
// Gets the size (may be in dialog units).
|
||||
wxSize GetSize(const wxString& param = wxPySizeString);
|
||||
|
||||
// Gets the position (may be in dialog units).
|
||||
wxPoint GetPosition(const wxString& param = wxPyPosString);
|
||||
|
||||
// Gets a dimension (may be in dialog units).
|
||||
wxCoord GetDimension(const wxString& param, wxCoord defaultv = 0);
|
||||
|
||||
// Gets a bitmap.
|
||||
wxBitmap GetBitmap(const wxString& param = wxPyBitmapString,
|
||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
||||
wxSize size = wxDefaultSize);
|
||||
|
||||
// Gets an icon.
|
||||
wxIcon GetIcon(const wxString& param = wxPyIconString,
|
||||
const wxArtClient& defaultArtClient = wxART_OTHER,
|
||||
wxSize size = wxDefaultSize);
|
||||
|
||||
// Gets a font.
|
||||
wxFont GetFont(const wxString& param = wxPyFontString);
|
||||
|
||||
// Sets common window options.
|
||||
void SetupWindow(wxWindow *wnd);
|
||||
|
||||
// Creates children.
|
||||
void CreateChildren(wxObject *parent, bool this_hnd_only = False);
|
||||
|
||||
// Helper function.
|
||||
void CreateChildrenPrivately(wxObject *parent, wxXmlNode *rootnode = NULL);
|
||||
|
||||
// Creates a resource from a node.
|
||||
wxObject *CreateResFromNode(wxXmlNode *node,
|
||||
wxObject *parent, wxObject *instance = NULL);
|
||||
|
||||
// helper
|
||||
wxFileSystem& GetCurFileSystem();
|
||||
};
|
||||
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//---------------------------------------------------------------------------
|
204
wxPython/src/_xmlres.i
Normal file
204
wxPython/src/_xmlres.i
Normal file
@@ -0,0 +1,204 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: _xmlres.i
|
||||
// Purpose: SWIG interface for wxXmlResource
|
||||
//
|
||||
// Author: Robin Dunn
|
||||
//
|
||||
// Created: 4-June-2001
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2003 by Total Control Software
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Not a %module
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
%newgroup
|
||||
|
||||
|
||||
|
||||
class wxPyXmlSubclassFactory;
|
||||
|
||||
enum {
|
||||
WX_XMLRES_CURRENT_VERSION_MAJOR,
|
||||
WX_XMLRES_CURRENT_VERSION_MINOR,
|
||||
WX_XMLRES_CURRENT_VERSION_RELEASE,
|
||||
WX_XMLRES_CURRENT_VERSION_REVISION,
|
||||
};
|
||||
|
||||
|
||||
enum wxXmlResourceFlags
|
||||
{
|
||||
wxXRC_USE_LOCALE,
|
||||
wxXRC_NO_SUBCLASSING,
|
||||
wxXRC_NO_RELOADING
|
||||
};
|
||||
|
||||
|
||||
|
||||
// This class holds XML resources from one or more .xml files
|
||||
// (or derived forms, either binary or zipped -- see manual for
|
||||
// details).
|
||||
|
||||
class wxXmlResource : public wxObject
|
||||
{
|
||||
public:
|
||||
|
||||
%pythonAppend wxXmlResource(const wxString& filemask, int flags) "self.InitAllHandlers()"
|
||||
%pythonAppend wxXmlResource(int flags) "val.InitAllHandlers()"
|
||||
|
||||
// Ctors.
|
||||
// Flags: wxXRC_USE_LOCALE
|
||||
// translatable strings will be translated via _()
|
||||
// wxXRC_NO_SUBCLASSING
|
||||
// subclass property of object nodes will be ignored
|
||||
// (useful for previews in XRC editors)
|
||||
wxXmlResource(const wxString& filemask, int flags = wxXRC_USE_LOCALE);
|
||||
%name(EmptyXmlResource) wxXmlResource(int flags = wxXRC_USE_LOCALE);
|
||||
~wxXmlResource();
|
||||
|
||||
|
||||
// Loads resources from XML files that match given filemask.
|
||||
// This method understands VFS (see filesys.h).
|
||||
bool Load(const wxString& filemask);
|
||||
|
||||
%extend {
|
||||
bool LoadFromString(const wxString& data) {
|
||||
static int s_memFileIdx = 0;
|
||||
|
||||
// Check for memory FS. If not present, load the handler:
|
||||
wxMemoryFSHandler::AddFile(wxT("XRC_resource/dummy_file"),
|
||||
wxT("dummy data"));
|
||||
wxFileSystem fsys;
|
||||
wxFSFile *f = fsys.OpenFile(wxT("memory:XRC_resource/dummy_file"));
|
||||
wxMemoryFSHandler::RemoveFile(wxT("XRC_resource/dummy_file"));
|
||||
if (f)
|
||||
delete f;
|
||||
else
|
||||
wxFileSystem::AddHandler(new wxMemoryFSHandler);
|
||||
|
||||
// Now put the resource data into the memory FS
|
||||
wxString filename(wxT("XRC_resource/data_string_"));
|
||||
filename << s_memFileIdx;
|
||||
s_memFileIdx += 1;
|
||||
wxMemoryFSHandler::AddFile(filename, data);
|
||||
|
||||
// Load the "file" into the resource object
|
||||
bool retval = self->Load(wxT("memory:") + filename );
|
||||
|
||||
return retval;
|
||||
}
|
||||
}
|
||||
|
||||
// Initialize handlers for all supported controls/windows.
|
||||
void InitAllHandlers();
|
||||
|
||||
// Initialize only specific handler (or custom handler). Convention says
|
||||
// that handler name is equal to control's name plus 'XmlHandler', e.g.
|
||||
// wxTextCtrlXmlHandler, wxHtmlWindowXmlHandler. XML resource compiler
|
||||
// (xmlres) can create include file that contains initialization code for
|
||||
// all controls used within the resource.
|
||||
void AddHandler(wxPyXmlResourceHandler *handler);
|
||||
|
||||
// Add a new handler at the begining of the handler list
|
||||
void InsertHandler(wxPyXmlResourceHandler *handler);
|
||||
|
||||
// Removes all handlers
|
||||
void ClearHandlers();
|
||||
|
||||
// Registers subclasses factory for use in XRC. This function is not meant
|
||||
// for public use, please see the comment above wxXmlSubclassFactory
|
||||
// definition.
|
||||
static void AddSubclassFactory(wxPyXmlSubclassFactory *factory);
|
||||
|
||||
|
||||
// Loads menu from resource. Returns NULL on failure.
|
||||
wxMenu *LoadMenu(const wxString& name);
|
||||
|
||||
// Loads menubar from resource. Returns NULL on failure.
|
||||
wxMenuBar *LoadMenuBar(const wxString& name);
|
||||
%name(LoadMenuBarOnFrame) wxMenuBar *LoadMenuBar(wxWindow *parent, const wxString& name);
|
||||
|
||||
|
||||
// Loads toolbar
|
||||
wxToolBar *LoadToolBar(wxWindow *parent, const wxString& name);
|
||||
|
||||
// Loads dialog. dlg points to parent window (if any). Second form
|
||||
// is used to finish creation of already existing instance (main reason
|
||||
// for this is that you may want to use derived class with new event table)
|
||||
// Example (typical usage):
|
||||
// MyDialog dlg;
|
||||
// wxTheXmlResource->LoadDialog(&dlg, mainFrame, "my_dialog");
|
||||
// dlg->ShowModal();
|
||||
wxDialog *LoadDialog(wxWindow *parent, const wxString& name);
|
||||
%name(LoadOnDialog)bool LoadDialog(wxDialog *dlg, wxWindow *parent, const wxString& name);
|
||||
|
||||
// Loads panel. panel points to parent window (if any). Second form
|
||||
// is used to finish creation of already existing instance.
|
||||
wxPanel *LoadPanel(wxWindow *parent, const wxString& name);
|
||||
%name(LoadOnPanel)bool LoadPanel(wxPanel *panel, wxWindow *parent, const wxString& name);
|
||||
|
||||
// Load a frame's contents from a resource
|
||||
wxFrame *LoadFrame(wxWindow* parent, const wxString& name);
|
||||
%name(LoadOnFrame)bool LoadFrame(wxFrame* frame, wxWindow *parent, const wxString& name);
|
||||
|
||||
// Load an object from the resource specifying both the resource name and
|
||||
// the classname. This lets you load nonstandard container windows.
|
||||
wxObject *LoadObject(wxWindow *parent, const wxString& name,
|
||||
const wxString& classname);
|
||||
|
||||
// Load an object from the resource specifying both the resource name and
|
||||
// the classname. This form lets you finish the creation of an existing
|
||||
// instance.
|
||||
%name(LoadOnObject)bool LoadObject(wxObject *instance, wxWindow *parent, const wxString& name,
|
||||
const wxString& classname);
|
||||
|
||||
// Loads a bitmap resource from a file.
|
||||
wxBitmap LoadBitmap(const wxString& name);
|
||||
|
||||
// Loads an icon resource from a file.
|
||||
wxIcon LoadIcon(const wxString& name);
|
||||
|
||||
// Attaches unknown control into given panel/window/dialog:
|
||||
// (unknown controls are used in conjunction with <object class="unknown">)
|
||||
bool AttachUnknownControl(const wxString& name, wxWindow *control,
|
||||
wxWindow *parent = NULL);
|
||||
|
||||
// Returns numeric ID that is equivalent to string id used in XML
|
||||
// resource. To be used in event tables
|
||||
// Macro XMLID is provided for convenience
|
||||
static int GetXRCID(const wxString& str_id);
|
||||
|
||||
// Returns version info (a.b.c.d = d+ 256*c + 256^2*b + 256^3*a)
|
||||
long GetVersion() const;
|
||||
|
||||
// Compares resources version to argument. Returns -1 if resources version
|
||||
// is less than the argument, +1 if greater and 0 if they equal.
|
||||
int CompareVersion(int major, int minor, int release, int revision) const;
|
||||
|
||||
|
||||
// Gets global resources object or create one if none exists
|
||||
static wxXmlResource *Get();
|
||||
// Sets global resources object and returns pointer to previous one (may be NULL).
|
||||
static wxXmlResource *Set(wxXmlResource *res);
|
||||
|
||||
// Returns flags, which may be a bitlist of wxXRC_USE_LOCALE and wxXRC_NO_SUBCLASSING.
|
||||
int GetFlags();
|
||||
|
||||
// Set flags after construction.
|
||||
void SetFlags(int flags) { m_flags = flags; }
|
||||
|
||||
};
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
|
||||
%pythoncode {
|
||||
def XRCID(str_id):
|
||||
return XmlResource_GetXRCID(str_id)
|
||||
|
||||
def XRCCTRL(window, str_id, *ignoreargs):
|
||||
return window.FindWindowById(XRCID(str_id))
|
||||
};
|
||||
|
||||
//---------------------------------------------------------------------------
|
44
wxPython/src/_xmlsub.i
Normal file
44
wxPython/src/_xmlsub.i
Normal file
@@ -0,0 +1,44 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: _xmlres.i
|
||||
// Purpose: SWIG interface for wxXmlSubclassFactory
|
||||
//
|
||||
// Author: Robin Dunn
|
||||
//
|
||||
// Created: 4-June-2001
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2003 by Total Control Software
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Not a %module
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
%newgroup
|
||||
|
||||
|
||||
|
||||
%{
|
||||
class wxPyXmlSubclassFactory : public wxXmlSubclassFactory
|
||||
{
|
||||
public:
|
||||
wxPyXmlSubclassFactory() {}
|
||||
DEC_PYCALLBACK_OBJECT_STRING_pure(Create);
|
||||
PYPRIVATE;
|
||||
};
|
||||
|
||||
IMP_PYCALLBACK_OBJECT_STRING_pure(wxPyXmlSubclassFactory, wxXmlSubclassFactory, Create);
|
||||
%}
|
||||
|
||||
|
||||
|
||||
%name(XmlSubclassFactory)class wxPyXmlSubclassFactory {
|
||||
public:
|
||||
%pythonAppend wxPyXmlSubclassFactory "self._setCallbackInfo(self, XmlSubclassFactory)"
|
||||
wxPyXmlSubclassFactory();
|
||||
void _setCallbackInfo(PyObject* self, PyObject* _class);
|
||||
};
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//---------------------------------------------------------------------------
|
36
wxPython/src/_xrc_ex.py
Normal file
36
wxPython/src/_xrc_ex.py
Normal file
@@ -0,0 +1,36 @@
|
||||
#----------------------------------------------------------------------------
|
||||
# The global was removed in favor of static accessor functions. This is for
|
||||
# backwards compatibility:
|
||||
|
||||
TheXmlResource = XmlResource_Get()
|
||||
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Create a factory for handling the subclass property of the object tag.
|
||||
|
||||
|
||||
def _my_import(name):
|
||||
mod = __import__(name)
|
||||
components = name.split('.')
|
||||
for comp in components[1:]:
|
||||
mod = getattr(mod, comp)
|
||||
return mod
|
||||
|
||||
|
||||
class XmlSubclassFactory_Python(XmlSubclassFactory):
|
||||
def __init__(self):
|
||||
XmlSubclassFactory.__init__(self)
|
||||
|
||||
def Create(self, className):
|
||||
assert className.find('.') != -1, "Module name must be specified!"
|
||||
mname = className[:className.rfind('.')]
|
||||
cname = className[className.rfind('.')+1:]
|
||||
module = _my_import(mname)
|
||||
klass = getattr(module, cname)
|
||||
inst = klass()
|
||||
return inst
|
||||
|
||||
|
||||
XmlResource_AddSubclassFactory(XmlSubclassFactory_Python())
|
||||
|
||||
#----------------------------------------------------------------------------
|
27
wxPython/src/_xrc_rename.i
Normal file
27
wxPython/src/_xrc_rename.i
Normal file
@@ -0,0 +1,27 @@
|
||||
// A bunch of %rename directives generated by BuildRenamers in config.py
|
||||
// in order to remove the wx prefix from all global scope names.
|
||||
|
||||
#ifndef BUILDING_RENAMERS
|
||||
|
||||
%rename(XRC_USE_LOCALE) wxXRC_USE_LOCALE;
|
||||
%rename(XRC_NO_SUBCLASSING) wxXRC_NO_SUBCLASSING;
|
||||
%rename(XRC_NO_RELOADING) wxXRC_NO_RELOADING;
|
||||
%rename(XmlResource) wxXmlResource;
|
||||
%rename(XML_ELEMENT_NODE) wxXML_ELEMENT_NODE;
|
||||
%rename(XML_ATTRIBUTE_NODE) wxXML_ATTRIBUTE_NODE;
|
||||
%rename(XML_TEXT_NODE) wxXML_TEXT_NODE;
|
||||
%rename(XML_CDATA_SECTION_NODE) wxXML_CDATA_SECTION_NODE;
|
||||
%rename(XML_ENTITY_REF_NODE) wxXML_ENTITY_REF_NODE;
|
||||
%rename(XML_ENTITY_NODE) wxXML_ENTITY_NODE;
|
||||
%rename(XML_PI_NODE) wxXML_PI_NODE;
|
||||
%rename(XML_COMMENT_NODE) wxXML_COMMENT_NODE;
|
||||
%rename(XML_DOCUMENT_NODE) wxXML_DOCUMENT_NODE;
|
||||
%rename(XML_DOCUMENT_TYPE_NODE) wxXML_DOCUMENT_TYPE_NODE;
|
||||
%rename(XML_DOCUMENT_FRAG_NODE) wxXML_DOCUMENT_FRAG_NODE;
|
||||
%rename(XML_NOTATION_NODE) wxXML_NOTATION_NODE;
|
||||
%rename(XML_HTML_DOCUMENT_NODE) wxXML_HTML_DOCUMENT_NODE;
|
||||
%rename(XmlProperty) wxXmlProperty;
|
||||
%rename(XmlNode) wxXmlNode;
|
||||
%rename(XmlDocument) wxXmlDocument;
|
||||
|
||||
#endif
|
6
wxPython/src/_xrc_reverse.txt
Normal file
6
wxPython/src/_xrc_reverse.txt
Normal file
@@ -0,0 +1,6 @@
|
||||
# Other names that need to be reverse-renamed for the old namespace
|
||||
|
||||
XRCID = wx.xrc.XRCID
|
||||
XRCCTRL = wx.xrc.XRCCTRL
|
||||
|
||||
TheXmlResource
|
71
wxPython/src/xrc.i
Normal file
71
wxPython/src/xrc.i
Normal file
@@ -0,0 +1,71 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: xrc.i
|
||||
// Purpose: Wrappers for the XML based Resource system
|
||||
//
|
||||
// Author: Robin Dunn
|
||||
//
|
||||
// Created: 4-June-2001
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2001 by Total Control Software
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
%define DOCSTRING
|
||||
"The `XmlResource` class allows program resources defining menus, layout of
|
||||
controls on a panel, etc. to be loaded from an XML file."
|
||||
%enddef
|
||||
|
||||
%module(package="wx", docstring=DOCSTRING) xrc
|
||||
|
||||
|
||||
%{
|
||||
#include "wx/wxPython/wxPython.h"
|
||||
#include "wx/wxPython/pyclasses.h"
|
||||
#include "wx/wxPython/pyistream.h"
|
||||
|
||||
#include <wx/xml/xml.h>
|
||||
#include <wx/xrc/xmlres.h>
|
||||
%}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
%import core.i
|
||||
%pythoncode { wx = _core }
|
||||
%pythoncode { __docfilter__ = wx.__DocFilter(globals()) }
|
||||
|
||||
|
||||
MAKE_CONST_WXSTRING_NOSWIG(EmptyString);
|
||||
MAKE_CONST_WXSTRING2(UTF8String, wxT("UTF-8"));
|
||||
MAKE_CONST_WXSTRING2(StyleString, wxT("style"));
|
||||
MAKE_CONST_WXSTRING2(SizeString, wxT("size"));
|
||||
MAKE_CONST_WXSTRING2(PosString, wxT("pos"));
|
||||
MAKE_CONST_WXSTRING2(BitmapString, wxT("bitmap"));
|
||||
MAKE_CONST_WXSTRING2(IconString, wxT("icon"));
|
||||
MAKE_CONST_WXSTRING2(FontString, wxT("font"));
|
||||
|
||||
|
||||
%include _xrc_rename.i
|
||||
|
||||
|
||||
// Include all the files that make up this module
|
||||
%include _xmlres.i
|
||||
%include _xmlsub.i
|
||||
%include _xml.i
|
||||
%include _xmlhandler.i
|
||||
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
%init %{
|
||||
|
||||
wxXmlInitResourceModule();
|
||||
wxXmlResource::Get()->InitAllHandlers();
|
||||
|
||||
%}
|
||||
|
||||
|
||||
%pythoncode "_xrc_ex.py";
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
Reference in New Issue
Block a user