src/Palete/VapiParser.vala
[app.Builder.js] / src / Palete / VapiParser.vala
index 2f52322..ca7dda4 100644 (file)
@@ -8,20 +8,216 @@ namespace Palete {
         
 
        public class VapiParser : Vala.CodeVisitor {
+               
+               
+               
+               
+               
                Vala.CodeContext context;
                public VapiParser() {
                        base();
+                       if (Gir.cache == null) {
+                               Gir.cache =  new Gee.HashMap<string,Gir>();
+                       }
+               }
+               
+               
+               
+               public override void visit_namespace (Vala.Namespace element) 
+               {
+                       if (element == null) {
+                               
+                               return;
+                       }
+                       print("parsing namespace %s\n", element.name);
+                       if (element.name == null) {
+                               element.accept_children(this); // catch sub namespaces..
+                               return;
+                       }
+                       
+                       var g = new Gir.new_empty(element.name);
+                       Gir.cache.set(element.name, g);
+                       
+                       
+                       foreach(var c in element.get_classes()) {
+                               this.add_class(g, c);
+                       }
+                       foreach(var c in element.get_enums()) {
+                               this.add_enum(g, c);
+                       }
+                       
+                       
+                       element.accept_children(this); // catch sub namespaces..
+                       
                        
                }
-               private PackageMetaData register_package (Package package) {
-                       PackageMetaData meta_data = new PackageMetaData (package);
-                       tree.add_package (package);
-                       packages.add (meta_data);
-                       return meta_data;
+               
+               
+               public void add_enum(GirObject parent, Vala.Enum cls)
+               {
+               
+                       var c = new GirObject("Enum",   cls.name);
+                       parent.consts.set(cls.name, c);
+                       c.ns = parent.name;
+                       c.gparent = parent;
+                       
+                       foreach(var e in cls.get_values()) {
+                               var em = new GirObject("EnumMember",e.name);
+                               em.gparent = c;
+                               em.ns = c.ns;
+                               em.type  = e.type_reference == null ||  e.type_reference.data_type == null ? "" : e.type_reference.data_type.get_full_name();
+                               // unlikely to get value..
+                               //c.value = element->get_prop("value");
+                               c.consts.set(e.name,em);
+                       }
+                       
+                       
+                       
+                        
                }
-
                
-               public void checkPackage(string name)
+               
+               public void add_class(GirObject parent, Vala.Class cls)
+               {
+               
+                       var c = new GirObject("Class", parent.name + "." + cls.name);
+                       parent.classes.set(cls.name, c);
+                       c.ns = parent.name;
+                       c.parent = cls.base_class == null ? "" : cls.base_class.get_full_name() ;  // extends...
+                       c.gparent = parent;
+                       
+                       foreach(var p in cls.get_properties()) {
+                               this.add_property(c, p);
+                       }
+                       // methods...
+                       foreach(var p in cls.get_signals()) {
+                               this.add_signal(c, p);
+                       }
+                       
+                       foreach(var p in cls.get_methods()) {
+                               // skip static methods..
+                               if (p.binding != Vala.MemberBinding.INSTANCE &&
+                                       !(p is Vala.CreationMethod)
+                               ) {
+                                       continue;
+                               }
+                               
+                               this.add_method(c, p);
+                       }
+                       
+                       if (cls.base_class != null) {
+                               c.inherits.add(cls.base_class.get_full_name());
+                       }
+                       foreach(var p in cls.get_base_types()) {
+                               if (p.data_type != null) {
+                                       c.implements.add(p.data_type.get_full_name());
+                               }
+                       }
+                         
+                       
+                       
+                        
+               }
+               public void add_property(GirObject parent, Vala.Property prop)
+               {
+                       var c = new GirObject("Prop",prop.name);
+                       c.gparent = parent;
+                       c.ns = parent.ns;
+                       c.propertyof = parent.name;
+                       c.type  = prop.property_type.data_type == null ? "" : prop.property_type.data_type.get_full_name();
+                       parent.props.set(prop.name,c);
+                       
+               }
+               public void add_signal(GirObject parent, Vala.Signal sig)
+               {
+                       var c = new GirObject("Signal",sig.name);
+                       c.gparent = parent;
+                       c.ns = parent.ns;
+                       
+                       if (sig.return_type.data_type != null) {
+                               //print("creating return type on signal %s\n", sig.name);
+                               var cc = new GirObject("Return", "return-value");
+                               cc.gparent = c;
+                               cc.ns = c.ns;
+                               cc.type  =  sig.return_type.data_type.get_full_name();
+                               c.return_value = cc;
+                       }
+                       parent.signals.set(sig.name,c);
+                       
+                       var params =  sig.get_parameters() ;
+                       if (params.size < 1) {
+                               return;
+                       }
+                       var cc = new GirObject("Paramset",sig.name); // what's the name on this?
+                       cc.gparent = c;
+                       cc.ns = c.ns;
+                       c.paramset = cc;
+                       
+                       
+                       foreach(var p in params) {
+                               this.add_param(cc, p);
+                       }
+                       
+               }       
+               
+               public void add_method(GirObject parent, Vala.Method met)
+               {
+                       var n = met.name == null ? parent.name : "";
+                       var ty  = "Method";
+                       if (met is Vala.CreationMethod && n == "") {
+                               n = ".new";
+                               ty = "Ctor";
+                       }
+                       
+                       var c = new GirObject(ty,n);
+                       c.gparent = parent;
+                       c.ns = parent.ns;
+                       
+                       if (met.return_type.data_type != null) {
+                               //print("creating return type on method %s\n", met.name);
+                               var cc = new GirObject("Return", "return-value");
+                               cc.gparent = c;
+                               cc.ns = c.ns;
+                               cc.type  =  met.return_type.data_type.get_full_name();
+                               c.return_value = cc;
+                       }
+                       if (met is Vala.CreationMethod) {
+                               parent.ctors.set(c.name,c);
+                       } else {
+                               parent.methods.set(met.name,c);
+                       }
+                       
+                       var params =  met.get_parameters() ;
+                       if (params.size < 1) {
+                               return;
+                       }
+                       var cc = new GirObject("Paramset",met.name); // what's the name on this?
+                       cc.gparent = c;
+                       cc.ns = c.ns;
+                       c.paramset = cc;
+                       
+                       
+                       foreach(var p in params) {
+                               if (p.name == null) {
+                                       continue;
+                               }
+                               this.add_param(cc, p);
+                       }
+                       
+               }
+               
+               public void add_param(GirObject parent, Vala.Parameter pam)
+               {
+                       var c = new GirObject("Param",pam.name);
+                       c.gparent = parent;
+                       c.ns = parent.ns;
+                       parent.params.add(c);
+                       c.type = pam.variable_type.data_type == null ? "" : pam.variable_type.data_type.get_full_name();
+                       // this.checkParamOverride(c);   - this is an old kludge for Gir files..
+                       
+               }
+               
+               public void create_valac_tree( )
                {
                        // init context:
                        context = new Vala.CodeContext ();
@@ -50,10 +246,7 @@ namespace Palete {
                        
                        
                        //vapidirs +=  Path.get_dirname (context.get_vapi_path("glib-2.0")) ;
-                       
-                       //for(var i =0 ; i < vapidirs.length; i++) {
-                       //      valac += " --vapidir=" + vapidirs[i];
-                       //}
+                        
                                
                        
                        // or context.get_vapi_path("glib-2.0"); // should return path..
@@ -83,14 +276,17 @@ namespace Palete {
                        // default.. packages..
                        context.add_external_package ("glib-2.0"); 
                        context.add_external_package ("gobject-2.0");
+                       context.add_external_package ("gdk-3.0");
+                       context.add_external_package ("atk");
+                       context.add_external_package ("gdk-x11-3.0");
+                       context.add_external_package ("x11");
+                       
                        // user defined ones..
-                       context.add_package ("Gtk");
+                       //context.add_package ("Gtk");
                  
                        var vfile = new Vala.SourceFile (context, Vala.SourceFileType.PACKAGE, "/usr/share/vala-0.26/vapi/gtk+-3.0.vapi");
                        context.add_source_file (vfile);
-                       Package vdpkg = new Package (pkg, true, null);
-                       register_source_file (register_package (vdpkg), vfile);
-                       
+                        
                        //context.add_external_package ("libvala-0.24");
                        
                         
@@ -123,7 +319,12 @@ namespace Palete {
                         
                        Vala.CodeContext.pop ();
                         
-                       print("%s\n", valac);
+                       context.accept(this);
+                       
+                       // dump the tree for Gtk?
+                       
+                       
+                       print("%s\n", Gir.cache.get("Gtk").asJSONString());
                        print("ALL OK?\n");
                 
                }
@@ -136,10 +337,10 @@ namespace Palete {
  
 int main (string[] args) {
 
-       var a = new VapiParser(file);
+       var a = new Palete.VapiParser( );
        a.create_valac_tree();
        return 0;
 }
-*/