X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fregistry.h;h=dce8efbd77466f1b44e7800b5e5bbb40f7d340a4;hb=eeacf7371f20fb0413e8964bbeea6f682ad47742;hp=c4a82818440325f4de112d430ec6979a37ea096d;hpb=64b820f5aa8bb7f2df9f297e325434f043e2d25b;p=swftools.git diff --git a/lib/as3/registry.h b/lib/as3/registry.h index c4a8281..dce8efb 100644 --- a/lib/as3/registry.h +++ b/lib/as3/registry.h @@ -31,17 +31,23 @@ DECLARE(classinfo); DECLARE(memberinfo); DECLARE_LIST(classinfo); +/* member/class flags */ #define FLAG_PUBLIC 1 -#define FLAG_FINAL 2 -#define FLAG_PROTECTED 4 -#define FLAG_STATIC 8 -#define FLAG_DYNAMIC 16 -#define FLAG_PRIVATE 32 -#define FLAG_OVERRIDE 64 -#define FLAG_METHOD 64 -#define FLAG_INTERNAL 128 +#define FLAG_PROTECTED 2 +#define FLAG_NAMESPACE_ADOBE 4 +#define FLAG_PRIVATE 8 +#define FLAG_PACKAGEINTERNAL 16 +#define FLAG_FINAL 32 + +/* member flags */ +#define FLAG_STATIC 64 +#define FLAG_OVERRIDE 128 #define FLAG_NATIVE 256 +/* class flags */ +#define FLAG_METHOD 64 +#define FLAG_DYNAMIC 128 + struct _classinfo { U8 access; U8 flags; @@ -76,6 +82,7 @@ struct _memberinfo { classinfo_t*parent; classinfo_list_t*params; int slot; + void*deprecated; }; extern type_t classinfo_type; @@ -96,12 +103,14 @@ classinfo_t* registry_getstringclass(); classinfo_t* registry_getintclass(); classinfo_t* registry_getuintclass(); classinfo_t* registry_getnullclass(); +classinfo_t* registry_getregexpclass(); classinfo_t* registry_getbooleanclass(); classinfo_t* registry_getMovieClip(); classinfo_t* memberinfo_asclass(memberinfo_t*f); classinfo_t* registry_getclassclass(classinfo_t*a); classinfo_t* registry_findclass(const char*package, const char*name); +void registry_dumpclasses(); memberinfo_t* registry_findmember(classinfo_t*cls, const char*name, char superclasses); void registry_fill_multiname(multiname_t*m, namespace_t*n, classinfo_t*c); @@ -112,6 +121,8 @@ char registry_isclassclass(); classinfo_t* memberinfo_gettype(memberinfo_t*); +namespace_t flags2namespace(int flags, char*package); + /* convenience functions */ #define sig2mname(x) classinfo_to_multiname(x) #define TYPE_ANY registry_getanytype() @@ -128,6 +139,8 @@ classinfo_t* memberinfo_gettype(memberinfo_t*); #define TYPE_IS_BOOLEAN(t)((t) == registry_getbooleanclass()) #define TYPE_STRING registry_getstringclass() #define TYPE_IS_STRING(t) ((t) == registry_getstringclass()) +#define TYPE_REGEXP registry_getregexpclass() +#define TYPE_IS_REGEXP(t) ((t) == registry_getregexpclass()) #define TYPE_OBJECT registry_getobjectclass()