X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=43743900dd506cf555313aaff686e371c48e6284;hb=969fbfc948ff6aa3a4dab6e1f1117584e05397fa;hp=945774225cc4a19c7bfd5dceac1a68f6cf7aa5e7;hpb=83c96747963a72cfa1a06623e161a1a90c637f41;p=app.Builder.js diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 945774225..43743900d 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -276,9 +276,31 @@ function BuildLists () { if (method !='Gtk.Container:add') { return true; } + var cls = parent.split('.').pop(); + + + 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; + } + + //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()); + // get the Gtype for the child? + + return true; } @@ -342,13 +364,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') { @@ -381,6 +405,10 @@ right: return false; } + + + + print (JSON.stringify(usage,null,4)); var nusage = {}; var usage_left = {}; for(var par in usage) { @@ -459,7 +487,7 @@ right: //print(JSON.stringify(implementations,null,4)); } -Gtk.init(Seed.argv); +imports.gi.Gtk.init(Seed.argv); BuildLists(); // we now have a list of classes / methods that can be used..