Directory.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Copyright (c) 2022, kleines Filmröllchen <filmroellchen@serenityos.org>
  3. * Copyright (c) 2023, Sam Atkins <atkinssj@serenityos.org>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #pragma once
  8. #include <AK/Error.h>
  9. #include <AK/Format.h>
  10. #include <AK/Function.h>
  11. #include <AK/IterationDecision.h>
  12. #include <AK/LexicalPath.h>
  13. #include <AK/Noncopyable.h>
  14. #include <AK/Optional.h>
  15. #include <LibCore/DirIterator.h>
  16. #include <LibCore/DirectoryEntry.h>
  17. #include <LibCore/File.h>
  18. #include <dirent.h>
  19. #include <sys/stat.h>
  20. namespace Core {
  21. // Deal with real system directories. Any Directory instance always refers to a valid existing directory.
  22. class Directory {
  23. AK_MAKE_NONCOPYABLE(Directory);
  24. public:
  25. Directory(Directory&&);
  26. ~Directory();
  27. // When this flag is set, both the directory attempted to instantiate as well as all of its parents are created with mode 0755 if necessary.
  28. enum class CreateDirectories : bool {
  29. No,
  30. Yes,
  31. };
  32. static ErrorOr<Directory> create(LexicalPath path, CreateDirectories, mode_t creation_mode = 0755);
  33. static ErrorOr<Directory> create(ByteString path, CreateDirectories, mode_t creation_mode = 0755);
  34. static ErrorOr<Directory> adopt_fd(int fd, LexicalPath path);
  35. ErrorOr<NonnullOwnPtr<File>> open(StringView filename, File::OpenMode mode) const;
  36. ErrorOr<struct stat> stat(StringView filename, int flags) const;
  37. ErrorOr<struct stat> stat() const;
  38. int fd() const { return m_directory_fd; }
  39. LexicalPath const& path() const { return m_path; }
  40. using ForEachEntryCallback = Function<ErrorOr<IterationDecision>(DirectoryEntry const&, Directory const& parent)>;
  41. static ErrorOr<void> for_each_entry(StringView path, DirIterator::Flags, ForEachEntryCallback);
  42. ErrorOr<void> for_each_entry(DirIterator::Flags, ForEachEntryCallback);
  43. ErrorOr<void> chown(uid_t, gid_t);
  44. static ErrorOr<bool> is_valid_directory(int fd);
  45. private:
  46. Directory(int directory_fd, LexicalPath path);
  47. static ErrorOr<void> ensure_directory(LexicalPath const& path, mode_t creation_mode = 0755);
  48. LexicalPath m_path;
  49. int m_directory_fd;
  50. };
  51. }
  52. namespace AK {
  53. template<>
  54. struct Formatter<Core::Directory> : Formatter<StringView> {
  55. ErrorOr<void> format(FormatBuilder& builder, Core::Directory const& directory)
  56. {
  57. TRY(builder.put_string(directory.path().string()));
  58. return {};
  59. }
  60. };
  61. }