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 112 113 114 115 116 117 118
|
#---------------------------------------------------------------------------
# Name: etg/propgridprops.py
# Author: Robin Dunn
#
# Created: 25-Aug-2016
# Copyright: (c) 2016-2017 by Total Control Software
# License: wxWindows License
#---------------------------------------------------------------------------
import etgtools
import etgtools.tweaker_tools as tools
PACKAGE = "wx"
MODULE = "_propgrid"
NAME = "propgridprops" # Base name of the file to generate to for this script
DOCSTRING = ""
# The classes and/or the basename of the Doxygen XML files to be processed by
# this script.
ITEMS = [ 'wxPGInDialogValidator',
'wxStringProperty',
'wxNumericPropertyValidator',
'wxIntProperty',
'wxUIntProperty',
'wxFloatProperty',
'wxBoolProperty',
'wxEnumProperty',
'wxEditEnumProperty',
'wxFlagsProperty',
'wxPGFileDialogAdapter',
'wxFileProperty',
'wxPGLongStringDialogAdapter',
'wxLongStringProperty',
'wxDirProperty',
'wxArrayStringProperty',
'wxPGArrayEditorDialog',
'wxPGArrayStringEditorDialog',
]
#---------------------------------------------------------------------------
def run():
# Parse the XML file(s) building a collection of Extractor objects
module = etgtools.ModuleDef(PACKAGE, MODULE, NAME, DOCSTRING)
etgtools.parseDoxyXML(module, ITEMS)
#-----------------------------------------------------------------
# Tweak the parsed meta objects in the module object as needed for
# customizing the generated code and docstrings.
c = module.find('wxNumericPropertyValidator')
assert isinstance(c, etgtools.ClassDef)
c.bases = ['wxValidator']
for name in ['wxEnumProperty', 'wxEditEnumProperty']:
c = module.find(name)
# Ignore problematic ctors, that we don't need anyway.
# Yes, there are two of them
c.find(name).findOverload('wxChar').ignore()
c.find(name).findOverload('wxChar').ignore()
m = c.find(name).findOverload('wxArrayString')
m.find('label').default = 'wxPG_LABEL'
m.find('name').default = 'wxPG_LABEL'
m.find('labels').default = 'wxArrayString()'
c = module.find('wxFlagsProperty')
# Ignore problematic ctors, that we don't need anyway.
c.find('wxFlagsProperty').findOverload('wxChar').ignore()
c = module.find('wxIntProperty')
# clear the parts of the docstrings that are not really applicable to Python
c.briefDoc = "Basic property with integer value."
c.detailedDoc = []
c = module.find('wxLongStringProperty')
c.find('OnButtonClick.value').inOut = True
c.find('DisplayEditorDialog.value').inOut = True
c = module.find('wxDirProperty')
c.find('OnButtonClick.value').inOut = True
c = module.find('wxArrayStringProperty')
c.find('GenerateValueAsString').ignore(False)
c = module.find('wxPGArrayEditorDialog')
tools.fixWindowClass(c, hideVirtuals=False, ignoreProtected=False)
c = module.find('wxPGArrayStringEditorDialog')
tools.fixWindowClass(c, hideVirtuals=False, ignoreProtected=False)
# Switch all wxVariant types to wxPGVariant, so the propgrid-specific
# version of the MappedType will be used for converting to/from Python
# objects.
for item in module.allItems():
if hasattr(item, 'type') and 'wxVariant' in item.type:
item.type = item.type.replace('wxVariant', 'wxPGVariant')
# Switch all StringToValue and IntToValue methods to return the variant
# value instead of using it as a parameter.
for item in module.allItems():
if (item.name in ['StringToValue', 'IntToValue'] and item.findItem('variant')):
item.find('variant').out = True
#-----------------------------------------------------------------
tools.doCommonTweaks(module)
tools.runGenerators(module)
#---------------------------------------------------------------------------
if __name__ == '__main__':
run()
|