X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=2275f78236548b47ba6eb2c51fe593233899f83e;hb=296b806cddc41184c9725706b2d0ee2e6280b858;hp=b9f81534b642f90ce387357c97025777afee1f0d;hpb=cf00e062beb8ca6e253a906c12ee72b1ff4137b8;p=app.Builder.js diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index b9f81534b..2275f7823 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -276,28 +276,44 @@ function BuildLists () { if (method !='Gtk.Container:add') { return true; } - - var cls = parent.split('.').pop(); + var ar = parent.split('.') + var cls =ar[1]; + var ns =ar[0]; - + /* if (parent == 'Gtk.Bin' || methods['Gtk.Bin'].extendsClasses.indexOf(parent) > -1) { return false; } if (['GtkSource.CompletionInfo', 'Gtk.MenuShell', - 'Gtk.SourceView', // ??? nothing can be added to it? + 'GtkSource.View', // ??? nothing can be added to it? + 'WebKit.WebView', // ??? nothing can be added to it? 'GtkClutter.Embed' ].indexOf(parent) > -1) { return false; } + */ - print("TRY ctor: " + parent ); - - var x = new imports.gi.Gtk[cls](); - print("TRY child type: " + parent); - print(parent + " : says children are of type : " + x.child_type()); - return true; + try { + var x = new imports.gi[ns][cls](); + } catch(e) { + print("TRY ctor: " + parent ); + print(e.toString()); + return false; + } + + //print("TRY child type: " + parent); + 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 GObject.type_is_a(match, ct ) ? true : false; } @@ -360,13 +376,15 @@ right: } for (var par in methods[cls].can_be_added_to_as) { + if (!verifyUsage(par,cls)) { + continue; + } + if (typeof(usage[par]) == 'undefined') { usage[par] = []; } - if (!verifyUsage(par,cls)) { - continue; - } + usage[par].pushUnique(cls); if (typeof(tops[cls]) == 'undefined') { @@ -375,6 +393,8 @@ right: tops[cls].pushUnique(par); } } + + function canTop(cls, rec) { rec = rec || 0; @@ -397,8 +417,22 @@ 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.exit(); + + + + + print (JSON.stringify(usage,null,4)); var nusage = {}; var usage_left = {}; for(var par in usage) { @@ -447,7 +481,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..] @@ -478,6 +512,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..