/* * Copyright (c) 2021, Xavier Defrang * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Core { class FilePermissionsMask { public: static ErrorOr parse(StringView string); static ErrorOr from_numeric_notation(StringView string); static ErrorOr 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(); 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 m_directory_or_executable_mask; }; }