1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
|
#---------------------------------------------------------------------------
# Name: etg/_xml.py
# Author: Robin Dunn
#
# Created: 28-Nov-2012
# Copyright: (c) 2012-2020 by Total Control Software
# License: wxWindows License
#---------------------------------------------------------------------------
import etgtools
import etgtools.tweaker_tools as tools
PACKAGE = "wx"
MODULE = "_xml"
NAME = "_xml" # Base name of the file to generate to for this script
DOCSTRING = """\
Some simple XML classes for use with XRC.
For more advanced XML needs it would be better to use one of the XML packages
provided by Python.
"""
# The classes and/or the basename of the Doxygen XML files to be processed by
# this script.
ITEMS = [ 'wxXmlNode',
'wxXmlAttribute',
'wxXmlDocument',
'wxXmlDoctype',
]
# The list of other ETG scripts and back-end generator modules that are
# included as part of this module. These should all be items that are put in
# the wxWidgets "xml" library in a multi-lib build.
INCLUDES = [ ]
# Separate the list into those that are generated from ETG scripts and the
# rest. These lists can be used from the build scripts to get a list of
# sources and/or additional dependencies when building this extension module.
ETGFILES = ['etg/%s.py' % NAME] + tools.getEtgFiles(INCLUDES)
DEPENDS = tools.getNonEtgFiles(INCLUDES)
OTHERDEPS = [ ]
#---------------------------------------------------------------------------
def run():
# Parse the XML file(s) building a collection of Extractor objects
module = etgtools.ModuleDef(PACKAGE, MODULE, NAME, DOCSTRING)
etgtools.parseDoxyXML(module, ITEMS)
module.check4unittest = False
#-----------------------------------------------------------------
# Tweak the parsed meta objects in the module object as needed for
# customizing the generated code and docstrings.
module.addHeaderCode('#include <wxPython/wxpy_api.h>')
module.addImport('_core')
module.addPyCode('import wx', order=10)
module.addInclude(INCLUDES)
#-----------------------------------------------------------------
module.addPyCode("""\
XmlProperty = wx.deprecated(XmlAttribute, 'Use XmlProperty instead.')
""")
c = module.find('wxXmlNode')
assert isinstance(c, etgtools.ClassDef)
c.find('wxXmlNode.parent').transferThis = True
c.find('AddAttribute.attr').transfer = True
c.find('AddChild.child').transfer = True
c.find('InsertChild.child').transfer = True
c.find('InsertChildAfter.child').transfer = True
c.find('RemoveChild.child').transferBack = True
# we like the other overload better
c.find('GetAttribute').findOverload('value').ignore()
c.find('SetAttributes').ignore()
c.find('SetChildren').ignore()
c = module.find('wxXmlDocument')
c.piBases = ['wx.Object']
c.find('GetEncoding').ignore()
c.find('SetEncoding').ignore()
c.find('AppendToProlog.node').transfer = True
c.find('DetachDocumentNode').transferBack = True
c.find('DetachRoot').transferBack = True
c.find('SetDocumentNode.node').transfer = True
c.find('SetRoot.node').transfer = True
#-----------------------------------------------------------------
tools.doCommonTweaks(module)
tools.runGenerators(module)
#---------------------------------------------------------------------------
if __name__ == '__main__':
run()
|