diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-09-23 11:00:27 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-10-24 15:57:18 +0200 |
commit | ee26abcab9faf037cf87438cca20d54e5b0edd05 (patch) | |
tree | 2880119327da17d5024b06a5e63808a295b41410 /include/xfrm | |
parent | 6e7b20a41c8a7f10392884e1741b031b579a93fa (diff) |
Cleanup: move xfrm stream wrappers to libxfrm
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'include/xfrm')
-rw-r--r-- | include/xfrm/wrap.h | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/include/xfrm/wrap.h b/include/xfrm/wrap.h new file mode 100644 index 0000000..48ae112 --- /dev/null +++ b/include/xfrm/wrap.h @@ -0,0 +1,55 @@ +/* SPDX-License-Identifier: GPL-3.0-or-later */ +/* + * wrap.h + * + * Copyright (C) 2019 David Oberhollenzer <goliath@infraroot.at> + */ +#ifndef XFRM_WRAP_H +#define XFRM_WRAP_H + +#include "sqfs/predef.h" +#include "xfrm/stream.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Create an input stream that transparently decodes data. + * + * @memberof sqfs_istream_t + * + * This function creates an input stream that wraps an underlying input stream + * that is encoded/compressed and transparently decodes the data when reading + * from it. + * + * @param strm A pointer to another stream that should be wrapped. + * @param xfrm The transformation stream to use. + * + * @return A pointer to an input stream on success, NULL on failure. + */ +SQFS_INTERNAL sqfs_istream_t *istream_xfrm_create(sqfs_istream_t *strm, + xfrm_stream_t *xfrm); + +/** + * @brief Create an output stream that transparently encodes data. + * + * @memberof sqfs_ostream_t + * + * This function creates an output stream that transparently encodes + * (e.g. compresses) all data appended to it and writes it to an + * underlying, wrapped output stream. + * + * @param strm A pointer to another stream that should be wrapped. + * @param xfrm The transformation stream to use. + * + * @return A pointer to an output stream on success, NULL on failure. + */ +SQFS_INTERNAL sqfs_ostream_t *ostream_xfrm_create(sqfs_ostream_t *strm, + xfrm_stream_t *xfrm); + +#ifdef __cplusplus +} +#endif + +#endif /* XFRM_WRAP_H */ |