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

📄 toast.c

📁 gsm-1.0.12.tar.gz
💻 C
📖 第 1 页 / 共 2 页
字号:
# else	if (stat(name, st) < 0)# endif	{		perror(name);		fprintf(stderr, "%s: cannot stat \"%s\"\n", progname, name);		return 0;	}	if (!S_ISREG(st->st_mode)) {		fprintf(stderr,			"%s: \"%s\" is not a regular file -- unchanged.\n",			progname, name);		return 0;	}	if (st->st_nlink > 1 && !f_cat && !f_precious) {		fprintf(stderr, 		      "%s: \"%s\" has %s other link%s -- unchanged.\n",			progname,name,st->st_nlink - 1,"s" + (st->st_nlink<=2));		return 0;	}	return 1;}static void prepare_io P1(( desc), struct fmtdesc * desc){	output      = desc->output;	input       = desc->input;	init_input  = desc->init_input;	init_output = desc->init_output;}static struct fmtdesc * grok_format P1((name), char * name){	char * c;	struct fmtdesc ** f;	if (name) {		c = plainname(name);		for (f = alldescs; *f; f++) {			if (  (*f)->suffix			   && *(*f)->suffix			   && suffix(c, (*f)->suffix)) {				free(c);				return *f;			}		}		free(c);	}	return (struct fmtdesc *)0;}static int open_input P2((name, st), char * name, struct stat * st){	struct fmtdesc * f = f_format;	st->st_nlink = 0;	/* indicates `undefined' value */	if (!name) {		inname = (char *)NULL;		in     = stdin;#ifdef	HAS__FSETMODE		_fsetmode(in, "b");#endif	}	else {		if (f_decode) inname = codename(name);		else {			if (!f_cat && suffix(name, SUFFIX_TOASTED)) {				fprintf(stderr,			"%s: %s already has \"%s\" suffix -- unchanged.\n",					progname, name, SUFFIX_TOASTED );				return 0;			}			inname = strcpy(emalloc(strlen(name)+1), name);		}		if (!(in = fopen(inname, READ))) {			perror(inname);	/* not guaranteed to be valid here */			fprintf(stderr, "%s: cannot open \"%s\" for reading\n",				progname, inname);			return 0;		}		if (!okay_as_input(inname, in, st)) return 0;		if (!f) f = grok_format(inname);	}	prepare_io( f ? f : & DEFAULT_FORMAT );	return 1;}static int open_output P1((name), char *name){	if (!name || f_cat) {		out     = stdout;		outname = (char *)NULL;#ifdef	HAS__FSETMODE		_fsetmode(out, "b"); #endif	}	else {		int outfd = -1;		char * o;		o = (*(f_decode ? plainname : codename))(name);		if (!length_okay(o)) return 0;		if ((outfd = open(o, O_WRITE_EXCL, 0666)) >= 0)			out = fdopen(outfd, WRITE);		else if (errno != EEXIST) out = (FILE *)NULL;		else if (ok_to_replace(o)) out = fopen(o, WRITE);		else return 0;		if (!out) {			perror(o);			fprintf(stderr,				"%s: can't open \"%s\" for writing\n",				progname, o);			if (outfd >= 0) (void)close(outfd);			return 0;		}		outname = o;	}	return 1;}static int process_encode P0(){	gsm      	r;	gsm_signal    	s[ 160 ];	gsm_frame	d; 	int		cc;	if (!(r = gsm_create())) {		perror(progname);		return -1;	}	(void)gsm_option(r, GSM_OPT_FAST,       &f_fast);	(void)gsm_option(r, GSM_OPT_VERBOSE,    &f_verbose);	(void)gsm_option(r, GSM_OPT_LTP_CUT,	&f_ltp_cut);	while ((cc = (*input)(s)) > 0) {		if (cc < sizeof(s) / sizeof(*s))			memset((char *)(s+cc), 0, sizeof(s)-(cc * sizeof(*s)));		gsm_encode(r, s, d);		if (fwrite((char *)d, sizeof(d), 1, out) != 1) {			perror(outname ? outname : "stdout");			fprintf(stderr, "%s: error writing to %s\n",				progname, outname ? outname : "stdout");			gsm_destroy(r);			return -1;		}	}	if (cc < 0) {		perror(inname ? inname : "stdin");		fprintf(stderr, "%s: error reading from %s\n",			progname, inname ? inname : "stdin");		gsm_destroy(r);		return -1;	}	gsm_destroy(r);	return 0;}static int process_decode P0(){	gsm      	r;	gsm_frame	s;	gsm_signal	d[ 160 ]; 	int		cc;	if (!(r = gsm_create())) {	/* malloc failed */		perror(progname);		return -1;	}	(void)gsm_option(r, GSM_OPT_FAST,    &f_fast);	(void)gsm_option(r, GSM_OPT_VERBOSE, &f_verbose);	while ((cc = fread(s, 1, sizeof(s), in)) > 0) {		if (cc != sizeof(s)) {			if (cc >= 0) fprintf(stderr,			"%s: incomplete frame (%d byte%s missing) from %s\n",					progname, sizeof(s) - cc,					"s" + (sizeof(s) - cc == 1),					inname ? inname : "stdin" );			gsm_destroy(r);			errno = 0;			return -1;		}		if (gsm_decode(r, s, d)) {			fprintf(stderr, "%s: bad frame in %s\n", 				progname, inname ? inname : "stdin");			gsm_destroy(r);			errno = 0;			return -1;		}		if ((*output)(d) < 0) {			perror(outname);			fprintf(stderr, "%s: error writing to %s\n",					progname, outname);			gsm_destroy(r);			return -1;		}	}	if (cc < 0) {		perror(inname ? inname : "stdin" );		fprintf(stderr, "%s: error reading from %s\n", progname,			inname ? inname : "stdin");		gsm_destroy(r);		return -1;	}	gsm_destroy(r);	return 0;}static int process P1((name), char * name){	int step = 0;	out     = (FILE *)0;	in      = (FILE *)0;	outname = (char *)0;	inname  = (char *)0;	if (!open_input(name, &instat) || !open_output(name))		goto err;	if ((*(f_decode ? init_output    : init_input))()) {		fprintf(stderr, "%s: error %s %s\n",			progname,			f_decode ? "writing header to" : "reading header from",			f_decode ? (outname ? outname : "stdout")				 : (inname ? inname : "stdin"));		goto err;	}	if ((*(f_decode ? process_decode : process_encode))())		goto err;	if (fflush(out) < 0 || ferror(out)) {		perror(outname ? outname : "stdout");		fprintf(stderr, "%s: error writing \"%s\"\n", progname,				outname ? outname:"stdout");		goto err;	}	if (out != stdout) {		update_times();		update_mode ();		update_own  ();		if (fclose(out) < 0) {			perror(outname);			fprintf(stderr, "%s: error writing \"%s\"\n",				progname, outname);			goto err;		}		if (outname != name) free(outname);		outname = (char *)0;	}	out = (FILE *)0;	if (in  != stdin) {		(void)fclose(in), in = (FILE *)0;		if (!f_cat && !f_precious) {			if (unlink(inname) < 0) {				perror(inname);				fprintf(stderr,					"%s: source \"%s\" not deleted.\n",					progname, inname);			}			goto err;		}		if (inname != name) free(inname);		inname = (char *)0;	}	return 0;	/*	 *  Error handling and cleanup.	 */err:	if (out && out != stdout) {		(void)fclose(out), out = (FILE *)0;		if (unlink(outname) < 0 && errno != ENOENT && errno != EINTR) {			perror(outname);			fprintf(stderr, "%s: could not unlink \"%s\"\n",				progname, outname);		}	}	if (in && in != stdin) (void)fclose(in), in = (FILE *)0;	if (inname  && inname  != name) free(inname);	if (outname && outname != name) free(outname);	return -1;}static void version P0(){	printf( "%s 1.0, version %s\n",		progname,		"$Id: toast.c,v 1.8 1996/07/02 10:41:04 jutta Exp $" );}static void help P0(){	printf("Usage: %s [-fcpdhvaulsFC] [files...]\n", progname);	printf("\n");	printf(" -f  force     Replace existing files without asking\n");	printf(" -c  cat       Write to stdout, do not remove source files\n");	printf(" -d  decode    Decode data (default is encode)\n");	printf(" -p  precious  Do not delete the source\n");	printf("\n");	printf(" -u  u-law     Force 8 kHz/8 bit u-law in/output format\n");	printf(" -s  sun .au   Force Sun .au u-law in/output format\n");	printf(" -a  A-law     Force 8 kHz/8 bit A-law in/output format\n");	printf(" -l  linear    Force 16 bit linear in/output format\n");	printf("\n");	printf(" -F  fast      Sacrifice conformance to performance\n");	printf(" -C  cutoff    Ignore most samples during LTP\n");	printf(" -v  version   Show version information\n");	printf(" -h  help      Print this text\n");	printf("\n");}static void set_format P1((f), struct fmtdesc * f){	if (f_format && f_format != f) {		fprintf( stderr,	"%s: only one of -[uals] is possible (%s -h for help)\n",			progname, progname);		exit(1);	}	f_format = f;}int main P2((ac, av), int ac, char **av){	int  		opt;	extern int	optind;	extern char	* optarg;	parse_argv0(*av);	while ((opt = getopt(ac, av, "fcdpvhuaslVFC:")) != EOF) switch (opt) {	case 'd': f_decode   = 1; break;	case 'f': f_force    = 1; break;	case 'c': f_cat      = 1; break;	case 'p': f_precious = 1; break;	case 'F': f_fast     = 1; break;	case 'C': f_ltp_cut  = 100; break;#ifndef	NDEBUG	case 'V': f_verbose  = 1; break;	/* undocumented */#endif	case 'u': set_format( &f_ulaw   ); break;	case 'l': set_format( &f_linear ); break;	case 'a': set_format( &f_alaw	); break;	case 's': set_format( &f_audio  ); break;	case 'v': version(); exit(0);	case 'h': help();    exit(0);	default: 	usage:		fprintf(stderr,	"Usage: %s [-fcpdhvuaslFC] [files...] (-h for help)\n",			progname);		exit(1);	}	f_precious |= f_cat;	av += optind;	ac -= optind;	catch_signals(onintr);	if (ac <= 0) process( (char *)0 );	else while (ac--) process( *av++ );	exit(0);}

⌨️ 快捷键说明

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