1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-08 21:18:16 +03:00

smbd: Expand IS_DOS_* macros

To me these macros hide more than they clarify. In a lot of places we
already directly check for these flags without those macros. Unify
that.

Also, check for the dosmode bits first, lp_map_* is a bit more effort
to evaluate.

Signed-off-by: Volker Lendecke <vl@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
Volker Lendecke 2023-10-06 13:42:19 +02:00 committed by Jeremy Allison
parent 1fbf08e812
commit 817f68e4a1

View File

@ -112,7 +112,8 @@ mode_t unix_mode(connection_struct *conn, int dosmode,
mode_t dir_mode = 0; /* Mode of the inherit_from directory if mode_t dir_mode = 0; /* Mode of the inherit_from directory if
* inheriting. */ * inheriting. */
if (!lp_store_dos_attributes(SNUM(conn)) && IS_DOS_READONLY(dosmode)) { if ((dosmode & FILE_ATTRIBUTE_READONLY) &&
!lp_store_dos_attributes(SNUM(conn))) {
result &= ~(S_IWUSR | S_IWGRP | S_IWOTH); result &= ~(S_IWUSR | S_IWGRP | S_IWOTH);
} }
@ -140,7 +141,7 @@ mode_t unix_mode(connection_struct *conn, int dosmode,
result = 0; result = 0;
} }
if (IS_DOS_DIR(dosmode)) { if (dosmode & FILE_ATTRIBUTE_DIRECTORY) {
/* We never make directories read only for the owner as under DOS a user /* We never make directories read only for the owner as under DOS a user
can always create a file in a read-only directory. */ can always create a file in a read-only directory. */
result |= (S_IFDIR | S_IWUSR); result |= (S_IFDIR | S_IWUSR);
@ -158,14 +159,20 @@ mode_t unix_mode(connection_struct *conn, int dosmode,
result |= lp_force_directory_mode(SNUM(conn)); result |= lp_force_directory_mode(SNUM(conn));
} }
} else { } else {
if (lp_map_archive(SNUM(conn)) && IS_DOS_ARCHIVE(dosmode)) if ((dosmode & FILE_ATTRIBUTE_ARCHIVE) &&
lp_map_archive(SNUM(conn))) {
result |= S_IXUSR; result |= S_IXUSR;
}
if (lp_map_system(SNUM(conn)) && IS_DOS_SYSTEM(dosmode)) if ((dosmode & FILE_ATTRIBUTE_SYSTEM) &&
lp_map_system(SNUM(conn))) {
result |= S_IXGRP; result |= S_IXGRP;
}
if (lp_map_hidden(SNUM(conn)) && IS_DOS_HIDDEN(dosmode)) if ((dosmode & FILE_ATTRIBUTE_HIDDEN) &&
lp_map_hidden(SNUM(conn))) {
result |= S_IXOTH; result |= S_IXOTH;
}
if (dir_mode) { if (dir_mode) {
/* Inherit 666 component of parent directory mode */ /* Inherit 666 component of parent directory mode */