diff options
author | Johan Dahlin <jdahlin@litl.com> | 2011-08-13 12:45:12 -0300 |
---|---|---|
committer | Tomeu Vizoso <tomeu.vizoso@collabora.co.uk> | 2011-08-13 19:03:34 +0200 |
commit | c3a1333790dd1c25c2e19b80be84f6c8a84c91d6 (patch) | |
tree | 146b3a417c0b33f7dac40f79beb53da56cb4a2c0 | |
parent | afb508ed41233b1cf56b685ba99bbf7c0c727345 (diff) | |
download | gobject-introspection-c3a1333790dd1c25c2e19b80be84f6c8a84c91d6.tar.gz |
Make sure signal works when there isn't one specifiedgir-docbook
-rw-r--r-- | giscanner/ast.py | 2 | ||||
-rw-r--r-- | giscanner/gdumpparser.py | 2 | ||||
-rw-r--r-- | giscanner/girparser.py | 2 | ||||
-rw-r--r-- | giscanner/girwriter.py | 5 |
4 files changed, 6 insertions, 5 deletions
diff --git a/giscanner/ast.py b/giscanner/ast.py index bf1ab976..c84bfc72 100644 --- a/giscanner/ast.py +++ b/giscanner/ast.py @@ -864,7 +864,7 @@ class Boxed(Node, Registered): class Signal(Callable): - def __init__(self, name, retval, parameters, when="first", + def __init__(self, name, retval, parameters, when=None, no_recurse=False, detailed=False, action=False, no_hooks=False): Callable.__init__(self, name, retval, parameters, False) diff --git a/giscanner/gdumpparser.py b/giscanner/gdumpparser.py index be25d614..f94917e6 100644 --- a/giscanner/gdumpparser.py +++ b/giscanner/gdumpparser.py @@ -453,7 +453,7 @@ different --identifier-prefix.""" % (xmlnode.attrib['name'], self._namespace.ide rtype = ast.Type.create_from_gtype_name(rctype) return_ = ast.Return(rtype) parameters = [] - when = signal_info.attrib['when'] + when = signal_info.attrib.get('when') no_recurse = signal_info.attrib.get('no-recurse', '0') == '1' detailed = signal_info.attrib.get('detailed', '0') == '1' action = signal_info.attrib.get('action', '0') == '1' diff --git a/giscanner/girparser.py b/giscanner/girparser.py index ffe0dbc3..5184d16f 100644 --- a/giscanner/girparser.py +++ b/giscanner/girparser.py @@ -300,7 +300,7 @@ class GIRParser(object): func = klass(name, retval, parameters, throws) elif klass is ast.Signal: func = klass(name, retval, parameters, - when=node.attrib.get('when', 'first'), + when=node.attrib.get('when'), no_recurse=node.attrib.get('no-recurse', '0') == '1', detailed=node.attrib.get('detailed', '0') == '1', action=node.attrib.get('action', '0') == '1', diff --git a/giscanner/girwriter.py b/giscanner/girwriter.py index dc6db99e..6299a794 100644 --- a/giscanner/girwriter.py +++ b/giscanner/girwriter.py @@ -552,8 +552,9 @@ and/or use gtk-doc annotations. ''') self._write_type(field.type) def _write_signal(self, signal): - attrs = [('name', signal.name), - ('when', signal.when)] + attrs = [('name', signal.name)] + if signal.when: + attrs.append(('when', signal.when)) if signal.no_recurse: attrs.append(('no-recurse', '1')) if signal.detailed: |