- var ns_list = [ 'Gtk' , 'Gdk', 'Pango', 'GtkSource', 'WebKit', 'Vte'] ; //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.
//titleType : odata.titleType,
extendsClasses : [],
can_contain : [],
+ can_contain_using: [],
// can_be_added_to : [],
//using_methods : { },
can_be_added_to_as : {}
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;
//}
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) {
//}
- 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]=[];
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 ar = parent.split('.')
+ var cls =ar[1];
+ var ns =ar[0];
+
+ /*
+ 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;
+ }
+ */
+
+
+ try {
+ var x = new imports.gi[ns][cls]();
+ } catch(e) {
+ print("TRY ctor: " + parent );
+ print(e.toString());
+ return false;
+ }
+
+ //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"));
+
+
+ return GObject.type_is_a(match, ct ) ? true : false;
+
+ }
+
+ 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<mts.length;i++) {
+ var m = mts[i].split(':');
+ if (!is_a(child,m[0])) {
+ continue;
+
+ }
+ if (verifyUsageMethod(parent,child,mts[i])) {
+ return true;
+ }
+ }
+ return false;
+
+
+ }
+
+
+
+
+
+
// basically anything that is a Gtk.Container, should be available at the top.
/*
left:
tops[ch] = [ '*top' ];
});
for(var cls in methods) {
+ if (cls =='Gtk.Builder') {
+ continue;
+ }
for (var par in methods[cls].can_be_added_to_as) {
+
+ if (!verifyUsage(par,cls)) {
+ continue;
+ }
+
if (typeof(usage[par]) == 'undefined') {
usage[par] = [];
}
+
+
+
usage[par].pushUnique(cls);
if (typeof(tops[cls]) == 'undefined') {
tops[cls] = [];
tops[cls].pushUnique(par);
}
}
+
+
function canTop(cls, rec) {
+
rec = rec || 0;
+ //print('CANTOP: ' + cls + ' =' + rec);
if (rec > 5) {
- print('SKIP : ' + cls);
+ // print('SKIP : ' + cls);
}
if (typeof(tops[cls]) == 'undefined') {
return false;
if (cls == tops[cls][i]) {
continue;
}
- if (canTop(cls, rec+1)) {
+ if (canTop(tops[cls][i], rec+1)) {
return true;
}
}
return false;
-
}
+ var lefts = {};
+ for(var par in usage) {
+ var left = usange[par].join(',');
+ if (typeof(lefts[left]) == 'undefined') {
+ lefts[left] = [];
+ }
+ lefts.push(par);
+ }
+ print (JSON.stringify(lefts,null,4));
+ Seed.exit();
+
+
+
+
+ print (JSON.stringify(usage,null,4));
var nusage = {};
+ var usage_left = {};
for(var par in usage) {
// see if the parent can be added to something.
if (!canTop(par)) {
continue;
}
+ var duped = false;
+ for(var dupe in usage) {
+ if (par != dupe
+ && typeof(nusage[dupe]) != 'undefined'
+ && usage[par].join(',') == usage[dupe].join(',')) {
+ duped = true;
+
+ if (typeof(usage_left[dupe]) == 'undefined') {
+ usage_left[dupe] = [];
+ }
+ //print(par+ ' is a dupe of ' + dupe);
+ usage_left[dupe].pushUnique(par);
+ break;
+ }
+ }
+ if (duped) {
+ continue;
+ }
nusage[par] = usage[par];
}
-
- print(JSON.stringify(nusage,null,4));
-
-
-
-
+ usage = nusage;
+ //print(JSON.stringify(nusage,null,4)); Seed.exit();
+ print(JSON.stringify(methods['Gtk.TextView'],null,4));
+
+ var str = [];
+ for(var par in usage) {
+ str.push('left');
+ str.push(' ' + par);
+ if (typeof(usage_left[par]) != 'undefined') {
+ usage_left[par].forEach(function(d) { str.push(' ' + d);});
+ }
+ str.push('right');
+ usage[par].forEach(function(d) { str.push(' ' + d);});
+ str.push('');
+ }
+ print(str.join("\n"));
//print(JSON.stringify(implementations ,null,4));
/*
methods is
[a class]
- [has methods that use this object]
+ [has methods that use this object]
[list of methods of the top class..]
//print(JSON.stringify(implementations,null,4));
}
+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..