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;
41 function BuildLists () {
44 var ns_list = [ 'Gtk' ] ; //NameSpace.namespaces();
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.");
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;
60 ns['interfaces'].forEach( function(n) {
61 var odata =NameSpace.factory('Interface', ns_name, n);
62 classes[odata.alias] = odata;
67 print("Looping throught namespaces");
69 var implementations = {};
73 for (cls in classes) {
74 var odata = classes[cls];
77 implementations[odata.alias] = odata.titleType == 'Class' ? odata.childClasses : odata.implementedBy;
78 //print(JSON.stringify(odata.methods,null,4));
79 odata.methods.forEach(function(m) {
81 m.params.forEach(function(p) {
83 if (!p.type || typeof(classes[p.type]) == 'undefined') {
87 var full_method_name = p.ns + '.' + p.type;
88 print(full_method_name );
90 if (allmethods.indexOf(full_method_name) < 0) {
91 allmethods.push(full_method_name);
94 if (typeof(methods[cls][full_method_name]) == 'undefined') {
95 methods[cls][full_method_name] = [];
97 if (methods[cls][full_method_name].indexOf(m.name) > -1) {
100 methods[cls][full_method_name].push(m.name);
105 //for(method in odata.methods) {
106 // print(method.name);
111 this.methods = methods;
112 this.allmethods = methods;
113 this.implementations = implementations;
114 print(JSON.stringify(methods,null,4));
115 //print(JSON.stringify(implementations,null,4));
120 // we now have a list of classes / methods that can be used..
121 // we now need a ui to flag stuff as "don't bother with"