X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fdevices%2Frecord.c;h=a8a0088672b5ea848c97cc726d857c3204b00077;hb=bf04757cd94e94c1f67fa3d2a4e3e59fa5bce0c0;hp=9af6530e507d800a187ce34bbc539b5bc8ea54fc;hpb=a55572f73250f9db598d0f9fffe05a7d5198e4b5;p=swftools.git diff --git a/lib/devices/record.c b/lib/devices/record.c index 9af6530..a8a0088 100644 --- a/lib/devices/record.c +++ b/lib/devices/record.c @@ -40,6 +40,7 @@ typedef struct _internal { gfxfontlist_t* fontlist; writer_t w; + int cliplevel; } internal_t; typedef struct _internal_result { @@ -299,6 +300,7 @@ static void record_startclip(struct _gfxdevice*dev, gfxline_t*line) msg(" record: %08x STARTCLIP\n", dev); writer_writeU8(&i->w, OP_STARTCLIP); dumpLine(&i->w, line); + i->cliplevel++; } static void record_endclip(struct _gfxdevice*dev) @@ -306,6 +308,10 @@ static void record_endclip(struct _gfxdevice*dev) internal_t*i = (internal_t*)dev->internal; msg(" record: %08x ENDCLIP\n", dev); writer_writeU8(&i->w, OP_ENDCLIP); + i->cliplevel--; + if(i->cliplevel<0) { + msg(" record: endclip() without startclip()"); + } } static void record_fill(struct _gfxdevice*dev, gfxline_t*line, gfxcolor_t*color) @@ -342,10 +348,12 @@ static void record_fillgradient(struct _gfxdevice*dev, gfxline_t*line, gfxgradie static void record_addfont(struct _gfxdevice*dev, gfxfont_t*font) { internal_t*i = (internal_t*)dev->internal; - msg(" record: %08x ADDFONT\n", dev); - writer_writeU8(&i->w, OP_ADDFONT); - dumpFont(&i->w, font); - i->fontlist = gfxfontlist_addfont(i->fontlist, font); + msg(" record: %08x ADDFONT %s\n", dev, font->id); + if(font && !gfxfontlist_hasfont(i->fontlist, font)) { + writer_writeU8(&i->w, OP_ADDFONT); + dumpFont(&i->w, font); + i->fontlist = gfxfontlist_addfont(i->fontlist, font); + } } static void record_drawchar(struct _gfxdevice*dev, gfxfont_t*font, int glyphnr, gfxcolor_t*color, gfxmatrix_t*matrix) @@ -353,7 +361,6 @@ static void record_drawchar(struct _gfxdevice*dev, gfxfont_t*font, int glyphnr, internal_t*i = (internal_t*)dev->internal; if(font && !gfxfontlist_hasfont(i->fontlist, font)) { record_addfont(dev, font); - i->fontlist = gfxfontlist_addfont(i->fontlist, font); } msg(" record: %08x DRAWCHAR %d\n", glyphnr, dev); @@ -408,8 +415,7 @@ static void replay(struct _gfxdevice*dev, gfxdevice_t*out, void*data, int length unsigned char op = reader_readU8(r); switch(op) { case OP_END: - msg(" replay: END"); - return; + goto finish; case OP_SETPARAM: { msg(" replay: SETPARAM"); char*key; @@ -487,6 +493,7 @@ static void replay(struct _gfxdevice*dev, gfxdevice_t*out, void*data, int length gfxline_t* line = readLine(r); gfxcxform_t* cxform = readCXForm(r); out->fillbitmap(out, line, &img, &matrix, cxform); + gfxline_free(line); if(cxform) free(cxform); free(img.data);img.data=0; @@ -540,8 +547,13 @@ static void replay(struct _gfxdevice*dev, gfxdevice_t*out, void*data, int length } } } +finish: r->dealloc(r); - gfxfontlist_free(fontlist, 1); + /* problem: if we just replayed into a device which stores the + font for later use (the record device itself is a nice example), + then we can't free it yet */ + //gfxfontlist_free(fontlist, 1); + gfxfontlist_free(fontlist, 0); } void gfxresult_record_replay(gfxresult_t*result, gfxdevice_t*device) { @@ -625,7 +637,11 @@ void gfxdevice_record_flush(gfxdevice_t*dev, gfxdevice_t*out) static gfxresult_t* record_finish(struct _gfxdevice*dev) { internal_t*i = (internal_t*)dev->internal; - msg(" record: %08x END\n", dev); + msg(" record: %08x END", dev); + + if(i->cliplevel) { + msg(" Warning: unclosed cliplevels"); + } writer_writeU8(&i->w, OP_END); @@ -657,6 +673,7 @@ void gfxdevice_record_init(gfxdevice_t*dev) writer_init_growingmemwriter(&i->w, 1048576); i->fontlist = gfxfontlist_create(); + i->cliplevel = 0; dev->setparameter = record_setparameter; dev->startpage = record_startpage;