Hands-off reading for FLAC.
[disorder] / lib / hreader.h
CommitLineData
5e57438c
RK
1/*
2 * This file is part of DisOrder
3 * Copyright (C) 2010 Richard Kettlewell
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18/** @file lib/hreader.h
19 * @brief Hands-off reader - read files without keeping them open
20 */
21#ifndef HREADER_H
22#define HREADER_H
23
24#include <unistd.h>
25
26/** @brief A hands-off reader
27 *
28 * Allows files to be read without holding them open.
29 */
30struct hreader {
31 const char *path; /* file to read */
21237d05 32 off_t size; /* file size */
281d0fd4
RK
33 off_t read_offset; /* for next hreader_read() */
34 off_t buf_offset; /* offset of start of buffer */
5e57438c
RK
35 char *buffer; /* input buffer */
36 size_t bufsize; /* buffer size */
37 size_t bytes; /* size of last read */
5e57438c
RK
38};
39
40/** @brief Initialize a hands-off reader
41 * @param path File to read
42 * @param h Reader to initialize
21237d05 43 * @return 0 on success, -1 on error
5e57438c 44 */
21237d05 45int hreader_init(const char *path, struct hreader *h);
5e57438c
RK
46
47/** @brief Read some bytes
48 * @param h Reader to read from
49 * @param buffer Where to store bytes
50 * @param n Maximum bytes to read
51 * @return Bytes read, or 0 at EOF, or -1 on error
52 */
53int hreader_read(struct hreader *h, void *buffer, size_t n);
54
281d0fd4
RK
55/** @brief Read some bytes at a given offset
56 * @param h Reader to read from
57 * @param offset Offset to read at
58 * @param buffer Where to store bytes
59 * @param n Maximum bytes to read
60 * @return Bytes read, or 0 at EOF, or -1 on error
5e57438c 61 */
281d0fd4 62int hreader_pread(struct hreader *h, void *buffer, size_t n, off_t offset);
5e57438c 63
21237d05
RK
64/** @brief Seek within a file
65 * @param h Reader to seek
66 * @param offset Offset
67 * @param whence SEEK_*
68 * @return Result offset
69 */
70off_t hreader_seek(struct hreader *h, off_t offset, int whence);
71
d868c56e
RK
72/** @brief Return file size
73 * @param h Reader to find size of
74 * @return Size in bytes
75 */
76static inline off_t hreader_size(const struct hreader *h) {
77 return h->size;
78}
79
80/** @brief Test for end of file
81 * @param h Reader to test
82 * @return 1 at eof, 0 otherwise
83 *
84 * This tells you whether the next read will return 0 bytes, rather than
85 * whether the last read reached end of file. So it is slightly different to
86 * feof().
87 */
88static inline int hreader_eof(const struct hreader *h) {
89 return h->read_offset == h->size;
90}
91
5e57438c
RK
92#endif /* HREADER_H */
93
5e57438c
RK
94/*
95Local Variables:
96c-basic-offset:2
97comment-column:40
98fill-column:79
99indent-tabs-mode:nil
100End:
101*/