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     var methods = {};
71     var allmethods = [];  
72     
73     for (cls in classes) {
74         var odata = classes[cls];
75         methods[cls] = {
76             can_contain : [],
77             using_methods : { }
78             
79         };
80            
81         implementations[odata.alias] = odata.titleType == 'Class' ? odata.childClasses :  odata.implementedBy;  
82         //print(JSON.stringify(odata.methods,null,4));
83         odata.methods.forEach(function(m) {
84            
85             m.params.forEach(function(p) {
86                  
87                 if (!p.type || typeof(classes[p.type]) == 'undefined') {
88                     return;
89                 }
90                 // now add it..
91                 //print(JSON.stringify(p));Seed.exit();
92                 var addable_type = p.type;
93                 if (addable_type.indexOf('.') < 0) {
94                     addable_type = p.memberOf + '.' + p.type;
95                 }
96                 
97                 
98                 if (!m.name.match(/^(add|pack)/)) {
99                     return;
100                 }
101                 
102                 //print(full_method_name );
103                 
104                 //if (allmethods.indexOf(full_method_name) < 0) {
105                 //    allmethods.push(full_method_name);
106                 //}
107                 if (methods[cls].can_contain.indexOf(addable_type) < 0) {
108                     methods[cls].can_contain.push(addable_type);
109                 }
110                 methods[cls].using_methods[m.name] = m.params;
111                 
112                 return;
113             /*
114                     methods[cls].using_methods[m.name] = {};
115                 }
116                 
117                 
118                 if (typeof(methods[cls][full_method_name]) == 'undefined') {
119                     methods[cls][full_method_name] = [];
120                 }
121                 if (methods[cls][full_method_name].indexOf(m.name) > -1) {
122                     return;
123                 }
124                 methods[cls][full_method_name].push(m.name);
125             */  
126             });
127             
128         });
129         //for(method in odata.methods) {
130         //    print(method.name);
131         //}
132         
133         
134     }
135     this.methods = methods;
136     this.allmethods = methods;
137     this.implementations = implementations;
138     //print(JSON.stringify(methods,null,4));
139     print(JSON.stringify(implementations ,null,4));
140     /*
141       methods is
142         [a class]
143             [has methods that use this object]
144                 [list of methods of the top class..]
145      
146      
147       So let's pick one..
148         TOP        ARRAY  2ND
149         Gtk.Button.add(Gtk.Widget) <<
150      
151      
152     */
153     
154     
155     //print(JSON.stringify(implementations,null,4));
156     
157 }
158 BuildLists();
159
160 // we now have a list of classes / methods that can be used..
161 // we now need a ui to flag stuff as "don't bother with"
162
163