[vala/wip/transform: 21/47] Cache wrapper methods
- From: Luca Bruno <lucabru src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala/wip/transform: 21/47] Cache wrapper methods
- Date: Sat, 25 Feb 2012 18:50:25 +0000 (UTC)
commit e59e7f347d72980a492b60f77023f55b1796a3a0
Author: Luca Bruno <lucabru src gnome org>
Date: Tue Jan 3 11:29:04 2012 +0100
Cache wrapper methods
codegen/valagvarianttransformer.vala | 44 ++++++++++++++++++++++++----------
1 files changed, 31 insertions(+), 13 deletions(-)
---
diff --git a/codegen/valagvarianttransformer.vala b/codegen/valagvarianttransformer.vala
index e2b71c7..84a9cf5 100644
--- a/codegen/valagvarianttransformer.vala
+++ b/codegen/valagvarianttransformer.vala
@@ -46,6 +46,7 @@ public class Vala.GVariantTransformer : CodeTransformer {
};
CodeBuilder b;
+ HashMap<string, CodeNode> wrapper_cache = new HashMap<string, CodeNode> (str_hash, str_equal);
bool get_basic_type_info (string signature, out BasicTypeInfo basic_type) {
foreach (BasicTypeInfo info in basic_types) {
@@ -155,28 +156,45 @@ public class Vala.GVariantTransformer : CodeTransformer {
return ret;
}
- Method wrapper_method (DataType return_type) {
+ bool get_cached_wrapper (string key, out CodeNode node) {
+ node = wrapper_cache.get (key);
+ return node != null;
+ }
+
+ void add_cached_wrapper (string key, CodeNode node) {
+ wrapper_cache.set (key, node);
+ }
+
+ bool wrapper_method (DataType return_type, string cache_key, out Method m) {
+ CodeNode n;
+ if (get_cached_wrapper (cache_key, out n)) {
+ m = (Method) n;
+ return true;
+ }
var name = CodeNode.get_temp_name ().replace (".", "");
name = "_vala_func_"+name;
- var m = new Method (name, return_type, b.source_reference);
+ m = new Method (name, return_type, b.source_reference);
context.root.add_method (m);
m.access = SymbolAccessibility.PRIVATE;
- return m;
+ add_cached_wrapper (cache_key, m);
+ return false;
}
Expression serialize_array (ArrayType array_type, Expression array_expr) {
- var m = wrapper_method (data_type ("GLib.Variant", true));
- m.add_parameter (new Parameter ("array", copy_type (array_type, false), b.source_reference));
- b.push_method (m);
+ Method m;
+ if (!wrapper_method (data_type ("GLib.Variant", true), "gvariant_serialize_array "+array_type.to_string(), out m)) {
+ m.add_parameter (new Parameter ("array", copy_type (array_type, false), b.source_reference));
+ b.push_method (m);
+
+ string[] indices = new string[array_type.rank];
+ for (int dim=1; dim <= array_type.rank; dim++) {
+ indices[dim-1] = b.add_temp_declaration (null, new IntegerLiteral ("0"));
+ }
+ b.add_return (serialize_array_dim (array_type, 1, indices, "array"));
- string[] indices = new string[array_type.rank];
- for (int dim=1; dim <= array_type.rank; dim++) {
- indices[dim-1] = b.add_temp_declaration (null, new IntegerLiteral ("0"));
+ b.pop_method ();
+ check (m);
}
- b.add_return (serialize_array_dim (array_type, 1, indices, "array"));
-
- b.pop_method ();
- check (m);
var call = (MethodCall) expression (m.name+"()");
call.add_argument (array_expr);
return call;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]