X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fregistry.c;h=069f923a18491da4cff4713958b1627123cd4b80;hb=ff7bd81590dc66a135f8ac513d0fb9d5c4c95bf9;hp=092491001e24bcae9661960cd24f6bdf0e2379f2;hpb=e07b2da57bc9c3da3c382b9edd5a53501d86976d;p=swftools.git diff --git a/lib/as3/registry.c b/lib/as3/registry.c index 0924910..069f923 100644 --- a/lib/as3/registry.c +++ b/lib/as3/registry.c @@ -103,7 +103,7 @@ classinfo_t* registry_getclassclass(classinfo_t*a) { return c; } - NEW(classinfo_t,c); + classinfo_t*c = rfx_calloc(sizeof(classinfo_t)+sizeof(classinfo_t*)); c->access = ACCESS_PUBLIC; c->package = ""; c->name = "Class"; @@ -150,6 +150,7 @@ classinfo_t* registry_safefindclass(const char*package, const char*name) assert(c); return c; } + classinfo_t* registry_findclass(const char*package, const char*name) { assert(classes); @@ -161,6 +162,20 @@ classinfo_t* registry_findclass(const char*package, const char*name) printf("%s.%s->%08x (%s.%s)\n", package, name, c, c->package, c->name);*/ return c; } +void registry_dumpclasses() +{ + int t; + for(t=0;thashsize;t++) { + dictentry_t*e = classes->slots[t]; + while(e) { + dictentry_t*next = e->next; + classinfo_t*i = (classinfo_t*)e->key; + printf("%s.%s\n", i->package, i->name); + e = e->next; + } + } +} + memberinfo_t* registry_findmember(classinfo_t*cls, const char*name, char recursive) { if(!recursive) { @@ -219,7 +234,7 @@ classinfo_t* memberinfo_asclass(memberinfo_t*f) { return c; } - NEW(classinfo_t,c); + classinfo_t*c = rfx_calloc(sizeof(classinfo_t)+sizeof(classinfo_t*)); c->access = ACCESS_PUBLIC; c->package = ""; c->name = "Function";