X-Git-Url: http://git.roojs.org/?p=app.Builder.js;a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=15472bdf16b6847563a7d74b1876d2872e0bea7f;hp=8f0f940117df14b06773e8d56dec25906dc6ae1e;hb=HEAD;hpb=95c4c7d21e903d54a477f5767d2e3dd6476e02f4 diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 8f0f94011..15472bdf1 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -269,13 +269,18 @@ function BuildLists () { this.implementations = implementations; //print(JSON.stringify(methods,null,4)); Seed.exit(); // dump out a usage file.. - + this.failed = []; + var failed = this.failed; function verifyUsageMethod(parent,child,method) { // currently only verifies add on container. if (method !='Gtk.Container:add') { return true; } + if (failed.indexOf(parent) > -1) { + return false; + } + var ar = parent.split('.') var cls =ar[1]; var ns =ar[0]; @@ -298,18 +303,23 @@ function BuildLists () { try { var x = new imports.gi[ns][cls](); } catch(e) { + failed.push(parent); print("TRY ctor: " + parent ); - print(e.toString()); + print(JSON.stringify(e)); return false; } //print("TRY child type: " + parent); - - print(parent + " : says children are of type : " + x.child_type()); + var ct = x.child_type(); + //print(parent + " : says children are of type : " + ct); // get the Gtype for the child? + var GObject = imports.gi.GObject; + var match = GObject.type_from_name(ar.join('')); + //print([match, ct]); + //print ("matching?" + (GObject.type_is_a(match, ct ) ? "YES" : "NO")); - return true; + return GObject.type_is_a(match, ct ) ? true : false; } @@ -389,6 +399,8 @@ right: tops[cls].pushUnique(par); } } + + function canTop(cls, rec) { rec = rec || 0; @@ -411,11 +423,21 @@ right: } } return false; - } - - - + var lefts = {}; + for(var par in usage) { + var left = usage[par].join(','); + if (typeof(lefts[left]) == 'undefined') { + lefts[left] = []; + } + lefts[left].push(par); + } + print (JSON.stringify(lefts,null,4)); + Seed.quit(); + + + + print (JSON.stringify(usage,null,4)); var nusage = {}; var usage_left = {}; @@ -465,7 +487,7 @@ right: /* methods is [a class] - [has methods that use this object] + [has methods that use this object] [list of methods of the top class..] @@ -496,6 +518,8 @@ right: } imports.gi.Gtk.init(Seed.argv); + +imports.gi.GtkClutter.init(Seed.argv); BuildLists(); // we now have a list of classes / methods that can be used..