tools/build_gtk_tree.js
[app.Builder.js] / tools / build_gtk_tree.js
1 //<script type="text/javascript">
2
3
4 /**
5  * usage:
6  * 
7  * this.data = new BuildLists();
8  * 
9  * 
10  * 
11  * 
12  * 
13  */
14 // see if we can build the insertion tree for gtk - using introspection
15
16 // it should build the tree of feasible insertions, then we will have to manually prune it..
17
18 // it needs to know
19 // a) what the inherited types are
20 // b) what methods are available for each type, that include a reference to another type..
21
22 // let's start with types.. 
23 GIRepository = imports.gi.GIRepository;
24 GLib        = imports.gi.GLib;
25
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');
28
29
30 imports.searchPath.push('../../gnome.introspection-doc-generator');
31
32 XObject     = imports.XObject.XObject;
33 File        = imports.File.File; 
34  
35 // Introspecion specific..
36 NameSpace   = imports.Introspect.NameSpace.NameSpace; 
37 Link        = imports.Introspect.Link.Link; 
38
39
40
41 function BuildLists () {
42  
43
44     var ns_list = [ 'Gtk' ] ; //NameSpace.namespaces();
45      
46     ns_list = ns_list.sort();
47     // let's try and load them, so we find out early what will fail.
48     print("loading library to make sure it works.");
49
50     var classes = {};
51
52     ns_list.forEach(function(ns_name) {   
53         var  core = imports.gi[ns_name];
54         var ns = NameSpace.ns(ns_name); // fetch all the elements in namespace...
55         ns['objects'].forEach( function(n) {
56             var odata = NameSpace.factory('Class', ns_name, n);
57             classes[odata.alias] = odata;
58             
59         });
60         ns['interfaces'].forEach( function(n) {
61              var odata =NameSpace.factory('Interface', ns_name, n);
62             classes[odata.alias] = odata;
63         });
64     });
65
66
67     print("Looping throught namespaces");
68     var ns_idx = [];
69     var implementations = {};
70     
71     var methods = {};
72     var allmethods = [];  
73     
74     for (cls in classes) {
75         
76         methods[cls] = {
77             can_contain : [],
78           //  can_be_added_to : [],
79             using_methods : { },
80             can_be_added_to_as : {}
81         };
82         var odata = classes[cls];
83         
84         implementations[odata.alias] = odata.titleType == 'Class' ? odata.childClasses :  odata.implementedBy;
85         
86     }
87     for (cls in classes) {
88         var odata = classes[cls];
89         
90         print(cls);
91         //print(JSON.stringify(odata.methods,null,4));
92         odata.methods.forEach(function(m) {
93             
94             
95             
96             
97              if (!m.name.match(/^(add|pack)/)) {
98                 return;
99             }
100             print(JSON.stringify(m,null,4));
101             m.params.forEach(function(p) {
102                  
103                 if (!p.type || typeof(classes[p.type]) == 'undefined') {
104                     return;
105                 }
106                 // now add it..
107                 //print(JSON.stringify(p));Seed.exit();
108                 var addable_type = p.type;
109                 if (addable_type.indexOf('.') < 0) {
110                     addable_type = p.memberOf + '.' + p.type;
111                 }
112                 
113                 
114                
115                 
116                 //print(full_method_name );
117                 
118                 //if (allmethods.indexOf(full_method_name) < 0) {
119                 //    allmethods.push(full_method_name);
120                 //}
121                 if (methods[cls].can_contain.indexOf(addable_type) < 0) {
122                     methods[cls].can_contain.push(addable_type);
123                 }
124                 methods[cls].using_methods[m.name] = m.params;
125                 
126                 //if (methods[addable_type].can_be_added_to.indexOf(cls) < 0) { 
127                 //    methods[addable_type].can_be_added_to.push(cls);
128                 //}
129                 var add = {}
130                 add[m.memberOf] = m.name;
131                 
132                 if (typeof(methods[addable_type].can_be_added_to_as[cls]) == 'undefined') {
133                     methods[addable_type].can_be_added_to_as[cls]=[];
134                 }
135                 methods[addable_type].can_be_added_to_as[cls].push( add );
136                 implementations[cls].forEach(function(imp) {
137                     if (typeof(methods[addable_type].can_be_added_to_as[imp]) == 'undefined') {
138                         methods[addable_type].can_be_added_to_as[imp] = [];
139                     }
140                     
141                     methods[addable_type].can_be_added_to_as[imp].push(add);
142                 });
143                 
144                 return;
145             /*
146                     methods[cls].using_methods[m.name] = {};
147                 }
148                 
149                 
150                 if (typeof(methods[cls][full_method_name]) == 'undefined') {
151                     methods[cls][full_method_name] = [];
152                 }
153                 if (methods[cls][full_method_name].indexOf(m.name) > -1) {
154                     return;
155                 }
156                 methods[cls][full_method_name].push(m.name);
157             */  
158             });
159             
160         });
161         //for(method in odata.methods) {
162         //    print(method.name);
163         //}
164         
165         
166     }
167     /*
168     // fill in the added to list..
169     for(var p in methods ) {
170         var odata = methods[p];
171         
172         methods[p].can_be_added_to.forEach(function(c) {
173             methods[p].can_be_added_to_as[c]=c;
174             implementations[c].forEach(function(imp) {
175                 methods[p].can_be_added_to_as[imp]=c;
176             });
177         });
178         
179         
180     }
181     */
182     // now do the reverese 'can be added to'
183     
184     
185     
186     this.methods = methods;
187     this.allmethods = methods;
188     this.implementations = implementations;
189     print(JSON.stringify(methods,null,4));
190     
191     //print(JSON.stringify(implementations ,null,4));
192     /*
193       methods is
194         [a class]
195             [has methods that use this object]
196                 [list of methods of the top class..]
197      
198      
199       So let's pick one..
200         TOP        ARRAY  2ND
201         Gtk.Button.add(Gtk.Widget) <<
202         
203         
204         What we need:
205         
206         A) what can this dragged element be dropped onto.
207         eg. list of parents.
208         - can_be_added_to_as (left)
209         
210         
211         
212         B) what method is available when this object is dropped onto this one.
213         
214         - get the right hand side?
215         
216         
217      
218      
219     */
220     
221     
222     //print(JSON.stringify(implementations,null,4));
223     
224 }
225 BuildLists();
226
227 // we now have a list of classes / methods that can be used..
228 // we now need a ui to flag stuff as "don't bother with"
229
230