X-Git-Url: https://wimlib.net/git/?p=wimlib;a=blobdiff_plain;f=include%2Fwimlib%2Fwim.h;h=00de8a53118a74d634b1d3385bfe16f3593015a2;hp=860a3236dd543abcc5770fbfb7027f9ac0554ca7;hb=3a0b45be3635a632f3acd97b170dead2de29e8a8;hpb=62458ef728064652932d49fbab1116b2f2462fa8 diff --git a/include/wimlib/wim.h b/include/wimlib/wim.h index 860a3236..00de8a53 100644 --- a/include/wimlib/wim.h +++ b/include/wimlib/wim.h @@ -67,6 +67,11 @@ struct WIMStruct { * referenced from other WIMStructs. */ struct blob_table *blob_table; + /* The number of references to this WIMStruct. This is equal to the + * number of resource descriptors that reference this WIMStruct, plus 1 + * if wimlib_free() still needs to be called. */ + ssize_t refcnt; + /* * The 1-based index of the currently selected image in this WIMStruct, * or WIMLIB_NO_IMAGE if no image is currently selected. @@ -105,16 +110,6 @@ struct WIMStruct { u8 decompressor_ctype; u32 decompressor_max_block_size; - /* - * 'subwims' is the list of dependent WIMStructs (linked by - * 'subwim_node') that have been opened by calls to - * wimlib_reference_resource_files(). These WIMStructs must be retained - * so that resources from them can be used. They are internal to the - * library and are not visible to API users. - */ - struct list_head subwims; - struct list_head subwim_node; - /* Temporary field; use sparingly */ void *private; @@ -124,6 +119,10 @@ struct WIMStruct { /* 1 if the WIM file has been locked for appending, otherwise 0 */ u8 locked_for_append : 1; + /* 1 if the WIM file is currently being compacted by wimlib_overwrite() + * with WIMLIB_WRITE_FLAG_UNSAFE_COMPACT */ + u8 being_compacted : 1; + /* If this WIM is backed by a file, then this is the compression type * for non-solid resources in that file. */ u8 compression_type; @@ -186,6 +185,9 @@ static inline bool wim_is_pipable(const WIMStruct *wim) return (wim->hdr.magic == PWM_MAGIC); } +extern void +finalize_wim_struct(WIMStruct *wim); + extern bool wim_has_solid_resources(const WIMStruct *wim);