d60b460b03
- Missing uncompface -X option used in exmh - Missing filter programs to generate ikon file - I will try communicate the necessary add ons to the new developers of faces.
336 lines
6.9 KiB
Text
336 lines
6.9 KiB
Text
*** compface/file.c Tue Jan 15 23:58:46 2002
|
|
--- /home/lkoeller/tmp/ports/mail/faces/work/faces/compface/file.c Sun Jan 19 19:35:35 2003
|
|
***************
|
|
*** 1,10 ****
|
|
-
|
|
/*
|
|
- * $Header: /cvs/faces/faces/compface/file.c,v 1.2 2002/01/15 22:58:46 devface Exp $
|
|
- *
|
|
* Compface - 48x48x1 image compression and decompression
|
|
*
|
|
! * Copyright (c) 1990-2002 James Ashton - Sydney University
|
|
*
|
|
* Permission is given to distribute these sources, as long as the
|
|
* copyright messages are not removed, and no monies are exchanged.
|
|
--- 1,9 ----
|
|
/*
|
|
* Compface - 48x48x1 image compression and decompression
|
|
*
|
|
! * Copyright (c) James Ashton - Sydney University - June 1990.
|
|
! *
|
|
! * Written 11th November 1989.
|
|
*
|
|
* Permission is given to distribute these sources, as long as the
|
|
* copyright messages are not removed, and no monies are exchanged.
|
|
***************
|
|
*** 16,147 ****
|
|
|
|
#include "compface.h"
|
|
|
|
void
|
|
! BigRead(char *fbuf)
|
|
{
|
|
! int c;
|
|
|
|
! while (*fbuf != '\0') {
|
|
c = *(fbuf++);
|
|
! if ((c < FIRSTPRINT) || (c > LASTPRINT)) {
|
|
continue;
|
|
- }
|
|
BigMul(NUMPRINTS);
|
|
BigAdd((WORD)(c - FIRSTPRINT));
|
|
}
|
|
}
|
|
|
|
-
|
|
void
|
|
! BigWrite(char *fbuf)
|
|
{
|
|
static WORD tmp;
|
|
static char buf[DIGITS];
|
|
! char *s;
|
|
! int i;
|
|
|
|
s = buf;
|
|
! while (B.b_words > 0) {
|
|
BigDiv(NUMPRINTS, &tmp);
|
|
*(s++) = tmp + FIRSTPRINT;
|
|
}
|
|
! i = 7; /* Leave room for the field name on the first line */
|
|
*(fbuf++) = ' ';
|
|
! while (s-- > buf) {
|
|
! if (i == 0) {
|
|
*(fbuf++) = ' ';
|
|
- }
|
|
*(fbuf++) = *s;
|
|
! if (++i >= MAXLINELEN) {
|
|
*(fbuf++) = '\n';
|
|
i = 0;
|
|
}
|
|
}
|
|
! if (i > 0) {
|
|
*(fbuf++) = '\n';
|
|
- }
|
|
*(fbuf++) = '\0';
|
|
}
|
|
|
|
-
|
|
void
|
|
! ReadFace(char *fbuf)
|
|
{
|
|
! int c, i;
|
|
! char *s, *t;
|
|
|
|
t = s = fbuf;
|
|
! for (i = strlen(s); i > 0; i--) {
|
|
! c = (int) *(s++);
|
|
! if ((c >= '0') && (c <= '9')) {
|
|
! if (t >= fbuf + DIGITS) {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - '0';
|
|
! } else if ((c >= 'A') && (c <= 'F')) {
|
|
! if (t >= fbuf + DIGITS) {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - 'A' + 10;
|
|
! } else if ((c >= 'a') && (c <= 'f')) {
|
|
! if (t >= fbuf + DIGITS) {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - 'a' + 10;
|
|
- } else if (((c == 'x') || (c == 'X')) && (t > fbuf) && (*(t-1) == 0)) {
|
|
- t--;
|
|
}
|
|
}
|
|
! if (t < fbuf + DIGITS) {
|
|
longjmp(comp_env, ERR_INSUFF);
|
|
- }
|
|
s = fbuf;
|
|
t = F;
|
|
c = 1 << (BITSPERDIG - 1);
|
|
! while (t < F + PIXELS) {
|
|
*(t++) = (*s & c) ? 1 : 0;
|
|
! if ((c >>= 1) == 0) {
|
|
s++;
|
|
c = 1 << (BITSPERDIG - 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
-
|
|
void
|
|
! WriteFace(char *fbuf)
|
|
{
|
|
! char *s, *t;
|
|
! int i, bits, digits, words;
|
|
|
|
s = F;
|
|
t = fbuf;
|
|
bits = digits = words = i = 0;
|
|
! while (s < F + PIXELS) {
|
|
! if ((bits == 0) && (digits == 0)) {
|
|
*(t++) = '0';
|
|
*(t++) = 'x';
|
|
}
|
|
! if (*(s++)) {
|
|
i = i * 2 + 1;
|
|
! } else {
|
|
i *= 2;
|
|
}
|
|
! if (++bits == BITSPERDIG) {
|
|
! *(t++) = *(i + HexDigits);
|
|
bits = i = 0;
|
|
! if (++digits == DIGSPERWORD) {
|
|
*(t++) = ',';
|
|
digits = 0;
|
|
! if (++words == WORDSPERLINE) {
|
|
*(t++) = '\n';
|
|
words = 0;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
*(t++) = '\0';
|
|
}
|
|
--- 15,191 ----
|
|
|
|
#include "compface.h"
|
|
|
|
+ int xbitmap=0;
|
|
+
|
|
void
|
|
! BigRead(fbuf)
|
|
! register char *fbuf;
|
|
{
|
|
! register int c;
|
|
|
|
! while (*fbuf != '\0')
|
|
! {
|
|
c = *(fbuf++);
|
|
! if ((c < FIRSTPRINT) || (c > LASTPRINT))
|
|
continue;
|
|
BigMul(NUMPRINTS);
|
|
BigAdd((WORD)(c - FIRSTPRINT));
|
|
}
|
|
}
|
|
|
|
void
|
|
! BigWrite(fbuf)
|
|
! register char *fbuf;
|
|
{
|
|
static WORD tmp;
|
|
static char buf[DIGITS];
|
|
! register char *s;
|
|
! register int i;
|
|
|
|
s = buf;
|
|
! while (B.b_words > 0)
|
|
! {
|
|
BigDiv(NUMPRINTS, &tmp);
|
|
*(s++) = tmp + FIRSTPRINT;
|
|
}
|
|
! i = 7; /* leave room for the field name on the first line */
|
|
*(fbuf++) = ' ';
|
|
! while (s-- > buf)
|
|
! {
|
|
! if (i == 0)
|
|
*(fbuf++) = ' ';
|
|
*(fbuf++) = *s;
|
|
! if (++i >= MAXLINELEN)
|
|
! {
|
|
*(fbuf++) = '\n';
|
|
i = 0;
|
|
}
|
|
}
|
|
! if (i > 0)
|
|
*(fbuf++) = '\n';
|
|
*(fbuf++) = '\0';
|
|
}
|
|
|
|
void
|
|
! ReadFace(fbuf)
|
|
! char *fbuf;
|
|
{
|
|
! register int c, i;
|
|
! register char *s, *t;
|
|
|
|
t = s = fbuf;
|
|
! for(i = strlen(s); i > 0; i--)
|
|
! {
|
|
! c = (int)*(s++);
|
|
! if ((c >= '0') && (c <= '9'))
|
|
! {
|
|
! if (t >= fbuf + DIGITS)
|
|
! {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - '0';
|
|
! }
|
|
! else if ((c >= 'A') && (c <= 'F'))
|
|
! {
|
|
! if (t >= fbuf + DIGITS)
|
|
! {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - 'A' + 10;
|
|
! }
|
|
! else if ((c >= 'a') && (c <= 'f'))
|
|
! {
|
|
! if (t >= fbuf + DIGITS)
|
|
! {
|
|
status = ERR_EXCESS;
|
|
break;
|
|
}
|
|
*(t++) = c - 'a' + 10;
|
|
}
|
|
+ else if (((c == 'x') || (c == 'X')) && (t > fbuf) && (*(t-1) == 0))
|
|
+ t--;
|
|
}
|
|
! if (t < fbuf + DIGITS)
|
|
longjmp(comp_env, ERR_INSUFF);
|
|
s = fbuf;
|
|
t = F;
|
|
c = 1 << (BITSPERDIG - 1);
|
|
! while (t < F + PIXELS)
|
|
! {
|
|
*(t++) = (*s & c) ? 1 : 0;
|
|
! if ((c >>= 1) == 0)
|
|
! {
|
|
s++;
|
|
c = 1 << (BITSPERDIG - 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
void
|
|
! WriteFace(fbuf)
|
|
! char *fbuf;
|
|
{
|
|
! register char *s, *t;
|
|
! register int i, bits, digits, words;
|
|
! extern int xbitmap;
|
|
! int digsperword = DIGSPERWORD;
|
|
! int wordsperline = WORDSPERLINE;
|
|
|
|
s = F;
|
|
t = fbuf;
|
|
bits = digits = words = i = 0;
|
|
! if (xbitmap) {
|
|
! sprintf(t,"#define noname_width 48\n#define noname_height 48\nstatic char noname_bits[] = {\n ");
|
|
! while (*t) t++;
|
|
! digsperword = 2;
|
|
! wordsperline = 15;
|
|
! }
|
|
! while (s < F + PIXELS)
|
|
! {
|
|
! if ((bits == 0) && (digits == 0))
|
|
! {
|
|
*(t++) = '0';
|
|
*(t++) = 'x';
|
|
}
|
|
! if (xbitmap) {
|
|
! if (*(s++))
|
|
! i = (i >> 1) | 0x8;
|
|
! else
|
|
! i >>= 1;
|
|
! }
|
|
! else {
|
|
! if (*(s++))
|
|
i = i * 2 + 1;
|
|
! else
|
|
i *= 2;
|
|
}
|
|
! if (++bits == BITSPERDIG)
|
|
! {
|
|
! if (xbitmap) {
|
|
! t++;
|
|
! t[-(digits & 1) * 2] = *(i + HexDigits);
|
|
! }
|
|
! else *(t++) = *(i + HexDigits);
|
|
bits = i = 0;
|
|
! if (++digits == digsperword)
|
|
! {
|
|
! if (xbitmap && (s >= F + PIXELS)) break;
|
|
*(t++) = ',';
|
|
digits = 0;
|
|
! if (++words == wordsperline)
|
|
! {
|
|
*(t++) = '\n';
|
|
+ if (xbitmap) *(t++) = ' ';
|
|
words = 0;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
+ if (xbitmap) {
|
|
+ sprintf(t, "}\n");
|
|
+ while (*t) t++;
|
|
+ }
|
|
*(t++) = '\0';
|
|
}
|