freebsd-ports/mail/faces/files/patch-ch
Lars Koeller d60b460b03 o) Patch reverse compface part to faces 1.6.1 port
- 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.
2003-01-19 19:07:23 +00:00

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';
}