X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fabc.h;h=d58f2d77c4195f0768a52e31831edd655a6b442e;hb=639ac6b9f7a89f10d02c5d9ef41bca3bad4eaf2b;hp=99392bb674bf60c13bbb4793425f25dcdabf0107;hpb=cdc086dfc22111a34d2f40308e8f066b89fc2398;p=swftools.git diff --git a/lib/as3/abc.h b/lib/as3/abc.h index 99392bb..d58f2d7 100644 --- a/lib/as3/abc.h +++ b/lib/as3/abc.h @@ -109,6 +109,7 @@ struct _trait { }; 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 @@ -137,6 +138,7 @@ 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); @@ -147,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); @@ -196,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 __