X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=tools%2Fbuild_gtk_tree.js;h=586c85c871e16a13278ccb9009898dfd8d125f77;hb=1ed475e61ad41a7318adc091a446aaab57204816;hp=221b0503f4406960861c4b31c71087a28d4e4139;hpb=c45564b04bb1eecbdc11330b7bfba7bf428352ff;p=app.Builder.js diff --git a/tools/build_gtk_tree.js b/tools/build_gtk_tree.js index 221b0503f..586c85c87 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. @@ -69,7 +69,12 @@ function BuildLists () { classes[odata.alias] = odata; }); }); - + //print(JSON.stringify(classes['Gtk.CellRenderer'] , null, 4)); + //print(JSON.stringify(classes['Gtk.CellRenderer'].titleType, null, 4)); + //print(JSON.stringify(classes['Gtk.CellRenderer'].childClasses, null, 4)); + //print(JSON.stringify(classes['Gtk.CellRenderer'].implementedBy, null, 4)); + + print("Looping throught namespaces"); var ns_idx = []; @@ -79,14 +84,20 @@ function BuildLists () { var allmethods = []; for (cls in classes) { - + var odata = classes[cls]; + methods[cls] = { + //titleType : odata.titleType, + extendsClasses : [], can_contain : [], + can_contain_using: [], // can_be_added_to : [], - using_methods : { }, + //using_methods : { }, can_be_added_to_as : {} }; - var odata = classes[cls]; + odata.extendsClasses.forEach(function(child) { + methods[cls].extendsClasses.push(child.alias); + }); implementations[odata.alias] = odata.titleType == 'Class' ? odata.childClasses : odata.implementedBy; @@ -94,7 +105,9 @@ function BuildLists () { for (cls in classes) { var odata = classes[cls]; - print(cls); + + + //print(cls); //print(JSON.stringify(odata.methods,null,4)); odata.methods.forEach(function(m) { @@ -104,7 +117,7 @@ function BuildLists () { if (!m.name.match(/^(add|pack)/)) { return; } - print(JSON.stringify(m,null,4)); + //print(JSON.stringify(m,null,4)); m.params.forEach(function(p) { if (!p.type || typeof(classes[p.type]) == 'undefined') { @@ -117,37 +130,97 @@ function BuildLists () { addable_type = p.memberOf + '.' + p.type; } - - - + 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 ); //if (allmethods.indexOf(full_method_name) < 0) { // allmethods.push(full_method_name); //} - if (methods[cls].can_contain.indexOf(addable_type) < 0) { - methods[cls].can_contain.push(addable_type); - } - methods[cls].using_methods[m.name] = m.params; + + 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) { // methods[addable_type].can_be_added_to.push(cls); //} - 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]=[]; } methods[addable_type].can_be_added_to_as[cls].pushUnique( add ); implementations[cls].forEach(function(imp) { - if (typeof(methods[addable_type].can_be_added_to_as[imp]) == 'undefined') { + + + if (typeof(methods[addable_type ].can_be_added_to_as[imp]) == 'undefined') { methods[addable_type].can_be_added_to_as[imp] = []; } methods[addable_type].can_be_added_to_as[imp].pushUnique(add); + + }); + // also needs to add + //print(addable_type); + //print(JSON.stringify(implementations[addable_type], null,4)); + + + implementations[addable_type].forEach(function(addable_child) { + + //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; + } + + if (typeof(methods[addable_child].can_be_added_to_as[cls]) == 'undefined') { + methods[addable_child].can_be_added_to_as[cls]=[]; + } + methods[addable_child].can_be_added_to_as[cls].pushUnique( add ); + implementations[cls].forEach(function(imp) { + if (typeof(methods[addable_child ].can_be_added_to_as[imp]) == 'undefined') { + methods[addable_child].can_be_added_to_as[imp] = []; + } + + methods[addable_child].can_be_added_to_as[imp].pushUnique(add); + + + }); + + + + }); + + + + + + + + return; /* @@ -194,8 +267,163 @@ 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(); + var x = new Gtk[cls](); + print(parent + " : says children are of type : " + x.child_type()); + + } + + 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 methods = methods[parent].can_contain_using; + for(var i =0;i