-
Notifications
You must be signed in to change notification settings - Fork 660
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove chmod and duplicated permissions functions #3782
base: main
Are you sure you want to change the base?
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #3782 +/- ##
==========================================
+ Coverage 89.02% 89.04% +0.02%
==========================================
Files 255 254 -1
Lines 14583 14594 +11
==========================================
+ Hits 12982 12995 +13
+ Misses 1601 1599 -2 ☔ View full report in Codecov by Sentry. |
6c58cd2
to
a5015cd
Compare
5b088d8
to
d50d4e4
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good! Thanks for cleaning this up and using the std::filesystem
! Just a few things to clean up and it should be good.
return ::chmod(path, mode); | ||
} | ||
std::error_code ec{}; | ||
std::filesystem::permissions(path, permissions, ec); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we maybe do something with the error code instead of throwing it away? Maybe log or change the signature to return the code?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If not, std::error_code
overloads the bool operator, so you shouldn't need the static cast.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
changing the signature wouldn't work since Windows can fail for reasons that don't create or map to an error_code
. But logging sounds like a good idea!
@@ -296,15 +296,15 @@ mp::Path mp::Utils::make_dir(const QDir& a_dir, const QString& name, QFileDevice | |||
throw std::runtime_error(fmt::format("unable to create directory '{}'", dir_path)); | |||
} | |||
|
|||
if (permissions) | |||
if (permissions != std::filesystem::perms::none) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
permissions
is an enum where std::filesystem::perms::none
is 0, so this isn't strictly necessary.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The enum is not implicitly convertible to bool
, I prefer this over an explicit cast to bool
tests/linux/test_platform_linux.cpp
Outdated
EXPECT_CALL(*mock_file_ops, permissions(_)).WillOnce(Return(QFileDevice::ReadOwner | QFileDevice::WriteOwner)); | ||
EXPECT_CALL(*mock_file_ops, setPermissions(_, _)).WillOnce(Return(true)); | ||
EXPECT_CALL(*mock_file_ops, get_permissions(_)) | ||
.WillOnce(Return(std::filesystem::perms::owner_read | std::filesystem::perms::owner_write)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since you're not testing the permissions and its a mock, you should be able to just Return()
, no?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Return()
won't work since get_permissions
doesn't return void
, I chose owner read write since that's how the test was originally with QPermissions. But any std perms should be fine.
tests/linux/test_platform_linux.cpp
Outdated
EXPECT_CALL(*mock_file_ops, permissions(_)).WillOnce(Return(QFileDevice::ReadOwner | QFileDevice::WriteOwner)); | ||
EXPECT_CALL(*mock_file_ops, setPermissions(_, _)).WillOnce(Return(false)); | ||
EXPECT_CALL(*mock_file_ops, get_permissions(_)) | ||
.WillOnce(Return(std::filesystem::perms::owner_read | std::filesystem::perms::owner_write)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
idem
024baf7
to
48de023
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Sploder12
Excellent job, it is nice to have a uniform std way of setting and getting file permissions. I only have some minor comments.
{ | ||
MP_PLATFORM.set_permissions(dir_path, permissions); | ||
MP_PLATFORM.set_permissions(dir_path.toStdU16String(), permissions); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same wandering as here.
This PR removes
chmod
fromPlatform.h
as well as functions that are similar infile_ops.h
. They have all been changed to useMP_PLATFORM.set_permissions
. This should not change behavior on Unix systems. On Windows this changes the behavior to modify ACLs as well as DOS permissions instead of just DOS permissions.MULTI-1420