enumerateUsedIDs(t, 0, callbackFillin, &ptr);
}
-void swf_Relocate (SWF*swf, char*bitmap)
+char swf_Relocate (SWF*swf, char*bitmap)
{
TAG*tag;
int slaveids[65536];
memset(slaveids, -1, sizeof(slaveids));
tag = swf->firstTag;
+ char ok = 1;
while(tag)
{
int num;
if(!bitmap[id]) { //free
newid = id;
- }
- else {
+ } else {
newid = 0;
for (t=1;t<65536;t++)
{
break;
}
}
+ if(t==65536) {
+ fprintf(stderr, "swf_Relocate: Couldn't relocate: Out of IDs");
+ return 0;
+ }
}
bitmap[newid] = 1;
slaveids[id] = newid;
if(slaveids[id]<0) {
fprintf(stderr, "swf_Relocate: Mapping id (%d) never encountered before in %s\n", id,
swf_TagGetName(tag));
+ ok = 0;
} else {
id = slaveids[id];
PUT16(&tag->data[ptr[t]], id);
}
tag=tag->next;
}
+ return ok;
}
/* untested */
int x0,int y0,int x1,int y1,int x2,int y2);
int swf_GetNumUsedIDs(TAG * t);
void swf_GetUsedIDs(TAG * t, int * positions);
-void swf_Relocate(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[a]==0 means id a is free
+char swf_Relocate(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[a]==0 means id a is free
void swf_RelocateDepth(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[d]==0 means depth d is free
TAG* swf_Concatenate (TAG*list1,TAG*list2); // warning: both list1 and list2 are invalid after this call.