1 struct check_wav_context;
4 * These come from the command line arguments.
6 * Different users of the check_wav API have different arg_info structs,
7 * so we need a universal variant for these.
10 /** Number of channels, or the default value. */
12 /** Whether the channel count was given. */
14 /** Same semantics as \a channels_count. */
16 /** Whether the sample rate was given. */
17 int sample_rate_given;
18 /** Same semantics as \a sample_rate. */
19 int sample_format_arg;
20 /** Whether the sample format was given. */
21 int sample_format_given;
25 * Copy the wav parameters.
27 * \param dst Usually a pointer to struct wav_params.
28 * \param src Usually a pointer to some args_info struct.
30 * This can not be implemented as a function since the type of the structure
31 * pointed to by \a src depends on the application.
33 #define COPY_WAV_PARMS(dst, src) \
34 (dst)->channels_arg = (src)->channels_arg; \
35 (dst)->channels_given = (src)->channels_given; \
36 (dst)->sample_rate_arg = (src)->sample_rate_arg; \
37 (dst)->sample_rate_given = (src)->sample_rate_given; \
38 (dst)->sample_format_arg = (src)->sample_format_arg; \
39 (dst)->sample_format_given = (src)->sample_format_given;
41 struct check_wav_context *check_wav_init(struct btr_node *parent,
42 struct btr_node *child, struct wav_params *params,
43 struct btr_node **cw_btrn);
44 void check_wav_pre_select(struct sched *s, struct check_wav_context *cwc);
45 int check_wav_post_select(struct check_wav_context *cwc);
46 void check_wav_shutdown(struct check_wav_context *cwc);