home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: Graphics
/
Graphics.zip
/
jpeg2ps2.zip
/
asc85ec.c
next >
Wrap
C/C++ Source or Header
|
1997-01-23
|
3KB
|
113 lines
/* ASCII85 and Hex encoding for PostScript Level 2 and PDF */
/* (C) Thomas Merz 1994-96 */
#include <stdio.h>
#include <fcntl.h>
#ifdef DOS
#include <io.h>
#include <stdlib.h>
#endif
#include "psimage.h"
typedef unsigned char byte;
static unsigned char buf[4];
static unsigned long power85[5] = { 1L, 85L, 85L*85, 85L*85*85, 85L*85*85*85};
/* read 0-4 Bytes. result: number of bytes read */
static int
ReadSomeBytes P1(FILE *, in)
{
register int count, i;
for (count = 0; count < 4; count++) {
if ((i = getc(in)) == EOF)
break;
else
buf[count] = (byte) i;
}
return count;
}
static void
outbyte P2(byte, c, FILE *, out)
{ /* output one byte */
static int outbytes = 0;
if (fputc(c, out) == EOF) {
fprintf(stderr, "jpeg2ps: write error - exit!\n");
exit(1);
}
if (++outbytes > 63) { /* insert line feed */
fputc('\n', out);
outbytes = 0;
}
}
int
ASCII85Encode P2(FILE *, in, FILE *, out)
{
register int i, count;
unsigned long word, v;
/* 4 bytes read ==> output 5 bytes */
while ((count = ReadSomeBytes(in)) == 4) {
word = ((unsigned long)(((unsigned int)buf[0] << 8) + buf[1]) << 16) +
(((unsigned int)buf[2] << 8) + buf[3]);
if (word == 0)
outbyte('z', out); /* shortcut for 0 */
else
/* calculate 5 ASCII85 bytes and output them */
for (i = 4; i >= 0; i--) {
v = word / power85[i];
outbyte((byte)v + '!', out);
word -= v * power85[i];
}
}
word = 0;
if (count != 0) { /* 1-3 bytes left */
for (i = count-1; i >= 0; i--) /* accumulate bytes */
word += (unsigned long)buf[i] << 8 * (3-i);
/* encoding as above, but output only count+1 bytes */
for (i = 4; i >= 4-count; i--) {
v = word / power85[i];
outbyte((byte)v + '!', out);
word -= v * power85[i];
}
}
fputc('~', out); /* EOD marker */
fputc('>', out);
return 0;
}
void
ASCIIHexEncode P2(FILE *, in, FILE *, out) {
static char buffer[512];
static char BinToHex[] = "0123456789ABCDEF";
int i, CharsPerLine;
size_t n;
unsigned char *p;
CharsPerLine = 0;
putc('\n', out);
while ((n = fread(buffer, 1, sizeof(buffer), in)) != 0)
for (i = 0, p = (unsigned char *) buffer; i < n; i++, p++) {
putc(BinToHex[*p>>4], out); /* first nibble */
putc(BinToHex[*p & 0x0F], out); /* second nibble */
if ((CharsPerLine += 2) >= 64) {
putc('\n', out);
CharsPerLine = 0;
}
}
putc('>', out); /* EOD marker for PostScript hex strings */
}