mirror of
https://github.com/videolan/vlc.git
synced 2024-11-27 03:47:46 +08:00
171 lines
4.8 KiB
C
171 lines
4.8 KiB
C
/*****************************************************************************
|
|
* vlc_memstream.h:
|
|
*****************************************************************************
|
|
* Copyright (C) 2016 Rémi Denis-Courmont
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation; either version 2.1 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
|
|
*****************************************************************************/
|
|
|
|
#ifndef VLC_MEMSTREAM_H
|
|
# define VLC_MEMSTREAM_H 1
|
|
|
|
# include <stdarg.h>
|
|
# include <stdio.h>
|
|
|
|
/**
|
|
* \defgroup memstream In-memory byte streams
|
|
* \ingroup cext
|
|
*
|
|
* In-memory byte stream are a portable wrapper for in-memory formatted output
|
|
* byte streams. Compare with POSIX @c open_memstream().
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* In-memory stream object.
|
|
*/
|
|
struct vlc_memstream
|
|
{
|
|
union
|
|
{
|
|
FILE *stream;
|
|
int error;
|
|
};
|
|
char *ptr; /**< Buffer start address */
|
|
size_t length; /**< Buffer length in bytes */
|
|
};
|
|
|
|
/**
|
|
* Initializes a byte stream object.
|
|
*
|
|
* @note Even when this function fails, the stream object is initialized and
|
|
* can be used safely. It is sufficient to check for errors from
|
|
* vlc_memstream_flush() and vlc_memstream_close().
|
|
*
|
|
* Compare with POSIX @c open_memstream().
|
|
*
|
|
* @param ms byte stream object
|
|
*
|
|
* @retval 0 on success
|
|
* @retval EOF on error
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_open(struct vlc_memstream *ms);
|
|
|
|
/**
|
|
* Flushes a byte stream object.
|
|
*
|
|
* This function ensures that any previous write to the byte stream is flushed
|
|
* and the in-memory buffer is synchronized. It can be used observe the content
|
|
* of the buffer before the final vlc_memstream_close().
|
|
*
|
|
* Compare with @c fflush().
|
|
*
|
|
* @note vlc_memstream_close() implicitly flushes the object.
|
|
* Calling vlc_memstream_flush() before closing is thus superfluous.
|
|
*
|
|
* @warning @c ms->ptr must <b>not</b> be freed. It can only be freed after
|
|
* a successful call to vlc_memstream_close().
|
|
*
|
|
* @retval 0 success, i.e., @c ms->ptr and @c ms->length are valid
|
|
* @retval EOF failure (@c ms->ptr and @c ms->length are unspecified)
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_flush(struct vlc_memstream *ms) VLC_USED;
|
|
|
|
/**
|
|
* Closes a byte stream object.
|
|
*
|
|
* This function flushes the stream object, releases any underlying
|
|
* resource, except for the heap-allocated formatted buffer @c ms->ptr,
|
|
* and deinitializes the object.
|
|
*
|
|
* On success, the caller is responsible for freeing the buffer with @c free().
|
|
*
|
|
* Compare with @c fclose().
|
|
*
|
|
* \retval 0 success
|
|
* \retval EOF failure (@c ms->ptr and @c ms->length are unspecified)
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_close(struct vlc_memstream *ms) VLC_USED;
|
|
|
|
/**
|
|
* Appends a binary blob to a byte stream.
|
|
*
|
|
* Compare with @c fwrite().
|
|
*
|
|
* @param ms the VLC memstream to write to
|
|
* @param ptr start address of the blob
|
|
* @param len byte length of the blob
|
|
*/
|
|
VLC_API
|
|
size_t vlc_memstream_write(struct vlc_memstream *ms,
|
|
const void *ptr, size_t len);
|
|
|
|
/**
|
|
* Appends a single byte to a byte stream.
|
|
*
|
|
* Compare with @c putc() or @c fputc().
|
|
*
|
|
* @param ms the VLC memstream to write to
|
|
* @param c Unsigned byte value converted to int.
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_putc(struct vlc_memstream *ms, int c);
|
|
|
|
/**
|
|
* Appends a nul-terminated string to a byte stream.
|
|
*
|
|
* Compare with @c fputs().
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_puts(struct vlc_memstream *ms, const char *str);
|
|
|
|
/**
|
|
* Appends a formatted string to a byte stream.
|
|
*
|
|
* Compare with @c vfprintf().
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_vprintf(struct vlc_memstream *ms, const char *fmt,
|
|
va_list args);
|
|
|
|
/**
|
|
* Appends a formatted string to a byte stream.
|
|
*
|
|
* Compare with @c fprintf().
|
|
*/
|
|
VLC_API
|
|
int vlc_memstream_printf(struct vlc_memstream *s, const char *fmt,
|
|
...) VLC_FORMAT(2,3);
|
|
|
|
# ifdef __GNUC__
|
|
static inline int vlc_memstream_puts_len(struct vlc_memstream *ms,
|
|
const char *str, size_t len)
|
|
{
|
|
return (vlc_memstream_write(ms, str, len) == len) ? (int)len : EOF;
|
|
}
|
|
# define vlc_memstream_puts(ms,s) \
|
|
(__builtin_constant_p(__builtin_strlen(s)) ? \
|
|
vlc_memstream_puts_len(ms,s,__builtin_strlen(s)) : \
|
|
vlc_memstream_puts(ms,s))
|
|
# endif
|
|
|
|
/** @} */
|
|
|
|
#endif /* VLC_MEMSTREAM_H */
|