view ater/play_cmd.c @ 28:fa341317c844

pcm: fix bug in play-stop command
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 24 Jun 2024 20:38:58 +0000
parents 2742dbea95f1
children 1dda11905e85
line wrap: on
line source

/*
 * Here we implement user commands controlling file play functionality.
 */

#include <stdint.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <osmocom/core/select.h>

#include "globals.h"
#include "submux.h"
#include "read_file.h"

void cmd_play_file(int argc, char **argv)
{
	int nr, rc;
	struct ater_subslot *at;

	if (argc != 3) {
usage:		fprintf(stderr, "usage: %s 0|1|2|3 play-file.tul\n", argv[0]);
		return;
	}
	if (argv[1][0] < '0' || argv[1][0] > '3' || argv[1][1])
		goto usage;
	nr = argv[1][0] - '0';
	at = &subslots[nr];
	if (!at->is_active) {
		fprintf(stderr, "error: subslot %d is not active\n", nr);
		return;
	}
	if (at->play_buffer) {
		fprintf(stderr, "error: file play already in progress\n");
		return;
	}
	rc = read_binary_file(argv[2], at->is_efr, &at->play_buffer,
				&at->play_buf_total);
	if (rc < 0)
		return;		/* error msg already printed */
	at->play_buf_ptr = 0;
	at->play_wait_align = true;
}