[pbs-devel] [RFC pxar 4/20] fix #3174: metadata: impl fn to calc byte size

Wolfgang Bumiller w.bumiller at proxmox.com
Wed Sep 27 13:38:28 CEST 2023


On Fri, Sep 22, 2023 at 09:16:05AM +0200, Christian Ebner wrote:
> Add a helper function to calculate the byte size of pxar Metadata
> objects, needed to be able to recalculate offsets when creating archives
> with appendix sections.
> 
> Signed-off-by: Christian Ebner <c.ebner at proxmox.com>
> ---
>  src/lib.rs | 44 ++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 44 insertions(+)
> 
> diff --git a/src/lib.rs b/src/lib.rs
> index 210c4b1..ed7ba40 100644
> --- a/src/lib.rs
> +++ b/src/lib.rs
> @@ -144,6 +144,50 @@ impl Metadata {
>      pub fn builder_from_stat(stat: &libc::stat) -> MetadataBuilder {
>          MetadataBuilder::new(0).fill_from_stat(stat)
>      }
> +
> +    /// Calculate the number of bytes when serialized in pxar archive
> +    pub fn calculate_byte_len(&self) -> usize {

This looks like a maintenance nightmare with extra sprinkles.

Can we instead create a specialized `SeqWrite` type that just counts
bytes instead of actually writing anything and call the encoder's
`encode_metadata()` with it?
(Either by factorizing `encode_metadat()` out further or by creating an
actual `EncoderImpl` instance with it...)

> +        let mut bytes = mem::size_of::<format::Header>();
> +        bytes += mem::size_of_val(&self.stat);
> +        for xattr in &self.xattrs {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(xattr);
> +        }
> +        for acl_user in &self.acl.users {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(acl_user);
> +        }
> +        for acl_group in &self.acl.groups {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(acl_group);
> +        }
> +        if let Some(group_obj) = &self.acl.group_obj {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(group_obj);
> +        }
> +        if let Some(default) = &self.acl.default {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(default);
> +        }
> +        for acl_default_user in &self.acl.default_users {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(acl_default_user);
> +        }
> +        for acl_default_group in &self.acl.default_groups {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(acl_default_group);
> +        }
> +        if let Some(fcaps) = &self.fcaps {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(fcaps);
> +        }
> +        if let Some(quota_project_id) = &self.quota_project_id {
> +            bytes += mem::size_of::<format::Header>();
> +            bytes += mem::size_of_val(quota_project_id);
> +        }
> +
> +        bytes
> +    }
>  }
>  
>  impl From<MetadataBuilder> for Metadata {
> -- 
> 2.39.2





More information about the pbs-devel mailing list