diff options
author | Lasse Collin <lasse.collin@tukaani.org> | 2017-03-30 20:00:09 +0300 |
---|---|---|
committer | Lasse Collin <lasse.collin@tukaani.org> | 2017-03-30 20:00:09 +0300 |
commit | a27920002dbc469f778a134fc665b7c3ea73701b (patch) | |
tree | e2b222f24d57e10d562e98f45dbd08f41bc30077 /src/liblzma/api | |
parent | liblzma: Fix lzma_memlimit_set(strm, 0). (diff) | |
download | xz-a27920002dbc469f778a134fc665b7c3ea73701b.tar.xz |
liblzma: Add generic support for input seeking (LZMA_SEEK).
Also mention LZMA_SEEK in xz/message.c to silence a warning.
Diffstat (limited to 'src/liblzma/api')
-rw-r--r-- | src/liblzma/api/lzma/base.h | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/src/liblzma/api/lzma/base.h b/src/liblzma/api/lzma/base.h index a6005acc..9b3e9e1a 100644 --- a/src/liblzma/api/lzma/base.h +++ b/src/liblzma/api/lzma/base.h @@ -234,6 +234,23 @@ typedef enum { * can be a sign of a bug in liblzma. See the documentation * how to report bugs. */ + + LZMA_SEEK = 12 + /**< + * \brief Request to change the input file position + * + * Some coders can do random access in the input file. The + * initialization functions of these coders take the file size + * as an argument. No other coders can return LZMA_SEEK. + * + * When this value is returned, the application must seek to + * the file position given in lzma_stream.seek_in. This value + * is guaranteed to never exceed the file size that was + * specified at the coder initialization. + * + * After seeking the application should read new input and + * pass it normally via lzma_stream.next_in and .avail_in. + */ } lzma_ret; @@ -514,7 +531,19 @@ typedef struct { void *reserved_ptr2; void *reserved_ptr3; void *reserved_ptr4; - uint64_t reserved_int1; + + /** + * \brief New seek input position for LZMA_SEEK + * + * When lzma_code() returns LZMA_SEEK, the new input position needed + * by liblzma will be available seek_in. The value is guaranteed to + * not exceed the file size that was specified when this lzma_stream + * was initialized. + * + * In all other situations the value of this variable is undefined. + */ + uint64_t seek_in; + uint64_t reserved_int2; size_t reserved_int3; size_t reserved_int4; |