From 276ec94f80f1ac1dced56e53f608d3bab7a2ca93 Mon Sep 17 00:00:00 2001 From: Emmanuel Leblond Date: Fri, 15 Mar 2024 16:40:39 +0100 Subject: [PATCH] Improve Debug display of flags by showing them in hexa --- winfsp_wrs/src/flags.rs | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/winfsp_wrs/src/flags.rs b/winfsp_wrs/src/flags.rs index 143bfb7..7b28f73 100644 --- a/winfsp_wrs/src/flags.rs +++ b/winfsp_wrs/src/flags.rs @@ -30,12 +30,24 @@ use crate::ext::{ FspCleanupSetChangeTime, FspCleanupSetLastAccessTime, FspCleanupSetLastWriteTime, }; -#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] +macro_rules! impl_debug_flags { + ($name:ident) => { + impl std::fmt::Debug for $name { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + f.debug_tuple("FileAttributes").field(&format_args!("{:X}", self.0)).finish() + } + } + }; +} + +#[derive(Clone, Copy, PartialEq, Eq, Hash)] /// File attributes are metadata values stored by the file system on disk and /// are used by the system and are available to developers via various file I/O /// APIs. pub struct FileAttributes(pub FILE_FLAGS_AND_ATTRIBUTES); +impl_debug_flags!(FileAttributes); + impl FileAttributes { /// A file that is read-only. Applications can read the file, but cannot write /// to it or delete it. This attribute is not honored on directories. For more @@ -224,9 +236,11 @@ impl BitOrAssign for FileAttributes { } } -#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] +#[derive(Clone, Copy, PartialEq, Eq, Hash)] pub struct CreateOptions(pub u32); +impl_debug_flags!(CreateOptions); + impl CreateOptions { pub const fn file_directory_file() -> Self { Self(FILE_DIRECTORY_FILE) @@ -259,9 +273,11 @@ impl BitOrAssign for CreateOptions { } } -#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] +#[derive(Clone, Copy, PartialEq, Eq, Hash)] pub struct FileAccessRights(pub FILE_ACCESS_RIGHTS); +impl_debug_flags!(FileAccessRights); + impl FileAccessRights { /// For a file object, the right to read the corresponding file data. For a /// directory object, the right to read the corresponding directory data. @@ -429,9 +445,11 @@ impl BitOrAssign for FileAccessRights { } } -#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] +#[derive(Clone, Copy, PartialEq, Eq, Hash)] pub struct CleanupFlags(pub i32); +impl_debug_flags!(CleanupFlags); + impl CleanupFlags { pub const fn delete() -> Self { Self(FspCleanupDelete) @@ -476,9 +494,11 @@ impl BitOrAssign for CleanupFlags { } } -#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Hash)] +#[derive(Default, Clone, Copy, PartialEq, Eq, Hash)] pub struct FileShareMode(pub FILE_SHARE_MODE); +impl_debug_flags!(FileShareMode); + impl FileShareMode { pub const fn none() -> Self { Self(FILE_SHARE_NONE)