X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=43743900dd506cf555313aaff686e371c48e6284;hb=969fbfc948ff6aa3a4dab6e1f1117584e05397fa;hp=2dad3b7a595050a1889600da10261a7dc73646b0;hpb=e152e2d0180c72b4e1ff74a46fd281ce01dee634;p=app.Builder.js diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 2dad3b7a5..43743900d 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -267,10 +267,43 @@ function BuildLists () { this.methods = methods; this.allmethods = methods; this.implementations = implementations; - print(JSON.stringify(methods,null,4)); Seed.exit(); + //print(JSON.stringify(methods,null,4)); Seed.exit(); // dump out a usage file.. - + function verifyUsageMethod(parent,child,method) + { + // currently only verifies add on container. + 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; + + } function is_a(cls, instance_of) { return methods[cls].extendsClasses.indexOf(instance_of) > -1; @@ -279,14 +312,14 @@ function BuildLists () { function verifyUsage(parent,child) { // find all the methods that child can be added to parent. - var methods = methods[parent].can_contain_using; - for(var i =0;i