Subversion Repositories wimsdev

Rev

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