X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fexample%2Fdumpfont.c;h=1481ed6e6c0d17c182a72463c44dff816bab9e2b;hb=b3ae7bccfb9f4ed16e26631fee072fa011f9847e;hp=aeb73fbb0d6b681225c63a585000f53635453994;hpb=5a8551400347ebdfdc8ed343fe02f992eaf3ee7a;p=swftools.git diff --git a/lib/example/dumpfont.c b/lib/example/dumpfont.c index aeb73fb..1481ed6 100644 --- a/lib/example/dumpfont.c +++ b/lib/example/dumpfont.c @@ -25,7 +25,7 @@ #include #include "../rfxswf.h" -#define PRINTABLE(a) ((a>='A')&&(a<='Z'))||((a>='a')&&(a<='z'))||((a>='0')&&(a<='9')) +#define PRINTABLE(a) (((a>0x20)&&(a<0xff)&&(a!='\\'))?a:0x20) SWF swf; @@ -64,14 +64,17 @@ void DumpFont(SWFFONT * f,char * name) printf(" f->name = strdup(\"%s\");\n",f->name); printf(" f->flags = 0x%02x;\n",f->flags); printf(" f->numchars = %d;\n",f->numchars); - printf(" f->glyph = (SWFGLYPH*)malloc(sizeof(SWFGLYPH)*%d);\n\n",f->numchars); - printf(" f->codes = (U16*)malloc(sizeof(U16)*%d);\n\n",f->numchars); + printf(" f->maxascii = %d;\n",f->maxascii); + printf(" f->glyph = (SWFGLYPH*)malloc(sizeof(SWFGLYPH)*%d);\n",f->numchars); + printf(" f->glyph2ascii = (U16*)malloc(sizeof(U16)*%d);\n",f->numchars); + printf(" f->ascii2glyph = (int*)malloc(sizeof(int)*%d);\n",f->maxascii); + printf(" memset(f->ascii2glyph, -1, sizeof(int)*%d);\n\n", f->maxascii); for (i=0;inumchars;i++) if (f->glyph[i].shape) - { printf(" addGlyph(f,%3i, 0x%02x,%4i,%3i, &Glyphs_%s[0x%04x],%4i); // %c\n", - i, f->codes[i], f->glyph[i].advance, f->glyph[i].gid, name, gpos[i], - f->glyph[i].shape->bitlen,(i!='\\')?i:0x20); + { printf(" addGlyph(f,%3i, 0x%02x,%4i, &Glyphs_%s[0x%04x],%4i); // %c\n", + i, f->glyph2ascii[i], f->glyph[i].advance, name, gpos[i], + f->glyph[i].shape->bitlen,PRINTABLE(f->glyph2ascii[i])); } printf(" return f;\n}\n\n"); @@ -79,17 +82,17 @@ void DumpFont(SWFFONT * f,char * name) } void DumpGlobal(char * funcname) -{ printf("\nvoid %s(SWFFONT * f,int i,U16 code,U16 advance,U16 gid,U8 * data,U32 bitlen)\n",funcname); +{ printf("\nvoid %s(SWFFONT * f,int i,U16 ascii,U16 advance,U8 * data,U32 bitlen)\n",funcname); printf("{ SHAPE * s;\n U32 l = (bitlen+7)/8;\n\n"); printf(" if (FAILED(swf_ShapeNew(&s))) return;\n"); printf(" s->data = malloc(l);\n"); printf(" if (!s->data) { swf_ShapeFree(s); return; }\n\n"); - printf(" f->codes[i] = code;\n"); - printf(" f->glyph[i].advance = advance;\n"); - printf(" f->glyph[i].gid = gid;\n"); - printf(" f->glyph[i].shape = s;\n"); - printf(" s->bitlen = bitlen;\n"); - printf(" s->bits.fill = 1;\n"); + printf(" f->glyph2ascii[i] = ascii;\n"); + printf(" f->ascii2glyph[ascii] = i;\n"); + printf(" f->glyph[i].advance = advance;\n"); + printf(" f->glyph[i].shape = s;\n"); + printf(" s->bitlen = bitlen;\n"); + printf(" s->bits.fill = 1;\n"); printf(" memcpy(s->data,data,l);\n}\n\n"); }