X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=include%2Fwimlib%2Fwim.h;h=4afa60eb8594943ecc8ad06e4d8912384e51627b;hb=5944d11442d5df847c3393951a8563412d16e640;hp=541d67ae3190e700b005928f9f827bb21805fb1e;hpb=ecce298b62c1625e28e2da5b594a8ac7e0afdd35;p=wimlib diff --git a/include/wimlib/wim.h b/include/wimlib/wim.h index 541d67ae..4afa60eb 100644 --- a/include/wimlib/wim.h +++ b/include/wimlib/wim.h @@ -42,6 +42,9 @@ struct WIMStruct { /* Temporary field */ void *private; + /* LZX compression context for default thread */ + struct wimlib_lzx_context *lzx_context; + struct list_head subwims; struct list_head subwim_node; @@ -67,6 +70,21 @@ struct WIMStruct { /* One of WIMLIB_COMPRESSION_TYPE_*, cached from the header flags. */ u8 compression_type : 2; + + /* Overwritten compression type for wimlib_overwrite() or + * wimlib_write(). Can be changed by + * wimlib_set_output_compression_type(); otherwise is the same as + * compression_type. */ + u8 out_compression_type : 2; + + /* Uncompressed size of compressed chunks in this WIM (cached from + * header). */ + u32 chunk_size; + + /* Overridden chunk size for wimlib_overwrite() or wimlib_write(). Can + * be changed by wimlib_set_output_chunk_size(); otherwise is the same + * as chunk_size. */ + u32 out_chunk_size; }; static inline bool wim_is_pipable(const WIMStruct *wim) @@ -84,11 +102,14 @@ static inline bool wim_has_metadata(const WIMStruct *wim) return (wim->image_metadata != NULL || wim->hdr.image_count == 0); } -extern void +extern int wim_recalculate_refcnts(WIMStruct *wim); extern int -init_wim_header(struct wim_header *hdr, int ctype); +set_wim_hdr_cflags(int ctype, struct wim_header *hdr); + +extern int +init_wim_header(struct wim_header *hdr, int ctype, u32 chunk_size); extern int read_wim_header(const tchar *filename, struct filedes *in_fd,