/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include namespace Kernel { class Inode; class InodeFile final : public File { public: static KResultOr> create(NonnullRefPtr&& inode) { auto file = adopt_ref_if_nonnull(new (nothrow) InodeFile(move(inode))); if (!file) return ENOMEM; return file.release_nonnull(); } virtual ~InodeFile() override; const Inode& inode() const { return *m_inode; } Inode& inode() { return *m_inode; } virtual bool can_read(const OpenFileDescription&, size_t) const override { return true; } virtual bool can_write(const OpenFileDescription&, size_t) const override { return true; } virtual KResultOr read(OpenFileDescription&, u64, UserOrKernelBuffer&, size_t) override; virtual KResultOr write(OpenFileDescription&, u64, const UserOrKernelBuffer&, size_t) override; virtual KResult ioctl(OpenFileDescription&, unsigned request, Userspace arg) override; virtual KResultOr mmap(Process&, OpenFileDescription&, Memory::VirtualRange const&, u64 offset, int prot, bool shared) override; virtual KResult stat(::stat& buffer) const override { return inode().metadata().stat(buffer); } virtual String absolute_path(const OpenFileDescription&) const override; virtual KResult truncate(u64) override; virtual KResult sync() override; virtual KResult chown(OpenFileDescription&, UserID, GroupID) override; virtual KResult chmod(OpenFileDescription&, mode_t) override; virtual StringView class_name() const override { return "InodeFile"sv; } virtual bool is_seekable() const override { return true; } virtual bool is_inode() const override { return true; } private: explicit InodeFile(NonnullRefPtr&&); NonnullRefPtr m_inode; }; }