aboutsummaryrefslogtreecommitdiff
path: root/tools/wave.h
blob: 87e8186e4a5ef820346e4db4b40704a4bfd92749 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/******************************************************************************
 *
 *  Copyright 2022 Google LLC
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at:
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 ******************************************************************************/

#ifndef __WAVE_H
#define __WAVE_H

#include <stdio.h>
#include <stdint.h>


/**
 * Read WAVE file header
 * fp              Opened file, moved after header on return
 * bitdepth        Return bitdepth
 * samplesize      Return size of samples, in bytes
 * samplerate      Return samplerate, in Hz
 * nchannels       Return number of channels
 * nframes         Return count of frames
 * return          0: Ok  -1: Bad or unsupported WAVE File
 */
int wave_read_header(FILE *fp, int *bitdepth, int *samplesize,
    int *samplerate, int *nchannels, int *nframes);

/**
 * Read PCM samples from wave file
 * fp              Opened file
 * samplesize      Size of samples, in bytes
 * nch, count      Number of channels and count of frames to read
 * buffer          Output buffer of `nchannels * count` interleaved samples
 * return          Number of frames read
 */
int wave_read_pcm(FILE *fp, int samplesize,
    int nch, int count, void *_buffer);

/**
 * Write WAVE file header
 * fp              Opened file, moved after header on return
 * bitdepth        Bitdepth
 * samplesize      Size of samples
 * samplerate      Samplerate, in Hz
 * nchannels       Number of channels
 * nframes         Count of frames
 */
void wave_write_header(FILE *fp, int bitdepth, int samplesize,
    int samplerate, int nchannels, int nframes);

/**
 * Write PCM samples to wave file
 * fp              Opened file
 * samplesize      Size of samples, in bytes
 * pcm, nch        PCM frames, as 'nch' interleaved samples
 * off, count      Offset and count of frames
 */
void wave_write_pcm(FILE *fp, int samplesize,
    const void *pcm, int nch, int off, int count);


#endif /* __WAVE_H */