⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 minirb.c

📁 ZMODEM协议的实现
💻 C
字号:
/* * minirb.c By Chuck Forsberg Omen Technology INC *        "The High Reliability Communications Software" * * A bootstrap program for Unix to receive files from computers running *  YMODEM Batch (Professional-YAM, PowerCom, ZCOMM, etc.). * *  Minirb uses system(3) to call stty, avoiding system dependent code. *   program strips CR and CPMEOF (^Z) characters (see putsec()). *  Please refer to rz.c for comments, etc. */char * Version = "minirb 2.00 05-25-87";#include <stdio.h>#include <signal.h>#include <setjmp.h>#define OK 0#define FALSE 0#define TRUE 1#define ERROR (-1)#define CAN ('X'&037)#define SOH 1#define STX 2#define EOT 4#define ACK 6#define NAK 025#define TIMEOUT (-2)#define RETRYMAX 9#define WCEOT (-10)FILE *fout;long Bytesleft;int Blklen;char secbuf[1024];char linbuf[1024];int Lleft=0;jmp_buf tohere;alrm() { longjmp(tohere, -1); }bibi(n) { canit(); mode(0); fprintf(stderr, "minirb: caught signal %d; exiting", n); exit(128+n);}mode(n) { if (n) system("stty raw -echo"); else system("stty echo -raw");}main() { mode(1); if (signal(SIGINT, bibi) == SIG_IGN) {  signal(SIGINT, SIG_IGN); signal(SIGKILL, SIG_IGN); } else {  signal(SIGINT, bibi); signal(SIGKILL, bibi); } printf("minirb: Now send file(s) with \042sb file ...\042 command\r\n"); if (wcreceive()==ERROR)  canit(); mode(0); exit(0);}wcreceive() { for (;;) {  if (wcrxpn(secbuf) == ERROR) break;  if (secbuf[0]==0) return OK;  if (procheader(secbuf)==ERROR || wcrx()==ERROR) break; } canit(); return ERROR;}wcrxpn(rpn) char *rpn; { register c; purgeline();et_tu: sendline(NAK); Lleft=0; while ((c = wcgetsec(rpn, 100)) != 0) {  if (c == WCEOT) { sendline(ACK); Lleft=0; readline(1); goto et_tu; }  return ERROR; } sendline(ACK); return OK;}wcrx() { register int sectnum, sectcurr, sendchar, cblklen; sectnum=0; sendchar=NAK; for (;;) {  sendline(sendchar); Lleft=0;  sectcurr=wcgetsec(secbuf, 50);  if (sectcurr==(sectnum+1 & 0377)) {   sectnum++; cblklen = Bytesleft>Blklen ? Blklen:Bytesleft;   putsec(secbuf, cblklen);   if ((Bytesleft-=cblklen) < 0) Bytesleft = 0;   sendchar=ACK;  }  else if (sectcurr==(sectnum&0377)) sendchar=ACK;  else if (sectcurr==WCEOT) {   if (fclose(fout)==ERROR) return ERROR;   sendline(ACK); Lleft=0; return OK;  }  else if (sectcurr==ERROR) return ERROR;  else return ERROR; }}wcgetsec(rxbuf, maxtime) char *rxbuf; int maxtime; { register checksum, wcj, firstch; register char *p; int sectcurr, errors; for (errors=0; errors<RETRYMAX; errors++) {  if ((firstch=readline(maxtime))==STX) { Blklen=1024; goto get2; }  if (firstch==SOH) {   Blklen=128;get2:   sectcurr=readline(1); checksum=0;   if ((sectcurr+(readline(1)))==0377) {    for (p=rxbuf,wcj=Blklen; --wcj>=0; ) {     if ((firstch=readline(1)) < 0) goto bilge;     checksum += (*p++ = firstch);    }    if ((firstch=readline(1)) < 0) goto bilge;    if (((checksum-firstch)&0377)==0) return sectcurr;   }  }  else if (firstch==EOT) return WCEOT;  else if (firstch==CAN) return ERROR;bilge:  while(readline(1)!=TIMEOUT)   ;  maxtime=40; sendline(NAK); Lleft=0; } canit(); return ERROR;}readline(timeout) int timeout; { register n; static char *cdq; if (--Lleft >= 0) return (*cdq++ & 0377); n = timeout/10; if (n < 2) n = 3; if (setjmp(tohere)) { Lleft = 0; return TIMEOUT; } signal(SIGALRM, alrm); alarm(n); Lleft=read(0, cdq=linbuf, 1024); alarm(0); if (Lleft < 1) return TIMEOUT; --Lleft; return (*cdq++ & 0377);}purgeline() { Lleft = 0; lseek(0, 0L, 2); }procheader(name) char *name; { register char *p; Bytesleft = 2000000000L; p = name + 1 + strlen(name); if (*p) sscanf(p, "%ld", &Bytesleft); if ((fout=fopen(name, "w")) == NULL) return ERROR; return OK;}putsec(p, n) char *p; int n;{ for (; --n>=0; ++p) if (*p != 015 && *p != 032) putc(*p, fout); }sendline(c) { char d; d = c; write(1, &d, 1); }char canistr[] = { 24,24,24,24,24,24,24,24,0 };canit() { printf(canistr); Lleft=0; }/* END of minirb.c */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -