view miscutil/raw2wav.c @ 530:96c4ed5529bf

libgsmfr2 preproc: implement support for DTXd
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 19 Sep 2024 20:15:54 +0000
parents c1dc094f0821
children
line wrap: on
line source

/*
 * This program reads a 16-bit linear PCM speech recording in raw format
 * (either BE or LE) and converts it into WAV container format.
 */

#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <strings.h>
#include "../libtest/wavwriter.h"

static void
swap_bytes(bytes, cc)
	uint8_t *bytes;
	unsigned cc;
{
	uint8_t *dp, *endp;
	int t;

	dp = bytes;
	endp = bytes + cc;
	while (dp < endp) {
		t = dp[0];
		dp[0] = dp[1];
		dp[1] = t;
		dp += 2;
	}
}

main(argc, argv)
	char **argv;
{
	int big_endian;
	FILE *binf;
	void *wav;
	uint8_t bytes[320];
	int cc;

	if (argc != 4) {
usage:		fprintf(stderr, "usage: %s be|le input.raw output.wav\n",
			argv[0]);
		exit(1);
	}
	if (!strcmp(argv[1], "be"))
		big_endian = 1;
	else if (!strcmp(argv[1], "le"))
		big_endian = 0;
	else
		goto usage;
	binf = fopen(argv[2], "r");
	if (!binf) {
		perror(argv[2]);
		exit(1);
	}
	wav = wav_write_open(argv[3], 8000, 16, 1);
	if (!wav) {
		perror(argv[3]);
		exit(1);
	}
	for (;;) {
		cc = fread(bytes, 1, sizeof bytes, binf);
		if (cc <= 0)
			break;
		if (cc & 1) {
			fprintf(stderr, "error: %s has odd number of bytes\n",
				argv[2]);
			exit(1);
		}
		if (big_endian)
			swap_bytes(bytes, cc);
		wav_write_data(wav, bytes, cc);
	}
	wav_write_close(wav);
	exit(0);
}