X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fabc.h;h=d58f2d77c4195f0768a52e31831edd655a6b442e;hb=639ac6b9f7a89f10d02c5d9ef41bca3bad4eaf2b;hp=9bf53924a1862637e2e387a18506b14caecf58c8;hpb=d611fcd8cfa36238cfaff6e8fe04b31e3159f693;p=swftools.git diff --git a/lib/as3/abc.h b/lib/as3/abc.h index 9bf5392..d58f2d7 100644 --- a/lib/as3/abc.h +++ b/lib/as3/abc.h @@ -108,6 +108,9 @@ struct _trait { constant_t*value; }; +trait_t*trait_new_method(trait_list_t**traits, multiname_t*name, abc_method_t*m); +trait_t*trait_new_member(trait_list_t**traits, multiname_t*type, multiname_t*name, constant_t*v); + #define CLASS_SEALED 1 #define CLASS_FINAL 2 #define CLASS_INTERFACE 4 @@ -135,6 +138,9 @@ struct _abc_class { int index; //filled in during writing }; +void abc_method_init(abc_method_t*m, abc_file_t*file, multiname_t*returntype, char body); +abc_method_t* abc_method_new(abc_file_t*file, multiname_t*returntype, char body); + abc_class_t* abc_class_new(abc_file_t*file, multiname_t*classname, multiname_t*superclass); abc_class_t* abc_class_new2(abc_file_t*file, char*classname, char*superclass); void abc_class_sealed(abc_class_t*c); @@ -143,7 +149,7 @@ void abc_class_interface(abc_class_t*c); void abc_class_protectedNS(abc_class_t*c, char*namespace); void abc_class_add_interface(abc_class_t*c, multiname_t*interface); -trait_t* abc_class_find_slotid(abc_class_t*c, int slotid); +trait_t* traits_find_slotid(trait_list_t*traits, int slotid); abc_method_t* abc_class_getconstructor(abc_class_t*cls, multiname_t*returntype); abc_method_t* abc_class_getstaticconstructor(abc_class_t*cls, multiname_t*returntype); @@ -192,7 +198,8 @@ typedef struct _abc_script { } abc_script_t; abc_method_t* abc_nullmethod(abc_file_t*file); -abc_script_t* abc_initscript(abc_file_t*file, multiname_t*returntype); +abc_script_t* abc_initscript(abc_file_t*file); +trait_t*abc_initscript_addClassTrait(abc_script_t*script, multiname_t*multiname, abc_class_t*cls); #define __