123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- /*
- * Copyright (c) 2021, Xavier Defrang <xavier.defrang@gmail.com>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #pragma once
- #include <AK/Error.h>
- #include <AK/OwnPtr.h>
- #include <sys/stat.h>
- namespace Core {
- class FilePermissionsMask {
- public:
- static ErrorOr<FilePermissionsMask> parse(StringView string);
- static ErrorOr<FilePermissionsMask> from_numeric_notation(StringView string);
- static ErrorOr<FilePermissionsMask> from_symbolic_notation(StringView string);
- FilePermissionsMask()
- : m_clear_mask(0)
- , m_write_mask(0)
- {
- }
- FilePermissionsMask& assign_permissions(mode_t mode);
- FilePermissionsMask& add_permissions(mode_t mode);
- FilePermissionsMask& remove_permissions(mode_t mode);
- mode_t apply(mode_t mode) const
- {
- if (m_directory_or_executable_mask && (S_ISDIR(mode) || (mode & 0111) != 0))
- mode = m_directory_or_executable_mask->apply(mode);
- return m_write_mask | (mode & ~m_clear_mask);
- }
- mode_t clear_mask() const { return m_clear_mask; }
- mode_t write_mask() const { return m_write_mask; }
- FilePermissionsMask& directory_or_executable_mask()
- {
- if (!m_directory_or_executable_mask)
- m_directory_or_executable_mask = make<FilePermissionsMask>();
- return *m_directory_or_executable_mask;
- }
- private:
- mode_t m_clear_mask; // the bits that will be cleared
- mode_t m_write_mask; // the bits that will be set
- // A separate mask, only for files that already have some executable bit set or directories.
- OwnPtr<FilePermissionsMask> m_directory_or_executable_mask;
- };
- }
|