123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- #pragma once
- #include <AK/HashMap.h>
- #include <Kernel/FileSystem/FileSystem.h>
- #include <Kernel/FileSystem/Inode.h>
- #include <Kernel/KBuffer.h>
- #include <Kernel/UnixTypes.h>
- class SynthFSInode;
- class SynthFS : public FS {
- public:
- virtual ~SynthFS() override;
- static NonnullRefPtr<SynthFS> create();
- virtual bool initialize() override;
- virtual const char* class_name() const override;
- virtual InodeIdentifier root_inode() const override;
- virtual RefPtr<Inode> create_inode(InodeIdentifier parentInode, const String& name, mode_t, off_t size, dev_t, int& error) override;
- virtual RefPtr<Inode> create_directory(InodeIdentifier parentInode, const String& name, mode_t, int& error) override;
- virtual RefPtr<Inode> get_inode(InodeIdentifier) const override;
- protected:
- typedef unsigned InodeIndex;
- InodeIndex generate_inode_index();
- static constexpr InodeIndex RootInodeIndex = 1;
- SynthFS();
- NonnullRefPtr<SynthFSInode> create_directory(String&& name);
- NonnullRefPtr<SynthFSInode> create_generated_file(String&& name, Function<ByteBuffer(SynthFSInode&)>&&, mode_t = 0100644);
- NonnullRefPtr<SynthFSInode> create_generated_file(String&& name, Function<ByteBuffer(SynthFSInode&)>&&, Function<ssize_t(SynthFSInode&, const ByteBuffer&)>&&, mode_t = 0100644);
- InodeIdentifier add_file(RefPtr<SynthFSInode>&&, InodeIndex parent = RootInodeIndex);
- bool remove_file(InodeIndex);
- private:
- InodeIndex m_next_inode_index { 2 };
- HashMap<InodeIndex, RefPtr<SynthFSInode>> m_inodes;
- };
- struct SynthFSInodeCustomData {
- virtual ~SynthFSInodeCustomData();
- };
- class SynthFSInode final : public Inode {
- friend class SynthFS;
- friend class DevPtsFS;
- public:
- virtual ~SynthFSInode() override;
- void set_custom_data(OwnPtr<SynthFSInodeCustomData>&& custom_data) { m_custom_data = move(custom_data); }
- SynthFSInodeCustomData* custom_data() { return m_custom_data.ptr(); }
- const SynthFSInodeCustomData* custom_data() const { return m_custom_data.ptr(); }
- private:
- // ^Inode
- virtual ssize_t read_bytes(off_t, ssize_t, u8* buffer, FileDescription*) const override;
- virtual InodeMetadata metadata() const override;
- virtual bool traverse_as_directory(Function<bool(const FS::DirectoryEntry&)>) const override;
- virtual InodeIdentifier lookup(StringView name) override;
- virtual void flush_metadata() override;
- virtual ssize_t write_bytes(off_t, ssize_t, const u8* buffer, FileDescription*) override;
- virtual KResult add_child(InodeIdentifier child_id, const StringView& name, mode_t) override;
- virtual KResult remove_child(const StringView& name) override;
- virtual size_t directory_entry_count() const override;
- virtual KResult chmod(mode_t) override;
- virtual KResult chown(uid_t, gid_t) override;
- SynthFS& fs();
- const SynthFS& fs() const;
- SynthFSInode(SynthFS&, unsigned index);
- String m_name;
- InodeIdentifier m_parent;
- Function<KBuffer(SynthFSInode&)> m_generator;
- Function<ssize_t(SynthFSInode&, const ByteBuffer&)> m_write_callback;
- Vector<SynthFSInode*> m_children;
- InodeMetadata m_metadata;
- OwnPtr<SynthFSInodeCustomData> m_custom_data;
- };
- inline SynthFS& SynthFSInode::fs()
- {
- return static_cast<SynthFS&>(Inode::fs());
- }
- inline const SynthFS& SynthFSInode::fs() const
- {
- return static_cast<const SynthFS&>(Inode::fs());
- }
|