]> wimlib.net Git - wimlib/blobdiff - src/xml.c
WIMBoot / system compression: try WOFADK in addition to WOF
[wimlib] / src / xml.c
index 0fb6472342d43c8396eea152087bc76107939595..6450bb095c3f170997de80acfcfa3e66c4308e7d 100644 (file)
--- a/src/xml.c
+++ b/src/xml.c
@@ -89,8 +89,6 @@ struct image_info {
        bool wimboot;
 
        /* Note: must update clone_image_info() if adding new fields here  */
-
-       struct blob_table *blob_table; /* temporary field */
 };
 
 /* A struct wim_info structure corresponds to the entire XML data for a WIM file. */
@@ -1076,8 +1074,6 @@ xml_export_image(const struct wim_info *old_wim_info,
        struct image_info *image_info;
        int ret;
 
-       DEBUG("Copying XML data between WIM files for source image %d.", image);
-
        wimlib_assert(old_wim_info != NULL);
        wimlib_assert(image >= 1 && image <= old_wim_info->num_images);
 
@@ -1129,7 +1125,6 @@ xml_delete_image(struct wim_info **wim_info_p, int image)
 
        wim_info = *wim_info_p;
        wimlib_assert(image >= 1 && image <= wim_info->num_images);
-       DEBUG("Deleting image %d from the XML data.", image);
 
        destroy_image_info(&wim_info->images[image - 1]);
 
@@ -1163,28 +1158,20 @@ xml_set_memory_allocator(void *(*malloc_func)(size_t),
        xmlMemSetup(free_func, malloc_func, realloc_func, STRDUP);
 }
 
-static int
-calculate_dentry_statistics(struct wim_dentry *dentry, void *_info)
+static u64
+inode_sum_stream_sizes(const struct wim_inode *inode,
+                      const struct blob_table *blob_table)
 {
-       struct image_info *info = _info;
-       const struct wim_inode *inode = dentry->d_inode;
-
-       if (inode_is_directory(inode))
-               info->dir_count++;
-       else
-               info->file_count++;
+       u64 total_size = 0;
 
        for (unsigned i = 0; i < inode->i_num_streams; i++) {
                const struct blob_descriptor *blob;
 
-               blob = stream_blob(&inode->i_streams[i], info->blob_table);
-               if (!blob)
-                       continue;
-               info->total_bytes += blob->size;
-               if (!dentry_is_first_in_inode(dentry))
-                       info->hard_link_bytes += blob->size;
+               blob = stream_blob(&inode->i_streams[i], blob_table);
+               if (blob)
+                       total_size += blob->size;
        }
-       return 0;
+       return total_size;
 }
 
 /*
@@ -1197,22 +1184,30 @@ calculate_dentry_statistics(struct wim_dentry *dentry, void *_info)
 void
 xml_update_image_info(WIMStruct *wim, int image)
 {
-       struct image_info *image_info;
-
-       DEBUG("Updating the image info for image %d", image);
-
-       image_info = &wim->wim_info->images[image - 1];
-
-       image_info->file_count      = 0;
-       image_info->dir_count       = 0;
-       image_info->total_bytes     = 0;
-       image_info->hard_link_bytes = 0;
-       image_info->blob_table = wim->blob_table;
+       struct image_info *info;
+       struct wim_image_metadata *imd;
+       struct wim_inode *inode;
+       u64 size;
+
+       info = &wim->wim_info->images[image - 1];
+       imd = wim->image_metadata[image - 1];
+
+       info->file_count = 0;
+       info->dir_count = 0;
+       info->total_bytes = 0;
+       info->hard_link_bytes = 0;
+
+       image_for_each_inode(inode, imd) {
+               if (inode_is_directory(inode))
+                       info->dir_count += inode->i_nlink;
+               else
+                       info->file_count += inode->i_nlink;
+               size = inode_sum_stream_sizes(inode, wim->blob_table);
+               info->total_bytes += size * inode->i_nlink;
+               info->hard_link_bytes += size * (inode->i_nlink - 1);
+       }
 
-       for_dentry_in_tree(wim->image_metadata[image - 1]->root_dentry,
-                          calculate_dentry_statistics,
-                          image_info);
-       image_info->last_modification_time = now_as_wim_timestamp();
+       info->last_modification_time = now_as_wim_timestamp();
 }
 
 /* Adds an image to the XML information. */
@@ -1502,7 +1497,6 @@ out_output_buffer_close:
 out_buffer_free:
        xmlBufferFree(buf);
 out:
-       DEBUG("ret=%d", ret);
        return ret;
 
 out_write_error:
@@ -1521,9 +1515,6 @@ write_wim_xml_data(WIMStruct *wim, int image, u64 total_bytes,
        u8 *xml_data;
        size_t xml_len;
 
-       DEBUG("Writing WIM XML data (image=%d, offset=%"PRIu64")",
-             image, wim->out_fd.offset);
-
        ret = prepare_wim_xml_data(wim, image, total_bytes,
                                   &xml_data, &xml_len);
        if (ret)
@@ -1541,7 +1532,6 @@ write_wim_xml_data(WIMStruct *wim, int image, u64 total_bytes,
                                             NULL,
                                             write_resource_flags);
        FREE(xml_data);
-       DEBUG("ret=%d", ret);
        return ret;
 }
 
@@ -1590,7 +1580,6 @@ wimlib_get_xml_data(WIMStruct *wim, void **buf_ret, size_t *bufsize_ret)
 
        xml_reshdr = &wim->hdr.xml_data_reshdr;
 
-       DEBUG("Reading XML data.");
        *bufsize_ret = xml_reshdr->uncompressed_size;
        return wim_reshdr_to_data(xml_reshdr, wim, buf_ret);
 }