home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Computer Club Elmshorn Atari PD
/
CCE_PD.iso
/
pc
/
0400
/
CCE_0483.ZIP
/
CCE_0483.PD
/
LZH_SOUR.CE
/
LZS.C
< prev
next >
Wrap
C/C++ Source or Header
|
1992-04-10
|
3KB
|
130 lines
/*************************************************
LHarc version 1.13b (c)Yoshi, 1988-89.
adaption to ATARI ST with TURBO-C 1.1
from LZS.ASM
by J. Moeller 1990/01/28
HTAB = 4
*************************************************/
#ifndef __TOS__
#error Please try assembling 'lzs.asm'!
#endif
#ifdef _hufst_
#define from extern
#else
#define from
#endif
#include <stdio.h>
#include <tos.h>
#ifdef __TOS__
#include "goodputc.h"
#endif
#define BUFFERSIZ 16384L /* also defined in 'LHARC.C' */
#define MAXBLK 64
unsigned char buf2 [BUFFERSIZ], /* IO-Buffer */
buf3 [BUFFERSIZ];
from unsigned crctbl [256];
#define RDERR 13
#define WTERR 14
#define setcrc(ch) (crc = (crc >> 8) ^ crctbl [(crc ^ (ch)) & 0xff])
extern unsigned char crcflg;
extern unsigned crc;
extern char *infname, *outfname;
extern unsigned blkcnt;
extern unsigned char flg_n;
extern void error (int errcode, char *p);
void mkcrc (void)
{
register unsigned i;
for (i = 0; i<= 255; i++)
{
register unsigned j, x;
x = i;
for (j = 0; j <= 7; j++)
{
if (x & 1)
x = (x >> 1) ^ 0xa001;
else
x >>= 1;
}
crctbl [i] = x;
}
}
/*****************************
Copy <size> Bytes
from <Source> to <Dest>
*****************************/
void copyfile (FILE *Source,
FILE *Dest,
long size)
{
register int ch;
long mem,r;
char *buf;
if (size == 0L)
return;
if (crcflg)
{
int printcount;
printcount = 4096;
if (printcount > size)
printcount = (unsigned) size;
if (blkcnt > MAXBLK)
blkcnt = MAXBLK;
crc = 0;
while (size-- > 0 && (ch = getc (Source)) != EOF) {
setcrc (ch);
if (Dest != NULL)
if (putc (ch, Dest)==EOF) error (WTERR, outfname);
if (!flg_n)
if (--printcount == 0) {
if (blkcnt > 0) {
putc ('*', stdout);
blkcnt--;
}
printcount = 4096;
if (printcount > size)
printcount = (unsigned) size;
}
}
} else {
mem=(long)Malloc(-1)-20000;
if (mem>0) {
if (mem>size) mem=size;
buf=(char *) Malloc(mem);
r=1;
while (size>0 && r>0) {
r=fread(buf,1,mem,Source);
size-=r;
fwrite(buf,1,mem,Dest);
}
Mfree(buf);
} else
while (size-- > 0 && (ch = getc (Source)) != EOF)
if (Dest != NULL)
if (putc (ch, Dest) == EOF) error (WTERR, outfname);
}
if (ferror (Source))
error (RDERR, infname);
if (Dest != NULL && ferror (Dest))
error (WTERR, outfname);
}