+2008-04-22 Johan Dahlin <jdahlin@async.com.br>
+
+ * giscanner/gidlwriter.py:
+ * giscanner/girwriter.py:
+ * giscanner/gobjecttreebuilder.py:
+ * giscanner/treebuilder.py:
+ Add support for Callbacks
+
2008-04-22 Havoc Pennington <hp@pobox.com>
* girepository/ginvoke.c (g_function_info_invoke): If a symbol is
Scanner
------
-- Callbacks
- Virtual functions
- Signals
- Property.readable/writable, GLibProperty.blurb/nick
from .gobjecttreebuilder import (GLibBoxed, GLibEnum, GLibEnumMember,
GLibFlags, GLibObject, GLibInterface)
-from .treebuilder import Class, Enum, Function, Interface
+from .treebuilder import Callback, Class, Enum, Function, Interface
from .xmlwriter import XMLWriter
self._write_class(node)
elif isinstance(node, GLibBoxed):
self._write_boxed(node)
+ elif isinstance(node, Callback):
+ self._write_callback(node)
else:
print 'WRITER: Unhandled node', node
attrs = [('name', prop.name),
('prop', prop.type)]
self.write_tag('property', attrs)
+
+ def _write_callback(self, func):
+ attrs = [('name', func.name)]
+ with self.tagcontext('callback', attrs):
+ self._write_return_type(func.retval)
+ self._write_parameters(func.parameters)
from .gobjecttreebuilder import (GLibBoxed, GLibEnum, GLibEnumMember,
GLibFlags, GLibObject, GLibInterface)
-from .treebuilder import Class, Enum, Function, Interface
+from .treebuilder import Callback, Class, Enum, Function, Interface
from .xmlwriter import XMLWriter
self._write_class(node)
elif isinstance(node, GLibBoxed):
self._write_boxed(node)
+ elif isinstance(node, Callback):
+ self._write_callback(node)
else:
print 'WRITER: Unhandled node', node
attrs = [('name', prop.name),
('prop', prop.type)]
self.write_tag('property', attrs)
+
+
+ def _write_callback(self, callback):
+ attrs = [('name', callback.name)]
+ with self.tagcontext('callback', attrs):
+ self._write_return_type(callback.retval)
+ self._write_parameters(callback.parameters)
from . import cgobject
from .odict import odict
-from .treebuilder import (Class, Enum, Function, Interface, Member, Property,
- Struct)
+from .treebuilder import (Callback, Class, Enum, Function, Interface,
+ Member, Property, Struct)
# Copied from h2defs.py
_upperstr_pat1 = re.compile(r'([^A-Z])([A-Z])')
self._parse_function(node)
elif isinstance(node, Struct):
self._parse_struct(node)
+ elif isinstance(node, Callback):
+ self._parse_callback(node)
else:
- print 'Unhandled node:', node
+ print 'GOBJECT BUILDER: Unhandled node:', node
def _parse_enum(self, enum):
enum.name = self._strip_namespace_object(enum.name)
return
self._add_attribute(struct)
+ def _parse_callback(self, callback):
+ self._add_attribute(callback)
+
def _introspect_type(self, type_id, symbol):
fundamental_type_id = cgobject.type_fundamental(type_id)
if (fundamental_type_id == cgobject.TYPE_ENUM or
self.name, self.type, self.value)
+class Callback(Node):
+ def __init__(self, name, retval, parameters):
+ self.name = name
+ self.retval = retval
+ self.parameters = parameters
+
+ def __repr__(self):
+ return 'Callback(%r, %r, %r)' % (
+ self.name, self.retval, self.parameters)
+
+
class TreeBuilder(object):
def __init__(self, generator):
self.generator = generator
if stype == giscanner.CSYMBOL_TYPE_FUNCTION:
return self._create_function(symbol)
elif stype == giscanner.CSYMBOL_TYPE_TYPEDEF:
- return self._traverse_one(symbol, symbol.base_type.type)
+ if (symbol.base_type.type == giscanner.CTYPE_POINTER and
+ symbol.base_type.base_type.type == giscanner.CTYPE_FUNCTION):
+ return self._create_callback(symbol)
+ else:
+ return self._traverse_one(symbol, symbol.base_type.type)
elif stype == giscanner.CSYMBOL_TYPE_STRUCT:
return self._create_struct(symbol)
elif stype == giscanner.CSYMBOL_TYPE_ENUM:
return Enum(symbol.ident, members)
def _create_function(self, symbol):
- parameters = []
- for child in symbol.base_type.child_list:
- parameters.append(self._create_parameter(child))
-
+ parameters = self._create_parameters(symbol.base_type)
retval = Return(self._create_source_type(symbol.base_type.base_type))
- return Function(symbol.ident, retval, parameters, symbol.ident)
+ return Function(symbol.ident, retval, list(parameters), symbol.ident)
def _create_source_type(self, source_type):
if source_type.type == giscanner.CTYPE_VOID:
value = '???'
return value
+ def _create_parameters(self, base_type):
+ for child in base_type.child_list:
+ yield self._create_parameter(child)
+
def _create_parameter(self, symbol):
return Parameter(symbol.ident,
self._create_source_type(symbol.base_type))
def _create_struct(self, symbol):
return Struct(symbol.ident)
+ def _create_callback(self, symbol):
+ parameters = self._create_parameters(symbol.base_type.base_type)
+ retval = Return(self._create_source_type(symbol.base_type.base_type.base_type))
+ return Callback(symbol.ident, retval, list(parameters))