h_nlrm.c

来自「speech signal process tools」· C语言 代码 · 共 96 行

C
96
字号
/********************************************//** NIST Speech Header Resources (SPHERE)  **//** Release 1.5 (beta)                     **//** Stan Janet (stan@jaguar.ncsl.nist.gov) **//** October 1990                           **//********************************************//* File: h_nlrm.c */#include <stdio.h>#include <strings.h>#include <sys/types.h>#include <sys/stat.h>#include "header.h"#include "sp.h"#include "version.h"extern int ignore_failure;extern char *prog;char opspec[] = "D:F:fo:u";char ops[]    = "F";int wav_edit(f1,f2,fct,f,fop)char *f1, *f2, *f[], fop[];int fct;{struct header_t *h;char *errmsg;register FILE *fp1, *fp2;int i, failed;long dummy;fp1 = fopen(f1,"r");if (fp1 == FPNULL) {	(void) fprintf(stderr,"%s: %s: Error opening for reading\n",prog,f1);	return -1;}fp2 = fopen(f2,"w");if (fp2 == FPNULL) {	(void) fprintf(stderr,"%s: %s: Error opening %s for writing\n",		prog,f1,f2);	(void) fclose(fp1);	return -1;}h = sp_open_header(fp1,1,&errmsg);if (h == HDRNULL) {	(void) fprintf(stderr,"%s: %s: Error reading header -- %s\n",		prog,f1,errmsg);	(void) fclose(fp1);	(void) fclose(fp2);	return -1;}{register int fc;register struct field_t **fv;char *p;fv = h->fv;fc = h->fc;for (i=0; i < fc; i++) {	if (fv[i]->type != T_STRING)		continue;	p = fv[i]->data + (fv[i]->datalen - 1);	while ((fv[i]->datalen > 0) && (*p == '\n')) {		*p-- = '\0';		--fv[i]->datalen;	}}}if ((sp_write_header(fp2,h,&dummy,&dummy) < 0) || (sp_fpcopy(fp1,fp2) < 0)) {	(void) fprintf(stderr,"%s: %s: Error writing to %s\n",		prog,f1,f2);	(void) unlink(f2);	(void) fclose(fp1);	(void) fclose(fp2);	(void) sp_close_header(h);	return -1;}(void) fclose(fp1);(void) fclose(fp2);if (sp_close_header(h) < 0) {	(void) fprintf(stderr,"%s: %s: Warning -- close_header failed\n",		prog,f1);	return -1;}return 0;}

⌨️ 快捷键说明

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