[vala] girparser: Provide default constructor for classes.
- From: Luca Bruno <lucabru src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala] girparser: Provide default constructor for classes.
- Date: Mon, 4 Apr 2011 14:18:31 +0000 (UTC)
commit 62da780a04365e5291a2030f6050baaf8b379c27
Author: Luca Bruno <lucabru src gnome org>
Date: Mon Jan 3 20:10:16 2011 +0100
girparser: Provide default constructor for classes.
vala/valagirparser.vala | 26 +++++++++++++++++++-------
1 files changed, 19 insertions(+), 7 deletions(-)
---
diff --git a/vala/valagirparser.vala b/vala/valagirparser.vala
index 5251f9e..d56d017 100644
--- a/vala/valagirparser.vala
+++ b/vala/valagirparser.vala
@@ -1063,11 +1063,11 @@ public class Vala.GirParser : CodeVisitor {
}
}
- void postprocess_symbol (Symbol symbol, Metadata metadata) {
+ void postprocess_symbol (Symbol sym, Metadata metadata) {
// deprecation
- symbol.replacement = metadata.get_string (ArgumentType.REPLACEMENT);
- symbol.deprecated_since = element_get_string ("deprecated-version", ArgumentType.DEPRECATED_SINCE);
- symbol.deprecated = metadata.get_bool (ArgumentType.DEPRECATED) || symbol.replacement != null || symbol.deprecated_since != null;
+ sym.replacement = metadata.get_string (ArgumentType.REPLACEMENT);
+ sym.deprecated_since = element_get_string ("deprecated-version", ArgumentType.DEPRECATED_SINCE);
+ sym.deprecated = metadata.get_bool (ArgumentType.DEPRECATED) || sym.replacement != null || sym.deprecated_since != null;
// mark to be reparented
if (metadata.has_argument (ArgumentType.PARENT)) {
@@ -1077,11 +1077,23 @@ public class Vala.GirParser : CodeVisitor {
reparent_list = new ArrayList<Symbol>();
symbol_reparent_map[target_symbol] = reparent_list;
}
- reparent_list.add (symbol);
+ reparent_list.add (sym);
// if referenceable, map unresolved references to point to the new place
- if (symbol is Namespace || symbol is TypeSymbol) {
- set_symbol_mapping (symbol, new UnresolvedSymbol (target_symbol, symbol.name));
+ if (sym is Namespace || sym is TypeSymbol) {
+ set_symbol_mapping (sym, new UnresolvedSymbol (target_symbol, sym.name));
+ }
+ }
+
+ if (sym is Class) {
+ var cl = (Class) sym;
+ if (cl.default_construction_method == null) {
+ // always provide constructor in generated bindings
+ // to indicate that implicit Object () chainup is allowed
+ var cm = new CreationMethod (null, null, cl.source_reference);
+ cm.has_construct_function = false;
+ cm.access = SymbolAccessibility.PROTECTED;
+ cl.add_method (cm);
}
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]