X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=src%2Fmetadata_resource.c;h=aebc5468cd0b30a24c6c8bc72a2bc70aab04916f;hb=90c19e287d02a962876f74e560812e75f370dbf7;hp=255903699bc0f1cc7f8d9e7abe42c9196ac3ee96;hpb=69a6de2b04308332d9e5e8bc61f34e4b9460c12f;p=wimlib diff --git a/src/metadata_resource.c b/src/metadata_resource.c index 25590369..aebc5468 100644 --- a/src/metadata_resource.c +++ b/src/metadata_resource.c @@ -31,6 +31,7 @@ #include "wimlib/metadata.h" #include "wimlib/resource.h" #include "wimlib/security.h" +#include "wimlib/write.h" /* * Reads a metadata resource for an image in the WIM file. The metadata @@ -71,13 +72,9 @@ read_metadata_resource(WIMStruct *wim, struct wim_image_metadata *imd) struct wim_inode *inode; metadata_lte = imd->metadata_lte; - metadata_len = wim_resource_size(metadata_lte); + metadata_len = metadata_lte->size; - DEBUG("Reading metadata resource: original_size = %"PRIu64", " - "size = %"PRIu64", offset = %"PRIu64"", - metadata_lte->resource_entry.original_size, - metadata_lte->resource_entry.size, - metadata_lte->resource_entry.offset); + DEBUG("Reading metadata resource."); /* There is no way the metadata resource could possibly be less than (8 * + WIM_DENTRY_DISK_SIZE) bytes, where the 8 is for security data (with @@ -90,7 +87,7 @@ read_metadata_resource(WIMStruct *wim, struct wim_image_metadata *imd) } /* Read the metadata resource into memory. (It may be compressed.) */ - ret = read_full_resource_into_alloc_buf(metadata_lte, &buf); + ret = read_full_stream_into_alloc_buf(metadata_lte, &buf); if (ret) return ret; @@ -296,10 +293,12 @@ write_metadata_resource(WIMStruct *wim, int image, int write_resource_flags) * the metadata resource. */ ret = write_wim_resource_from_buffer(buf, len, WIM_RESHDR_FLAG_METADATA, &wim->out_fd, - wim->compression_type, - &imd->metadata_lte->output_resource_entry, + wim->out_compression_type, + wim->out_chunk_size, + &imd->metadata_lte->out_reshdr, imd->metadata_lte->hash, - write_resource_flags); + write_resource_flags, + &wim->lzx_context); /* Original checksum was overridden; set a flag so it isn't used. */ imd->metadata_lte->dont_check_metadata_hash = 1;