ref: 210336f9b78b4089163bc16804a1e76984c6c46d
dir: /src/nulfile.c/
/* * July 5, 1991 * Copyright 1991 Lance Norskog And Sundry Contributors * This source code is freely redistributable and may be used for * any purpose. This copyright notice must be maintained. * Lance Norskog And Sundry Contributors are not responsible for * the consequences of using this software. */ /* * Sound Tools null file format driver. * Written by Carsten Borchardt * The author is not responsible for the consequences * of using this software */ #include "st_i.h" #include <string.h> int st_nulstartread(ft_t ft) { /* If format parameters are not given, set somewhat arbitrary * (but commonly used) defaults: */ if (ft->info.rate == 0) ft->info.rate = 44100; if (ft->info.channels == -1) ft->info.channels = 2; if (ft->info.size == -1) ft->info.size = ST_SIZE_WORD; if (ft->info.encoding == -1) ft->info.encoding = ST_ENCODING_SIGN2; return ST_SUCCESS; } st_ssize_t st_nulread(ft_t ft, st_sample_t *buf, st_ssize_t len) { /* Reading from null generates silence i.e. (st_sample_t)0. */ memset(buf, 0, sizeof(st_sample_t) * len); return len; /* Return number of samples "read". */ } st_ssize_t st_nulwrite(ft_t ft, const st_sample_t *buf, st_ssize_t len) { /* Writing to null just discards the samples */ return len; /* Return number of samples "written". */ } static const char *nulnames[] = { "null", "nul", /* For backwards compatibility with when -n did not exist */ NULL, }; static st_format_t st_nul_format = { nulnames, NULL, ST_FILE_STEREO | ST_FILE_NOSTDIO | ST_FILE_NOFEXT, st_nulstartread, st_nulread, st_format_nothing, st_format_nothing, st_nulwrite, st_format_nothing, st_format_nothing_seek }; const st_format_t *st_nul_format_fn(void) { return &st_nul_format; }