📄 lin2cod.c
字号:
/* * Copyright 1992 by Jutta Degener and Carsten Bormann, Technische * Universitaet Berlin. See the accompanying file "COPYRIGHT" for * details. THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE. *//*$Header: /home/kbs/jutta/src/gsm/gsm-1.0/tst/RCS/lin2cod.c,v 1.1 1992/10/28 00:32:06 jutta Exp $*/#include <stdio.h>#include "gsm.h"#include "proto.h"#include "getopt.h"char * pname;int debug = 0;int verbosity = 0;int fast = 0;int error = 0;usage P0(){ fprintf(stderr, "Usage: %s [-vF] [files...]\n", pname); exit(1);}void process P2((f, filename), FILE * f, char * filename){ gsm_frame buf; short source[160]; int cc; gsm r; if (!(r = gsm_create())) { perror("gsm_create"); error = 1; return ; } gsm_option(r, GSM_OPT_VERBOSE, &verbosity); gsm_option(r, GSM_OPT_FAST, &fast); for (;;) { if ((cc = fread((char *)source, 1, sizeof(source), f)) == 0) { gsm_destroy(r);#ifdef COUNT_OVERFLOW dump_overflow(stderr);#endif return; } if (cc != sizeof(source)) { error = 1; perror(filename); fprintf(stderr, "%s: cannot read input from %s\n", pname, filename); gsm_destroy(r); return; } gsm_encode(r, source, buf); gsm_explode(r, buf, source); /* 76 shorts */ if (write(1, source, sizeof(*source) * 76) != sizeof(*source) * 76) { perror("write"); error = 1; gsm_destroy(r); return; } }}main P2((ac, av), int ac, char ** av){ int opt; extern char * optarg; extern int optind; FILE * f; if (!(pname = av[0])) pname = "inp2cod"; while ((opt = getopt(ac, av, "vF")) != EOF) switch (opt) { case 'v': verbosity++; break; case 'F': fast++; break; default: usage(); } ac -= optind; av += optind; if (!ac) process(stdin, "*stdin*"); else for (; *av; av++) { if (!(f = fopen(*av, "r"))) perror(*av); else { process(f, *av); fclose(f); } } exit(error);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -