1 //<script type="text/javascript">
7 * this.data = new BuildLists();
14 // see if we can build the insertion tree for gtk - using introspection
16 // it should build the tree of feasible insertions, then we will have to manually prune it..
19 // a) what the inherited types are
20 // b) what methods are available for each type, that include a reference to another type..
22 // let's start with types..
23 GIRepository = imports.gi.GIRepository;
24 GLib = imports.gi.GLib;
26 // we add this in, as it appears to get lost sometimes if we set it using the ENV. variable in builder.sh
27 //GIRepository.Repository.prepend_search_path(GLib.get_home_dir() + '/.Builder/girepository-1.1');
30 imports.searchPath.push('../../gnome.introspection-doc-generator');
32 XObject = imports.XObject.XObject;
33 File = imports.File.File;
35 // Introspecion specific..
36 NameSpace = imports.Introspect.NameSpace.NameSpace;
37 Link = imports.Introspect.Link.Link;
40 Array.prototype.pushUnique = function(v) {
41 if (this.indexOf(v) < 0) {
46 function BuildLists () {
51 var ns_list = [ 'Gtk' ] ; //NameSpace.namespaces();
53 ns_list = ns_list.sort();
54 // let's try and load them, so we find out early what will fail.
55 print("loading library to make sure it works.");
59 ns_list.forEach(function(ns_name) {
60 var core = imports.gi[ns_name];
61 var ns = NameSpace.ns(ns_name); // fetch all the elements in namespace...
62 ns['objects'].forEach( function(n) {
63 var odata = NameSpace.factory('Class', ns_name, n);
64 classes[odata.alias] = odata;
67 ns['interfaces'].forEach( function(n) {
68 var odata =NameSpace.factory('Interface', ns_name, n);
69 classes[odata.alias] = odata;
72 //print(JSON.stringify(classes['Gtk.CellRenderer'] , null, 4));
73 //print(JSON.stringify(classes['Gtk.CellRenderer'].titleType, null, 4));
74 //print(JSON.stringify(classes['Gtk.CellRenderer'].childClasses, null, 4));
75 //print(JSON.stringify(classes['Gtk.CellRenderer'].implementedBy, null, 4));
79 print("Looping throught namespaces");
81 var implementations = {};
86 for (cls in classes) {
87 var odata = classes[cls];
90 //titleType : odata.titleType,
93 // can_be_added_to : [],
94 //using_methods : { },
95 can_be_added_to_as : {}
97 odata.extendsClasses.forEach(function(child) {
98 methods[cls].extendsClasses.push(child.alias);
101 implementations[odata.alias] = odata.titleType == 'Class' ? odata.childClasses : odata.implementedBy;
104 for (cls in classes) {
105 var odata = classes[cls];
110 //print(JSON.stringify(odata.methods,null,4));
111 odata.methods.forEach(function(m) {
116 if (!m.name.match(/^(add|pack)/)) {
119 //print(JSON.stringify(m,null,4));
120 m.params.forEach(function(p) {
122 if (!p.type || typeof(classes[p.type]) == 'undefined') {
126 //print(JSON.stringify(p));Seed.exit();
127 var addable_type = p.type;
128 if (addable_type.indexOf('.') < 0) {
129 addable_type = p.memberOf + '.' + p.type;
134 // in theory you can not add a window to anything.. ???
135 if ('Gtk.Window' == addable_type || methods[addable_type].extendsClasses.indexOf('Gtk.Window') > -1) {
140 //print(full_method_name );
142 //if (allmethods.indexOf(full_method_name) < 0) {
143 // allmethods.push(full_method_name);
146 methods[cls].can_contain.pushUnique(addable_type);
148 //methods[cls].using_methods[m.name] = m.params;
150 //if (methods[addable_type].can_be_added_to.indexOf(cls) < 0) {
151 // methods[addable_type].can_be_added_to.push(cls);
155 var add = m.memberOf +':'+ m.name;
157 if (typeof(methods[addable_type].can_be_added_to_as[cls]) == 'undefined') {
158 methods[addable_type].can_be_added_to_as[cls]=[];
160 methods[addable_type].can_be_added_to_as[cls].pushUnique( add );
161 implementations[cls].forEach(function(imp) {
164 if (typeof(methods[addable_type ].can_be_added_to_as[imp]) == 'undefined') {
165 methods[addable_type].can_be_added_to_as[imp] = [];
168 methods[addable_type].can_be_added_to_as[imp].pushUnique(add);
173 //print(addable_type);
174 //print(JSON.stringify(implementations[addable_type], null,4));
177 implementations[addable_type].forEach(function(addable_child) {
179 //if (addable_child == 'Gtk.AboutDialog') {
180 // print(JSON.stringify(methods[addable_child].extendsClasses,null,4));Seed.exit();
184 if (addable_child == 'Gtk.Window' ||
185 methods[addable_child].extendsClasses.indexOf('Gtk.Window') > -1) {
189 if (typeof(methods[addable_child].can_be_added_to_as[cls]) == 'undefined') {
190 methods[addable_child].can_be_added_to_as[cls]=[];
192 methods[addable_child].can_be_added_to_as[cls].pushUnique( add );
193 implementations[cls].forEach(function(imp) {
194 if (typeof(methods[addable_child ].can_be_added_to_as[imp]) == 'undefined') {
195 methods[addable_child].can_be_added_to_as[imp] = [];
198 methods[addable_child].can_be_added_to_as[imp].pushUnique(add);
217 methods[cls].using_methods[m.name] = {};
221 if (typeof(methods[cls][full_method_name]) == 'undefined') {
222 methods[cls][full_method_name] = [];
224 if (methods[cls][full_method_name].indexOf(m.name) > -1) {
227 methods[cls][full_method_name].push(m.name);
232 //for(method in odata.methods) {
233 // print(method.name);
239 // fill in the added to list..
240 for(var p in methods ) {
241 var odata = methods[p];
243 methods[p].can_be_added_to.forEach(function(c) {
244 methods[p].can_be_added_to_as[c]=c;
245 implementations[c].forEach(function(imp) {
246 methods[p].can_be_added_to_as[imp]=c;
253 // now do the reverese 'can be added to'
257 this.methods = methods;
258 this.allmethods = methods;
259 this.implementations = implementations;
260 print(JSON.stringify(methods,null,4));
262 //print(JSON.stringify(implementations ,null,4));
266 [has methods that use this object]
267 [list of methods of the top class..]
272 Gtk.Button.add(Gtk.Widget) <<
277 A) what can this dragged element be dropped onto.
279 - can_be_added_to_as (left)
283 B) what method is available when this object is dropped onto this one.
285 - get the right hand side?
293 //print(JSON.stringify(implementations,null,4));
298 // we now have a list of classes / methods that can be used..
299 // we now need a ui to flag stuff as "don't bother with"