if (method !='Gtk.Container:add') {
return true;
}
+ if (failed.indexOf(parent) > -1) {
+ return false;
+ }
- var cls = parent.split('.').pop();
+ 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;
}
].indexOf(parent) > -1) {
return false;
}
+ */
+
+
+ try {
+ var x = new imports.gi[ns][cls]();
+ } catch(e) {
+ failed.push(parent);
+ print("TRY ctor: " + parent );
+ print(JSON.stringify(e));
+ return false;
+ }
- //print("TRY ctor: " + parent );
-
- var x = new imports.gi.Gtk[cls]();
//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;
+ return GObject.type_is_a(match, ct ) ? true : false;
}
tops[cls].pushUnique(par);
}
}
+
+
function canTop(cls, rec) {
rec = rec || 0;
}
}
return false;
-
}
-
-
-
+ var lefts = {};
+ for(var par in usage) {
+ var left = usage[par].join(',');
+ if (typeof(lefts[left]) == 'undefined') {
+ lefts[left] = [];
+ }
+ lefts[left].push(par);
+ }
+ print (JSON.stringify(lefts,null,4));
+ Seed.exit();
+
+
+
+
print (JSON.stringify(usage,null,4));
var nusage = {};
var usage_left = {};
/*
methods is
[a class]
- [has methods that use this object]
+ [has methods that use this object]
[list of methods of the top class..]
}
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..