123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 |
- #include "SyntheticFileSystem.h"
- #include <AK/StdLib.h>
- //#define SYNTHFS_DEBUG
- RetainPtr<SyntheticFileSystem> SyntheticFileSystem::create()
- {
- return adopt(*new SyntheticFileSystem);
- }
- SyntheticFileSystem::SyntheticFileSystem()
- {
- }
- SyntheticFileSystem::~SyntheticFileSystem()
- {
- }
- bool SyntheticFileSystem::initialize()
- {
- // Add a File for the root directory.
- // FIXME: This needs work.
- auto rootDir = make<File>();
- rootDir->metadata.inode = { id(), RootInodeIndex };
- rootDir->parent = { id(), RootInodeIndex };
- rootDir->metadata.mode = 0040555;
- rootDir->metadata.uid = 0;
- rootDir->metadata.gid = 0;
- rootDir->metadata.size = 0;
- rootDir->metadata.mtime = mepoch;
- m_inodes.set(RootInodeIndex, move(rootDir));
- #if 0
- #ifndef SERENITY
- addFile(createTextFile("file", "I'm a synthetic file!\n"));
- addFile(createTextFile("message", "Hey! This isn't my bottle!\n"));
- #endif
- #endif
- return true;
- }
- auto SyntheticFileSystem::createDirectory(String&& name) -> OwnPtr<File>
- {
- auto file = make<File>();
- file->name = move(name);
- file->metadata.size = 0;
- file->metadata.uid = 0;
- file->metadata.gid = 0;
- file->metadata.mode = 0040555;
- file->metadata.mtime = mepoch;
- return file;
- }
- auto SyntheticFileSystem::createTextFile(String&& name, String&& text) -> OwnPtr<File>
- {
- auto file = make<File>();
- file->data = text.toByteBuffer();
- file->name = move(name);
- file->metadata.size = file->data.size();
- file->metadata.uid = 100;
- file->metadata.gid = 200;
- file->metadata.mode = 04;
- file->metadata.mtime = mepoch;
- return file;
- }
- auto SyntheticFileSystem::createGeneratedFile(String&& name, Function<ByteBuffer()>&& generator) -> OwnPtr<File>
- {
- auto file = make<File>();
- file->generator = move(generator);
- file->name = move(name);
- file->metadata.size = 0;
- file->metadata.uid = 0;
- file->metadata.gid = 0;
- file->metadata.mode = 0100644;
- file->metadata.mtime = mepoch;
- return file;
- }
- InodeIdentifier SyntheticFileSystem::addFile(OwnPtr<File>&& file, InodeIndex parent)
- {
- ASSERT(file);
- auto it = m_inodes.find(parent);
- ASSERT(it != m_inodes.end());
- InodeIdentifier newInode { id(), generateInodeIndex() };
- file->metadata.inode = newInode;
- file->parent = { id(), parent };
- (*it).value->children.append(file.ptr());
- m_inodes.set(newInode.index(), move(file));
- return newInode;
- }
- bool SyntheticFileSystem::removeFile(InodeIndex inode)
- {
- auto it = m_inodes.find(inode);
- if (it == m_inodes.end())
- return false;
- auto& file = *(*it).value;
- auto pit = m_inodes.find(file.parent.index());
- if (pit == m_inodes.end())
- return false;
- auto& parent = *(*pit).value;
- for (size_t i = 0; i < parent.children.size(); ++i) {
- if (parent.children[i]->metadata.inode.index() != inode) {
- continue;
- }
- parent.children.remove(i);
- break;
- }
- for (auto& child : file.children)
- removeFile(child->metadata.inode.index());
- m_inodes.remove(inode);
- return true;
- }
- const char* SyntheticFileSystem::className() const
- {
- return "synthfs";
- }
- InodeIdentifier SyntheticFileSystem::rootInode() const
- {
- return { id(), 1 };
- }
- bool SyntheticFileSystem::enumerateDirectoryInode(InodeIdentifier inode, Function<bool(const DirectoryEntry&)> callback) const
- {
- ASSERT(inode.fileSystemID() == id());
- #ifdef SYNTHFS_DEBUG
- kprintf("[synthfs] enumerateDirectoryInode %u\n", inode.index());
- #endif
- auto it = m_inodes.find(inode.index());
- if (it == m_inodes.end())
- return false;
- const File& synInode = *(*it).value;
- if (!synInode.metadata.isDirectory())
- return false;
- callback({ ".", synInode.metadata.inode });
- callback({ "..", synInode.parent });
- for (auto& child : synInode.children) {
- callback({ child->name, child->metadata.inode });
- }
- return true;
- }
- InodeMetadata SyntheticFileSystem::inodeMetadata(InodeIdentifier inode) const
- {
- ASSERT(inode.fileSystemID() == id());
- #ifdef SYNTHFS_DEBUG
- kprintf("[synthfs] inodeMetadata(%u)\n", inode.index());
- #endif
- auto it = m_inodes.find(inode.index());
- if (it == m_inodes.end())
- return { };
- return (*it).value->metadata;
- }
- bool SyntheticFileSystem::setModificationTime(InodeIdentifier, dword timestamp)
- {
- (void) timestamp;
- kprintf("FIXME: Implement SyntheticFileSystem::setModificationTime().\n");
- return false;
- }
- InodeIdentifier SyntheticFileSystem::createInode(InodeIdentifier parentInode, const String& name, Unix::mode_t mode, unsigned size)
- {
- (void) parentInode;
- (void) name;
- (void) mode;
- (void) size;
- kprintf("FIXME: Implement SyntheticFileSystem::createDirectoryInode().\n");
- return { };
- }
- bool SyntheticFileSystem::writeInode(InodeIdentifier, const ByteBuffer&)
- {
- kprintf("FIXME: Implement SyntheticFileSystem::writeInode().\n");
- return false;
- }
- Unix::ssize_t SyntheticFileSystem::readInodeBytes(InodeIdentifier inode, Unix::off_t offset, Unix::size_t count, byte* buffer) const
- {
- ASSERT(inode.fileSystemID() == id());
- #ifdef SYNTHFS_DEBUG
- kprintf("[synthfs] readInode %u\n", inode.index());
- #endif
- ASSERT(offset >= 0);
- ASSERT(buffer);
- \
- auto it = m_inodes.find(inode.index());
- if (it == m_inodes.end())
- return false;
- const File& file = *(*it).value;
- ByteBuffer generatedData;
- if (file.generator)
- generatedData = file.generator();
- auto* data = generatedData ? &generatedData : &file.data;
- Unix::ssize_t nread = min(static_cast<Unix::off_t>(data->size() - offset), static_cast<Unix::off_t>(count));
- memcpy(buffer, data->pointer() + offset, nread);
- return nread;
- }
- InodeIdentifier SyntheticFileSystem::makeDirectory(InodeIdentifier parentInode, const String& name, Unix::mode_t)
- {
- (void) parentInode;
- (void) name;
- kprintf("FIXME: Implement SyntheticFileSystem::makeDirectory().\n");
- return { };
- }
- auto SyntheticFileSystem::generateInodeIndex() -> InodeIndex
- {
- return m_nextInodeIndex++;
- }
|