mpd/src/io/Reader.hxx

58 lines
1.8 KiB
C++
Raw Normal View History

2014-08-07 18:10:23 +02:00
/*
2019-12-16 17:02:35 +01:00
* Copyright 2014-2019 Max Kellermann <max.kellermann@gmail.com>
2014-08-07 18:10:23 +02:00
*
2019-12-16 17:02:35 +01:00
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
2014-08-07 18:10:23 +02:00
*
2019-12-16 17:02:35 +01:00
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
2014-08-07 18:10:23 +02:00
*
2019-12-16 17:02:35 +01:00
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* FOUNDATION OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
2014-08-07 18:10:23 +02:00
*/
2019-12-16 17:02:35 +01:00
#ifndef READER_HXX
#define READER_HXX
2014-08-07 18:10:23 +02:00
#include <cstddef>
2014-08-07 18:10:23 +02:00
/**
* An interface that can read bytes from a stream until the stream
* ends.
*
* This interface is simpler and less cumbersome to use than
* #InputStream.
*/
class Reader {
public:
Reader() = default;
Reader(const Reader &) = delete;
/**
* Read data from the stream.
*
* @return the number of bytes read into the given buffer or 0
* on end-of-stream
2014-08-07 18:10:23 +02:00
*/
2021-10-13 11:28:04 +02:00
[[gnu::nonnull]]
virtual size_t Read(void *data, size_t size) = 0;
2014-08-07 18:10:23 +02:00
};
#endif