X-Git-Url: http://git.roojs.org/?p=app.Builder.js;a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=8d9adc822b3a6d0c532e88bfed0344c34ad69290;hp=83bdeade8faf172c832ceb48b8565c05de186c56;hb=372d185cfbe9ac31e2812ffe67f2dda59b976d3b;hpb=97434321be90468894fafb221db412b974f79650 diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 83bdeade8..8d9adc822 100644 --- a/tools/build_gtk_tree.js +++ b/tools/build_gtk_tree.js @@ -48,7 +48,7 @@ function BuildLists () { - var ns_list = [ 'Gtk' ] ; //NameSpace.namespaces(); + var ns_list = [ 'Gtk' , 'Gdk', 'Pango', 'GtkSource', 'WebKit', 'Vte', 'GtkClutter'] ; //NameSpace.namespaces(); ns_list = ns_list.sort(); // let's try and load them, so we find out early what will fail. @@ -90,6 +90,7 @@ function BuildLists () { //titleType : odata.titleType, extendsClasses : [], can_contain : [], + can_contain_using: [], // can_be_added_to : [], //using_methods : { }, can_be_added_to_as : {} @@ -129,12 +130,20 @@ function BuildLists () { addable_type = p.memberOf + '.' + p.type; } - - - // in theory you can not add a window to anything.. ??? - if (methods[addable_type].extendsClasses.indexOf('Gtk.Window') > -1) { + if (m.memberOf == 'Gtk.Buildable') { + return; + } + //"Gtk.Widget:add_accelerator", + //"Gtk.Widget:add_device_events" + + if (m.name.match(/^(add_mnemonic_label|add_accelerator|add_device_events)$/)) { return; } + + // in theory you can not add a window to anything.. ??? + //if ('Gtk.Window' == addable_type || methods[addable_type].extendsClasses.indexOf('Gtk.Window') > -1) { + // return; + //} // //print(full_method_name ); @@ -144,7 +153,9 @@ function BuildLists () { //} methods[cls].can_contain.pushUnique(addable_type); - + var add = m.memberOf +':'+ m.name; + + methods[cls].can_contain_using.pushUnique(add); //methods[cls].using_methods[m.name] = m.params; //if (methods[addable_type].can_be_added_to.indexOf(cls) < 0) { @@ -152,7 +163,6 @@ function BuildLists () { //} - var add = m.memberOf +':'+ m.name; if (typeof(methods[addable_type].can_be_added_to_as[cls]) == 'undefined') { methods[addable_type].can_be_added_to_as[cls]=[]; @@ -170,13 +180,19 @@ function BuildLists () { }); // also needs to add - print(addable_type); - print(JSON.stringify(implementations[addable_type], null,4)); - /* + //print(addable_type); + //print(JSON.stringify(implementations[addable_type], null,4)); + implementations[addable_type].forEach(function(addable_child) { - if (addable_child == 'Gtk.Window') { + //if (addable_child == 'Gtk.AboutDialog') { + // print(JSON.stringify(methods[addable_child].extendsClasses,null,4));Seed.exit(); + + //} + + if (addable_child == 'Gtk.Window' || + methods[addable_child].extendsClasses.indexOf('Gtk.Window') > -1) { return; } @@ -198,8 +214,7 @@ function BuildLists () { }); - - */ + @@ -252,8 +267,182 @@ function BuildLists () { this.methods = methods; this.allmethods = methods; this.implementations = implementations; - print(JSON.stringify(methods,null,4)); + //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? + '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; + + } + + function is_a(cls, instance_of) { + return methods[cls].extendsClasses.indexOf(instance_of) > -1; + } + + function verifyUsage(parent,child) + { + // find all the methods that child can be added to parent. + var mts = methods[parent].can_contain_using; + for(var i =0;i