/*
* This software is Copyright 1988 by Radical Eye Software.
*/
/*
* dpicheck of dvips.c. Checks the dots per inch to make sure
* it exists. The fonts which exist are DPI at the appropriate
* magnifications.
*/
#include "dvips.h"
extern int actualdpi ;
static integer existsizes[30] = { 0 , 99999999 } ;
static int checkdpi ;
/*
* This routine adds some sizes to `existsizes'.
*/
void addsiz P1C(int, rhsize)
{
register integer *p ;
long t, hsize ;
hsize = rhsize ;
for (p=existsizes; *p < hsize; p++) ;
if (*p == hsize)
return ;
do {
t = *p ;
*p++ = hsize ;
hsize = t ;
} while (hsize) ;
}
void adddpi P1C(int, hsize)
{
long a, b, c ;
int i ;
addsiz(hsize) ;
addsiz((int)((hsize * 116161L + 53020L) / 106040L)) ;
a = hsize ;
b = 0 ;
c = 1 ;
for (i=0; i<9; i++) {
b = 6 * b + (a % 5) * c ;
a = a + a / 5 ;
c = c * 5 ;
if (b > c) {
b -= c ;
a++ ;
}
if (b + b >= c)
addsiz((int)(a+1)) ;
else
addsiz((int)a) ;
}
}
/*
* Finally, the routine that checks a size for match.
*/
halfword
dpicheck P1C(halfword, dpi)
{
integer i ;
integer margin = 1 + dpi / 500 ;
if (! checkdpi) {
adddpi(DPI) ;
checkdpi = 1 ;
}
for (i=0; existsizes[i] < dpi; i++) ;
if (existsizes[i]-dpi <= margin)
return(existsizes[i]) ;
else if (dpi-existsizes[i-1] <= margin)
return(existsizes[i-1]) ;
else
return(dpi) ;
}
|