FreeCalypso > hg > gsm-codec-lib
view frtest/encode.c @ 553:ebcf414b7d99
doc/TFO-transform: describe details for FRv1, both modes
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 07 Oct 2024 08:24:24 +0000 |
parents | f00925b533b7 |
children |
line wrap: on
line source
/* * This file is the main module for gsmfr-encode utility. */ #include <stdio.h> #include <stdint.h> #include <stdlib.h> #include "../libgsmfr2/tw_gsmfr.h" #include "../libtest/wavreader.h" #include "../libtest/wavrdhelp.h" main(argc, argv) char **argv; { void *wav; FILE *binf; struct gsmfr_0610_state *enc_state; int16_t pcm[160]; uint8_t frame[33]; int rc; if (argc != 3) { fprintf(stderr, "usage: %s input.wav output.gsm\n", argv[0]); exit(1); } wav = wav_read_open(argv[1]); if (!wav) { perror(argv[1]); exit(1); } rc = wavrd_check_header(wav, argv[1]); if (rc < 0) exit(1); /* error msg already printed */ binf = fopen(argv[2], "w"); if (!binf) { perror(argv[2]); exit(1); } enc_state = gsmfr_0610_create(); if (!enc_state) { fprintf(stderr, "gsmfr_0610_create() failed!\n"); exit(1); } for (;;) { rc = wavrd_get_pcm_block(wav, pcm); if (!rc) break; gsmfr_0610_encode_frame(enc_state, pcm, frame); fwrite(frame, 1, sizeof frame, binf); } fclose(binf); exit(0); }