/** * The MIT License (MIT) * * Copyright (c) 2013-2018 Winlin * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef SRS_KERNEL_IO_HPP #define SRS_KERNEL_IO_HPP #include // for srs-librtmp, @see https://github.com/ossrs/srs/issues/213 #ifndef _WIN32 #include #endif /** * The reader to read data from channel. */ class ISrsReader { public: ISrsReader(); virtual ~ISrsReader(); public: /** * Read bytes from reader. * @param nread How many bytes read from channel. NULL to ignore. */ virtual srs_error_t read(void* buf, size_t size, ssize_t* nread) = 0; }; /** * The seeker to seek with a device. */ class ISrsSeeker { public: ISrsSeeker(); virtual ~ISrsSeeker(); public: /** * The lseek() function repositions the offset of the file descriptor fildes to the argument offset, according to the * directive whence. lseek() repositions the file pointer fildes as follows: * If whence is SEEK_SET, the offset is set to offset bytes. * If whence is SEEK_CUR, the offset is set to its current location plus offset bytes. * If whence is SEEK_END, the offset is set to the size of the file plus offset bytes. * @param seeked Upon successful completion, lseek() returns the resulting offset location as measured in bytes from * the beginning of the file. NULL to ignore. */ virtual srs_error_t lseek(off_t offset, int whence, off_t* seeked) = 0; }; /** * The reader and seeker. */ class ISrsReadSeeker : virtual public ISrsReader, virtual public ISrsSeeker { public: ISrsReadSeeker(); virtual ~ISrsReadSeeker(); }; /** * The writer to write stream data to channel. */ class ISrsStreamWriter { public: ISrsStreamWriter(); virtual ~ISrsStreamWriter(); public: /** * write bytes over writer. * @nwrite the actual written bytes. NULL to ignore. */ virtual srs_error_t write(void* buf, size_t size, ssize_t* nwrite) = 0; }; /** * The vector writer to write vector(iovc) to channel. */ class ISrsVectorWriter { public: ISrsVectorWriter(); virtual ~ISrsVectorWriter(); public: /** * write iov over writer. * @nwrite the actual written bytes. NULL to ignore. * @remark for the HTTP FLV, to writev to improve performance. * @see https://github.com/ossrs/srs/issues/405 */ virtual srs_error_t writev(const iovec *iov, int iov_size, ssize_t* nwrite) = 0; }; /** * The generally writer, stream and vector writer. */ class ISrsWriter : virtual public ISrsStreamWriter, virtual public ISrsVectorWriter { public: ISrsWriter(); virtual ~ISrsWriter(); }; /** * The writer and seeker. */ class ISrsWriteSeeker : virtual public ISrsWriter, virtual public ISrsSeeker { public: ISrsWriteSeeker(); virtual ~ISrsWriteSeeker(); }; #endif