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 ();
//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..
// 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");
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");
}
int main (string[] args) {
- var a = new VapiParser(file);
+ var a = new Palete.VapiParser( );
a.create_valac_tree();
return 0;
}
-*/
+