X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fregistry.c;h=293598fe78723445c5a8ed875760c827cfa21217;hb=021a96c1b603981f1ec214efaa59a049ed7e709a;hp=b43a5ddf8c612185d93a8821795d90a7ec0e2395;hpb=700f136a477a84d5a13fb1f8d6cb51f81e158328;p=swftools.git diff --git a/lib/as3/registry.c b/lib/as3/registry.c index b43a5dd..293598f 100644 --- a/lib/as3/registry.c +++ b/lib/as3/registry.c @@ -80,6 +80,7 @@ type_t memberinfo_type = { // ------------------------- constructors -------------------------------- +#define AVERAGE_NUMBER_OF_MEMBERS 8 classinfo_t* classinfo_register(int access, char*package, char*name) { NEW(classinfo_t,c); @@ -87,8 +88,17 @@ classinfo_t* classinfo_register(int access, char*package, char*name) c->package = package; c->name = name; dict_put(classes, c, c); + dict_init(&c->members,AVERAGE_NUMBER_OF_MEMBERS); return c; } +memberinfo_t* memberinfo_register(classinfo_t*cls, const char*name, U8 kind) +{ + NEW(memberinfo_t,m); + m->kind = kind; + m->name = strdup(name); + dict_put(&cls->members, name, m); + return m; +} // --------------- builtin classes (from builtin.c) ---------------------- @@ -113,6 +123,10 @@ 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; } +memberinfo_t* registry_findmember(classinfo_t*cls, const char*name) +{ + return (memberinfo_t*)dict_lookup(&cls->members, name); +} void registry_fill_multiname(multiname_t*m, namespace_t*n, classinfo_t*c) { m->type = QNAME;