Rev 10 | Rev 8195 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 10 | reyssat | 1 | /* Copyright (C) 2002-2003 XIAO, Gang of Universite de Nice - Sophia Antipolis |
| 2 | * |
||
| 3 | * This program is free software; you can redistribute it and/or modify |
||
| 4 | * it under the terms of the GNU General Public License as published by |
||
| 5 | * the Free Software Foundation; either version 2 of the License, or |
||
| 6 | * (at your option) any later version. |
||
| 7 | * |
||
| 8 | * This program is distributed in the hope that it will be useful, |
||
| 9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
| 10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
| 11 | * GNU General Public License for more details. |
||
| 12 | * |
||
| 13 | * You should have received a copy of the GNU General Public License |
||
| 14 | * along with this program; if not, write to the Free Software |
||
| 15 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
||
| 16 | */ |
||
| 17 | |||
| 18 | /* dvi 2 gif driver, gf font loader and processor */ |
||
| 8103 | bpr | 19 | #include "texgif.h" |
| 10 | reyssat | 20 | |
| 8103 | bpr | 21 | #define gf_paint_0 0 |
| 22 | #define gf_paint1 64 |
||
| 23 | #define gf_paint2 65 |
||
| 24 | #define gf_paint3 66 |
||
| 25 | #define gf_boc 67 |
||
| 26 | #define gf_boc1 68 |
||
| 27 | #define gf_eoc 69 |
||
| 28 | #define gf_skip0 70 |
||
| 29 | #define gf_skip1 71 |
||
| 30 | #define gf_skip2 72 |
||
| 31 | #define gf_skip3 73 |
||
| 32 | #define gf_new_row_0 74 |
||
| 33 | #define gf_xxx1 239 |
||
| 34 | #define gf_xxx2 240 |
||
| 35 | #define gf_xxx3 241 |
||
| 36 | #define gf_xxx4 242 |
||
| 37 | #define gf_yyy 243 |
||
| 38 | #define gf_no_op 244 |
||
| 39 | #define gf_char_loc 245 |
||
| 40 | #define gf_char_loc0 246 |
||
| 41 | #define gf_pre 247 |
||
| 42 | #define gf_post 248 |
||
| 43 | #define gf_post_post 249 |
||
| 44 | |||
| 10 | reyssat | 45 | int g; |
| 46 | FONTHEADER *fh; |
||
| 47 | int brush, x,y,xmax,ymax,thischar,xsize,charsize,charcnt,charpos; |
||
| 48 | int chswitch; |
||
| 49 | long int datapos; |
||
| 50 | char *onechar; |
||
| 51 | unsigned char *gfbuf; |
||
| 52 | int gfbuflen; |
||
| 53 | FILE *fontf; |
||
| 54 | |||
| 55 | void GF_eoc(void) |
||
| 56 | { |
||
| 57 | if(onechar==NULL) return; |
||
| 58 | fwrite(onechar,1,charsize,fontf); datapos+=charsize; |
||
| 59 | free(onechar); onechar=NULL; |
||
| 60 | } |
||
| 61 | |||
| 62 | void GF_boc(int p) |
||
| 63 | { |
||
| 64 | unsigned char cc; |
||
| 65 | int min_m, min_n, max_m, max_n, del_m, del_n; |
||
| 66 | if(!chswitch) return; |
||
| 67 | if(p==0) { |
||
| 68 | cc=texint(gfbuf+(++g),4); g+=8; |
||
| 69 | min_m=texint(gfbuf+g,4); g+=4; |
||
| 70 | max_m=texint(gfbuf+g,4); g+=4; |
||
| 71 | min_n=texint(gfbuf+g,4); g+=4; |
||
| 72 | max_n=texint(gfbuf+g,4); g+=4; |
||
| 73 | del_m=max_m-min_m; del_n=max_n-min_n; |
||
| 74 | g--; |
||
| 75 | } |
||
| 76 | else { |
||
| 77 | cc=gfbuf[++g]; |
||
| 78 | del_m=gfbuf[++g]; max_m=gfbuf[++g]; |
||
| 79 | del_n=gfbuf[++g]; max_n=gfbuf[++g]; |
||
| 80 | min_m=max_m-del_m; min_n=max_n-del_n; |
||
| 81 | } |
||
| 82 | if(cc>tfm.ec || cc<tfm.bc) return; |
||
| 83 | charpos=cc-tfm.bc; |
||
| 84 | if(del_m<0) del_m=0; if(del_n<0) del_n=0; |
||
| 85 | if(del_m>=MAX_FONT_X-1) del_m=MAX_FONT_X-2; |
||
| 86 | if(del_n>=MAX_FONT_Y-1) del_n=MAX_FONT_Y-2; |
||
| 87 | x=y=0; xmax=del_m+1; ymax=del_n+1; |
||
| 88 | fh[charpos].xstart=min_m; fh[charpos].ystart=-max_n; |
||
| 89 | fh[charpos].xmax=xmax; fh[charpos].ymax=ymax; |
||
| 90 | brush=0; thischar=cc; |
||
| 91 | xsize=(xmax+7)/8; charsize=xsize*ymax; |
||
| 92 | onechar=xmalloc(charsize+1024); |
||
| 93 | memset(onechar,0,charsize+1024); |
||
| 94 | fh[charpos].start=datapos; |
||
| 95 | fh[charpos].w=tfm.f[cc].w; |
||
| 96 | } |
||
| 97 | |||
| 98 | void GF_paint(int p) |
||
| 99 | { |
||
| 100 | int i; |
||
| 101 | if(onechar==NULL) return; |
||
| 102 | if(brush) for(i=x;i<p+x && i<xmax;i++) { |
||
| 103 | onechar[y*xsize+(i>>3)]|=(1<<(i&7)); |
||
| 104 | } |
||
| 105 | x+=p; if(x>xmax) x=xmax; |
||
| 106 | brush^=1; |
||
| 107 | } |
||
| 108 | |||
| 109 | void GF_new_row(int p) |
||
| 110 | { |
||
| 111 | y++; if(y>ymax) y=ymax; |
||
| 112 | x=p; if(x>xmax) x=xmax; |
||
| 113 | brush=1; |
||
| 114 | } |
||
| 115 | |||
| 116 | void GF_skip(int p) |
||
| 117 | { |
||
| 118 | if(p>0) p=texint(gfbuf+(++g),p); |
||
| 119 | p++; y+=p; if(y>ymax) y=ymax; |
||
| 120 | x=0; brush=0; |
||
| 121 | } |
||
| 122 | |||
| 123 | void GF_xxx(int p) |
||
| 124 | { |
||
| 125 | unsigned int t; |
||
| 126 | t=texint(gfbuf+(++g),p); |
||
| 127 | g+=p+t-1; |
||
| 128 | } |
||
| 129 | |||
| 130 | void GF_yyy(void) |
||
| 131 | { |
||
| 132 | g+=4; |
||
| 133 | } |
||
| 134 | |||
| 135 | void GF_char_loc(int p) |
||
| 136 | { |
||
| 137 | if(p==0) g+=1+1+4+4; |
||
| 138 | else g+=1+4+4+4+4; |
||
| 139 | } |
||
| 140 | |||
| 141 | void GF_post(void) |
||
| 142 | { |
||
| 143 | chswitch=0; |
||
| 144 | } |
||
| 145 | |||
| 146 | void GF_post_post(void) |
||
| 147 | { |
||
| 148 | g=gfbuflen; chswitch=0; |
||
| 149 | } |
||
| 150 | |||
| 151 | void loadgf(char *fname, int density) |
||
| 152 | { |
||
| 153 | int len; |
||
| 154 | char namebuf[128]; |
||
| 8103 | bpr | 155 | |
| 10 | reyssat | 156 | snprintf(namebuf,sizeof(namebuf),"%s/texgf.%dgf",tmpdir,density); |
| 157 | len=getfile(namebuf,&gfbuf); |
||
| 158 | if(len<=0) { |
||
| 159 | error("Metafont failed."); |
||
| 160 | } |
||
| 161 | gfbuflen=len; |
||
| 162 | } |
||
| 163 | |||
| 164 | void makegf(char *fontname, int density) |
||
| 165 | { |
||
| 166 | call_sh("mkdir -p %s\n\ |
||
| 167 | cd %s\n\ |
||
| 168 | rm -f texgf.* 2>/dev/null\n\ |
||
| 169 | cat >texgf.mf <<@\n\ |
||
| 170 | batchmode;\n\ |
||
| 171 | mode_def texgf =\n\ |
||
| 172 | mode_param (pixels_per_inch, %d);\n\ |
||
| 173 | mode_param (blacker, %f);\n\ |
||
| 174 | mode_param (fillin, 0);\n\ |
||
| 175 | mode_param (o_correction, 0);\n\ |
||
| 176 | mode_common_setup_;\n\ |
||
| 177 | enddef;\n\ |
||
| 178 | mode = texgf;\n\ |
||
| 179 | input %s;\n\ |
||
| 180 | @\n\ |
||
| 181 | mf texgf </dev/null || mf-nowin texgf </dev/null\n\ |
||
| 182 | ", fontdir, tmpdir, density, pow((double)density/100,0.75)*blacker, fontname); |
||
| 183 | } |
||
| 184 | |||
| 185 | void gf2font(char *fontname,int density) |
||
| 186 | { |
||
| 187 | unsigned char cc; |
||
| 188 | char namebuf[1024]; |
||
| 189 | char tmpname[1024]; |
||
| 8103 | bpr | 190 | |
| 10 | reyssat | 191 | if((gfbuf[0]&255)!=gf_pre || (gfbuf[1]&255)!=131) return; |
| 192 | g=3+(gfbuf[2]&255); |
||
| 193 | if(gfbuflen<=g) return; |
||
| 194 | if(tfm.ec==0 && tfm.bc==0) return; |
||
| 195 | charcnt=tfm.ec-tfm.bc+1; |
||
| 196 | fh=xmalloc(charcnt*sizeof(FONTHEADER)+256); |
||
| 197 | memset(fh,0,charcnt*sizeof(FONTHEADER)); |
||
| 198 | snprintf(tmpname,sizeof(tmpname),"%s/wims.fonttmp",tmpdir); |
||
| 199 | fontf=fopen(tmpname,"w"); if(fontf==NULL) return; |
||
| 200 | brush=0; x=y=xmax=ymax=datapos=0; onechar=NULL; chswitch=1; |
||
| 201 | for(;g<gfbuflen;g++) { |
||
| 202 | cc=gfbuf[g]; |
||
| 203 | if(cc<=63) {GF_paint(cc); continue;} |
||
| 204 | if(cc>=74 && cc<=238) {GF_new_row(cc-74); continue;} |
||
| 205 | switch(cc) { |
||
| 206 | case gf_boc: GF_boc(0); break; |
||
| 207 | case gf_boc1: GF_boc(1); break; |
||
| 208 | case gf_eoc: GF_eoc(); break; |
||
| 209 | case gf_skip0: GF_skip(0); break; |
||
| 210 | case gf_skip1: GF_skip(1); break; |
||
| 211 | case gf_skip2: GF_skip(2); break; |
||
| 212 | case gf_skip3: GF_skip(3); break; |
||
| 213 | case gf_char_loc: GF_char_loc(1); break; |
||
| 214 | case gf_char_loc0: GF_char_loc(0); break; |
||
| 215 | case gf_xxx1: GF_xxx(1); break; |
||
| 216 | case gf_xxx2: GF_xxx(2); break; |
||
| 217 | case gf_xxx3: GF_xxx(3); break; |
||
| 218 | case gf_xxx4: GF_xxx(4); break; |
||
| 219 | case gf_yyy: GF_yyy(); break; |
||
| 8103 | bpr | 220 | |
| 10 | reyssat | 221 | default: break; |
| 222 | } |
||
| 223 | } |
||
| 224 | fclose(fontf); |
||
| 225 | snprintf(namebuf,sizeof(namebuf),"%s/%s.font", |
||
| 226 | tmpdir,fontname); |
||
| 227 | fontf=fopen(namebuf,"w"); if(fontf!=NULL) { |
||
| 228 | fwrite(&(tfm.checksum),sizeof(int),1,fontf); |
||
| 229 | fwrite(&(tfm.designsize),sizeof(int),1,fontf); |
||
| 230 | fwrite(&(tfm.bc),sizeof(int),1,fontf); |
||
| 231 | fwrite(&(tfm.ec),sizeof(int),1,fontf); |
||
| 232 | fwrite(fh,sizeof(FONTHEADER),charcnt,fontf); |
||
| 233 | fclose(fontf); |
||
| 234 | call_sh("cat %s >>%s; mkdir -p %s/%d; mv -f %s %s/%d", |
||
| 235 | tmpname,namebuf,fontdir,density,namebuf,fontdir,density); |
||
| 236 | unlink(tmpname); |
||
| 237 | } |
||
| 238 | free(fh); |
||
| 239 | } |
||
| 240 |