X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=88f2e3ab720566e53925d8dfc6f3bda1ed5c505e;hb=bb0e805161dd74bc7784378fd681979eca70be21;hp=8d345b12bd8546e2fff77645f274e2ff882facc7;hpb=b5268a37dc21fcf3e2356a9567bb92330e3ecb8d;p=app.Builder.js diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 8d345b12b..88f2e3ab7 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -276,19 +276,43 @@ function BuildLists () { if (method !='Gtk.Container:add') { return true; } + 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', + 'GtkSource.View', // ??? nothing can be added to it? + 'WebKit.WebView', // ??? nothing can be added to it? + 'GtkClutter.Embed' + ].indexOf(parent) > -1) { + return false; + } + */ - var cls = parent.split('.').pop(); - if (parent == 'Gtk.Bin' || methods['Gtk.Bin'].extendsClasses.indexOf(parent) > -1) { + try { + var x = new imports.gi[ns][cls](); + } catch(e) { + print("TRY ctor: " + parent ); + print(e.toString()); return false; } - print("TRY ctor: " + parent ); - - var x = new imports.gi.Gtk[cls](); - print("TRY child type: " + parent); + //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")); + - print(parent + " : says children are of type : " + x.child_type()); return true; } @@ -352,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') { @@ -391,6 +417,10 @@ right: return false; } + + + + print (JSON.stringify(usage,null,4)); var nusage = {}; var usage_left = {}; for(var par in usage) { @@ -439,7 +469,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..] @@ -470,6 +500,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..