+}
+
+typedef struct _scheduled_file {
+ char*name;
+ char*filename;
+ struct _scheduled_file*next;
+} scheduled_file_t;
+
+static scheduled_file_t*scheduled=0;
+dict_t*scheduled_dict=0;
+
+void as3_parse_scheduled(int pass)
+{
+ //printf("[pass %d] parse scheduled\n", pass);
+
+ while(scheduled) {
+ scheduled_file_t*s = scheduled;
+ scheduled = 0;
+ while(s) {
+ scheduled_file_t*old = s;
+ as3_parse_file_or_array(pass, s->name, s->filename, 0,0);
+ s = s->next;
+
+ free(old->filename);
+ free(old->name);
+ old->filename = old->name = 0;
+ free(old);
+ }
+ }
+ if(scheduled_dict) {
+ dict_destroy(scheduled_dict);
+ scheduled_dict=0;
+ }
+}
+void as3_schedule_file(const char*name, const char*filename)
+{
+ if(!scheduled_dict)
+ scheduled_dict = dict_new();
+
+ if(dict_contains(scheduled_dict, filename)) {
+ return; //already processed
+ } else {
+ dict_put(scheduled_dict, filename, 0);
+ }
+ //printf("[pass %d] schedule %s %s\n", as3_pass, name, filename);
+
+ NEW(scheduled_file_t, f);
+ f->name = strdup(name);
+ f->filename = strdup(filename);
+ f->next = scheduled; // dfs
+ scheduled = f;
+}
+
+void as3_parse_bytearray(const char*name, void*mem, int length)
+{
+ as3_parse_file_or_array(1, name, 0, mem, length);
+ as3_parse_scheduled(1);
+
+ as3_parse_file_or_array(2, name, 0, mem, length);
+ as3_parse_scheduled(2);
+}
+
+void as3_parse_file(const char*filename)
+{
+ char*fullfilename = find_file(filename);
+ if(!fullfilename)
+ return; // not found
+
+ as3_parse_file_or_array(1, filename, fullfilename, 0,0);
+ as3_parse_scheduled(1);