as3: various bugfixes
[swftools.git] / lib / as3 / registry.h
1 /* registry.h
2
3    Routines for compiling Flash2 AVM2 ABC Actionscript
4
5    Extension module for the rfxswf library.
6    Part of the swftools package.
7
8    Copyright (c) 2008 Matthias Kramm <kramm@quiss.org>
9  
10    This program is free software; you can redistribute it and/or modify
11    it under the terms of the GNU General Public License as published by
12    the Free Software Foundation; either version 2 of the License, or
13    (at your option) any later version.
14
15    This program is distributed in the hope that it will be useful,
16    but WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18    GNU General Public License for more details.
19
20    You should have received a copy of the GNU General Public License
21    along with this program; if not, write to the Free Software
22    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
23
24 #ifndef __abc_registry_h__
25 #define __abc_registry_h__
26
27 #include "pool.h"
28
29 DECLARE(slotinfo);
30 DECLARE(classinfo);
31 DECLARE(memberinfo);
32 DECLARE(methodinfo);
33 DECLARE(unresolvedinfo);
34 DECLARE(varinfo);
35 DECLARE_LIST(classinfo);
36 DECLARE_LIST(slotinfo);
37
38 /* member/class flags */
39 #define FLAG_FINAL 1
40 #define FLAG_BUILTIN 128
41
42 /* member flags */
43 #define FLAG_STATIC 2
44 #define FLAG_OVERRIDE 8
45 #define FLAG_NATIVE 16
46 #define FLAG_CONST 32
47
48 /* class flags */
49 #define FLAG_DYNAMIC 8
50 #define FLAG_INTERFACE 16
51
52 #define INFOTYPE_VAR 1
53 #define INFOTYPE_METHOD 2
54 #define INFOTYPE_CLASS 3
55 #define INFOTYPE_UNRESOLVED 4
56 #define SUBTYPE_GET 1
57 #define SUBTYPE_SET 2
58 #define SUBTYPE_GETSET 3
59
60 struct _slotinfo {
61     U8 kind,subtype,flags,access;
62     const char*package;
63     const char*name;
64     int slot;
65 };
66 struct _unresolvedinfo {
67     U8 kind,subtype,flags,access;
68     const char*package;
69     const char*name;
70     int slot;
71     namespace_list_t*nsset;
72 };
73 struct _classinfo {
74     U8 kind,subtype,flags,access;
75     const char*package;
76     const char*name;
77     int slot;
78     classinfo_t*superclass;
79     dict_t members;
80     void*data; //TODO: get rid of this- parser.y should pass type/value/code triples around
81     classinfo_t*interfaces[];
82 };
83 struct _memberinfo {
84     U8 kind,subtype,flags,access;
85     const char*package;
86     const char*name;
87     int slot;
88     union {
89         classinfo_t*return_type;
90         classinfo_t*type;
91     };
92     classinfo_t*parent;
93 };
94 struct _methodinfo /*extends memberinfo*/ {
95     U8 kind,subtype,flags,access;
96     const char*package;
97     const char*name;
98     int slot;
99     classinfo_t*return_type;
100     classinfo_t*parent;
101     classinfo_list_t*params;
102 };
103 struct _varinfo /*extends memberinfo*/ {
104     U8 kind,subtype,flags,access;
105     const char*package;
106     const char*name;
107     int slot;
108     classinfo_t*type;
109     classinfo_t*parent;
110     constant_t*value;
111 };
112
113 extern type_t memberinfo_type;
114 extern type_t slotinfo_type;
115 char slotinfo_equals(slotinfo_t*c1, slotinfo_t*c2);
116
117 void registry_init();
118         
119 classinfo_t* classinfo_register(int access, const char*package, const char*name, int num_interfaces);
120 methodinfo_t* methodinfo_register_onclass(classinfo_t*cls, U8 access, const char*ns, const char*name);
121 methodinfo_t* methodinfo_register_global(U8 access, const char*package, const char*name);
122 varinfo_t* varinfo_register_onclass(classinfo_t*cls, U8 access,  const char*ns, const char*name);
123 varinfo_t* varinfo_register_global(U8 access, const char*package, const char*name);
124
125 slotinfo_t* registry_resolve(slotinfo_t*s);
126 void registry_resolve_all();
127
128 slotinfo_t* registry_find(const char*package, const char*name);
129 void registry_dump();
130 memberinfo_t* registry_findmember(classinfo_t*cls, const char*ns, const char*name, char superclasses);
131 memberinfo_t* registry_findmember_nsset(classinfo_t*cls, namespace_list_t*ns, const char*name, char superclasses);
132
133 void registry_fill_multiname(multiname_t*m, namespace_t*n, slotinfo_t*c);
134 #define MULTINAME(m,x) \
135     multiname_t m;\
136     namespace_t m##_ns;\
137     (x)->package; \
138     registry_fill_multiname(&m, &m##_ns, (slotinfo_t*)(x));
139                     
140 multiname_t* classinfo_to_multiname(slotinfo_t*cls);
141
142 char registry_isfunctionclass();
143 char registry_isclassclass();
144
145 classinfo_t* slotinfo_asclass(slotinfo_t*f);
146 classinfo_t* slotinfo_gettype(slotinfo_t*);
147
148 namespace_t access2namespace(U8 access, char*package);
149
150 char registry_ispackage(char*package);
151
152 // static multinames
153 classinfo_t* registry_getanytype();
154 classinfo_t* registry_getarrayclass();
155 classinfo_t* registry_getobjectclass();
156 classinfo_t* registry_getnumberclass();
157 classinfo_t* registry_getstringclass();
158 classinfo_t* registry_getintclass();
159 classinfo_t* registry_getuintclass();
160 classinfo_t* registry_getnullclass();
161 classinfo_t* registry_getregexpclass();
162 classinfo_t* registry_getbooleanclass();
163 classinfo_t* registry_getMovieClip();
164 classinfo_t* registry_getclassclass(classinfo_t*a);
165 classinfo_t* registry_getnamespaceclass();
166
167 char* infotypename(slotinfo_t*s);
168 void slotinfo_dump(slotinfo_t*s);
169
170 /* convenience functions */
171 #define sig2mname(x) (x->superclass,classinfo_to_multiname((slotinfo_t*)(x)))
172
173 #define TYPE_ANY             (0)
174 #define TYPE_IS_ANY(t)       ((t) == 0)
175 #define TYPE_INT                     registry_getintclass()
176 #define TYPE_IS_INT(t)       ((t) == registry_getintclass())
177 #define TYPE_UINT                    registry_getuintclass()
178 #define TYPE_IS_UINT(t)      ((t) == registry_getuintclass())
179 #define TYPE_NUMBER                  registry_getnumberclass()
180 #define TYPE_IS_NUMBER(t)    ((t) == registry_getnumberclass())
181 #define TYPE_FLOAT                   registry_getnumberclass()
182 #define TYPE_IS_FLOAT(t)     ((t) == registry_getnumberclass())
183 #define TYPE_BOOLEAN                 registry_getbooleanclass()
184 #define TYPE_IS_BOOLEAN(t)   ((t) == registry_getbooleanclass())
185 #define TYPE_STRING                  registry_getstringclass()
186 #define TYPE_IS_STRING(t)    ((t) == registry_getstringclass())
187 #define TYPE_OBJECT                  registry_getobjectclass()
188 #define TYPE_IS_OBJECT(t)    ((t) == registry_getobjectclass())
189 #define TYPE_REGEXP                  registry_getregexpclass()
190 #define TYPE_IS_REGEXP(t)    ((t) == registry_getregexpclass())
191 #define TYPE_NAMESPACE            registry_getnamespaceclass()
192 #define TYPE_IS_NAMESPACE(t) ((t) == registry_getnamespaceclass())
193 #define TYPE_FUNCTION(f)     ((f)->return_type,slotinfo_asclass((slotinfo_t*)(f)))
194 #define TYPE_IS_FUNCTION(t)  registry_isfunctionclass(t)
195 #define TYPE_CLASS(f)        ((f)->superclass,slotinfo_asclass((slotinfo_t*)(f)))
196 #define TYPE_IS_CLASS(t)     registry_isclassclass(t)
197 #define TYPE_NULL            registry_getnullclass()
198 #define TYPE_IS_NULL(t)      ((t) == registry_getnullclass())
199         
200 #define TYPE_IS_BUILTIN_SIMPLE(type) (TYPE_IS_INT(type) || \
201                                       TYPE_IS_UINT(type) || \
202                                       TYPE_IS_FLOAT(type) || \
203                                       TYPE_IS_BOOLEAN(type) || \
204                                       TYPE_IS_STRING(type))
205
206
207 #endif