From 13717837dd8c7a9a71564cd0abe8ec00687d72bf Mon Sep 17 00:00:00 2001 From: kramm Date: Fri, 2 Jan 2009 19:53:48 +0000 Subject: [PATCH] findmember now recursively scans superclasses, memberinfo now has a parent --- lib/as3/registry.c | 27 +++++++++++++++++++++++++-- lib/as3/registry.h | 3 ++- 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/lib/as3/registry.c b/lib/as3/registry.c index f160b5c..9ce74a1 100644 --- a/lib/as3/registry.c +++ b/lib/as3/registry.c @@ -119,6 +119,7 @@ memberinfo_t* memberinfo_register(classinfo_t*cls, const char*name, U8 kind) NEW(memberinfo_t,m); m->kind = kind; m->name = strdup(name); + m->parent = cls; dict_put(&cls->members, name, m); return m; } @@ -146,9 +147,31 @@ 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) +memberinfo_t* registry_findmember(classinfo_t*cls, const char*name, char recursive) { - return (memberinfo_t*)dict_lookup(&cls->members, name); + if(!recursive) { + return (memberinfo_t*)dict_lookup(&cls->members, name); + } + /* look at classes directly extended by this class */ + memberinfo_t*m = 0; + classinfo_t*s = cls; + while(s) { + m = (memberinfo_t*)dict_lookup(&s->members, name); + if(m) return m; + s = s->superclass; + } + /* look at interfaces, and parent interfaces */ + int t=0; + while(cls->interfaces[t]) { + classinfo_t*s = cls->interfaces[t]; + while(s) { + m = (memberinfo_t*)dict_lookup(&s->members, name); + if(m) return m; + s = s->superclass; + } + } + return 0; + } void registry_fill_multiname(multiname_t*m, namespace_t*n, classinfo_t*c) { diff --git a/lib/as3/registry.h b/lib/as3/registry.h index 0fb84a3..b92c6a2 100644 --- a/lib/as3/registry.h +++ b/lib/as3/registry.h @@ -62,6 +62,7 @@ struct _memberinfo { classinfo_t*return_type; classinfo_t*type; }; + classinfo_t*parent; classinfo_list_t*params; int slot; }; @@ -89,7 +90,7 @@ classinfo_t* memberinfo_asclass(memberinfo_t*f); classinfo_t* registry_getclassclass(classinfo_t*a); classinfo_t* registry_findclass(const char*package, const char*name); -memberinfo_t* registry_findmember(classinfo_t*cls, const char*name); +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); multiname_t* classinfo_to_multiname(classinfo_t*cls); -- 1.7.10.4