mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-22 07:42:02 +00:00
160 lines
5.5 KiB
Plaintext
160 lines
5.5 KiB
Plaintext
|
This file is public domain.
|
||
|
Originally written 1995, Geoffrey Tobin.
|
||
|
The author has expressed the hope that any modification will retain enough content to remain useful. He would also appreciate being acknowledged as the original author in the documentation.
|
||
|
This declaration added 2008/11/14 by Clea F. Rees with the permission of Geoffrey Tobin.
|
||
|
|
||
|
``dvi.doc''
|
||
|
Mon 27 Feb 1995
|
||
|
Geoffrey Tobin
|
||
|
|
||
|
Description of the DVI file structure.
|
||
|
--------------------------------------
|
||
|
|
||
|
Reference:
|
||
|
----------
|
||
|
|
||
|
CTAN: dviware/driv-standard/level-0/dvistd0.tex
|
||
|
|
||
|
"The DVI Driver Standard, Level 0",
|
||
|
by The TUG DVI Driver Standards Committee (now defunct)
|
||
|
chaired by Joachim Schrod.
|
||
|
Appendix A, "Device-Independent File Format",
|
||
|
section A.2, "Summary of DVI commands".
|
||
|
|
||
|
|
||
|
DVI Commands
|
||
|
------------
|
||
|
Listed in the free format:
|
||
|
"Opcode Symbol Parameter[Signed? Bytes] ... Action".
|
||
|
|
||
|
|
||
|
0 set_char_0 - set character 0 from current font
|
||
|
...
|
||
|
127 set_char_127 - set character 127 from current font
|
||
|
|
||
|
128 set1 c[1] - set 1-byte unsigned character (uchar) number c
|
||
|
129 set2 c[2] - set 2-byte uchar number c
|
||
|
130 set3 c[3] - set 3-byte uchar number c
|
||
|
131 set4 c[+4] - set 4-byte signed character (schar) number c
|
||
|
|
||
|
132 set_rule a[+4] b[+4] - set rule, height a, width b
|
||
|
|
||
|
133 put1 c[1] - put 1-byte uchar c
|
||
|
134 put2 c[2] - put 2-byte uchar
|
||
|
135 put3 c[3] - put 3-byte uchar
|
||
|
136 put4 c[+4] - put 4-byte schar
|
||
|
|
||
|
137 put_rule a[+4] b[+4] - put rule, height a, width b
|
||
|
|
||
|
138 nop - do nothing
|
||
|
|
||
|
139 bop c0[+4] ... c9[+4] p[+4] - beginning of page
|
||
|
140 eop - end of page
|
||
|
|
||
|
141 push - push (h,v,w,x,y,z) onto stack
|
||
|
142 pop - pop (h,v,w,x,y,z) from stack
|
||
|
|
||
|
143 right1 b[+1] - move right b units
|
||
|
144 right2 b[+2] - move right b units
|
||
|
145 right3 b[+3] - move right b units
|
||
|
146 right4 b[+4] - move right b units
|
||
|
|
||
|
147 w0 - move right w units
|
||
|
148 w1 b[+1] - move right b units, and set w = b
|
||
|
149 w2 b[+2] - move right b units, and set w = b
|
||
|
150 w3 b[+3] - move right b units, and set w = b
|
||
|
151 w4 b[+4] - move right b units, and set w = b
|
||
|
|
||
|
152 x0 - move right x units
|
||
|
153 x1 b[+1] - move right b units, and set x = b
|
||
|
154 x2 b[+2] - move right b units, and set x = b
|
||
|
155 x3 b[+3] - move right b units, and set x = b
|
||
|
156 x4 b[+4] - move right b units, and set x = b
|
||
|
|
||
|
157 down1 a[+1] - move down a units
|
||
|
158 down2 a[+2] - move down a units
|
||
|
159 down3 a[+3] - move down a units
|
||
|
160 down4 a[+4] - move down a units
|
||
|
|
||
|
161 y0 - move right y units
|
||
|
162 y1 a[+1] - move right a units, and set y = a
|
||
|
163 y2 a[+2] - move right a units, and set y = a
|
||
|
164 y3 a[+3] - move right a units, and set y = a
|
||
|
165 y4 a[+4] - move right a units, and set y = a
|
||
|
|
||
|
166 z0 - move right z units
|
||
|
167 z1 a[+1] - move right a units, and set z = a
|
||
|
168 z2 a[+2] - move right a units, and set z = a
|
||
|
169 z3 a[+3] - move right a units, and set z = a
|
||
|
170 z4 a[+4] - move right a units, and set z = a
|
||
|
|
||
|
171 fnt_num_0 - set current font number (f) = 0
|
||
|
...
|
||
|
234 fnt_num_63 - set f = 63
|
||
|
|
||
|
235 fnt1 k[1] - set f = k
|
||
|
236 fnt2 k[2] - set f = k
|
||
|
237 fnt3 k[3] - set f = k
|
||
|
238 fnt4 k[+4] - set f = k
|
||
|
|
||
|
239 xxx1 k[1] x[k] - special string x with k bytes
|
||
|
240 xxx2 k[2] x[k] - special string x with k bytes
|
||
|
241 xxx3 k[3] x[k] - special string x with k bytes
|
||
|
242 xxx4 k[4] x[k] - special string x with (unsigned) k bytes
|
||
|
|
||
|
243 fnt_def1 k[1] c[4] s[4] d[4] a[1] l[1] n[a+l] - define font k
|
||
|
244 fnt_def2 k[2] c[4] s[4] d[4] a[1] l[1] n[a+l] - define font k
|
||
|
245 fnt_def3 k[3] c[4] s[4] d[4] a[1] l[1] n[a+l] - define font k
|
||
|
246 fnt_def4 k[+4] c[4] s[4] d[4] a[1] l[1] n[a+l] - define font k
|
||
|
|
||
|
247 pre i[1] num[4] den[4] mag[4] k[1] x[k] - begin preamble
|
||
|
|
||
|
248 post p[4] num[4] den[4] mag[4] l[4] u[4] s[2] t[2] - begin postamble
|
||
|
249 post_post q[4] i[1] 223 ... 223 - end postamble
|
||
|
|
||
|
250 - undefined
|
||
|
...
|
||
|
255 - undefined
|
||
|
|
||
|
In bop:
|
||
|
|
||
|
c0[+4] ... c9[+4] = page counters, \`a la TeX.
|
||
|
p[+4] = pointer to previous bop (its byte address); first bop has p = -1 .
|
||
|
|
||
|
In the font definitions:
|
||
|
|
||
|
c[4] = check sum for TFM file.
|
||
|
s[4] = scale factor, in DVI units.
|
||
|
d[4] = design size, in DVI units.
|
||
|
a[1] = length of the "area" or directory.
|
||
|
l[1] = length of the font name.
|
||
|
n[a+l] = area and font name string(s).
|
||
|
|
||
|
In the preamble:
|
||
|
|
||
|
i[1] = DVI format ID = 2, except TeX-XeT has 3.
|
||
|
num[4] = numerator of 100 nm / DVI unit.
|
||
|
den[4] = denominator of 100 nm / DVI unit.
|
||
|
mag[4] = 1000 * magnification.
|
||
|
k[1] = comment length.
|
||
|
x[k] = comment string.
|
||
|
|
||
|
In the postamble:
|
||
|
|
||
|
p[4] = pointer to final bop.
|
||
|
num[4], den[4], mag[4] = duplicates of values in preamble.
|
||
|
l[4] = height-plus-depth of tallest page, in DVI units.
|
||
|
u[4] = width of widest page, in DVI units.
|
||
|
s[2] = maximum stack depth needed to process this DVI file.
|
||
|
t[2] = total number of pages (bop commands) present.
|
||
|
|
||
|
In the post-postamble:
|
||
|
|
||
|
q[4] = pointer to the "post" command that started the postamble.
|
||
|
i[1] = DVI format ID, as in the preamble.
|
||
|
223 ... 223 = at least four "223" bytes.
|
||
|
|
||
|
---------------
|
||
|
EOF ``dvi.doc''
|
||
|
---------------
|