FileDescriptor.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #pragma once
  2. #include "VirtualFileSystem.h"
  3. #include "InodeMetadata.h"
  4. #include <AK/ByteBuffer.h>
  5. #include <AK/Retainable.h>
  6. #ifdef SERENITY
  7. class TTY;
  8. #endif
  9. class FileDescriptor : public Retainable<FileDescriptor> {
  10. public:
  11. static RetainPtr<FileDescriptor> create(RetainPtr<VirtualFileSystem::Node>&&);
  12. ~FileDescriptor();
  13. RetainPtr<FileDescriptor> clone();
  14. int close();
  15. Unix::off_t seek(Unix::off_t, int whence);
  16. Unix::ssize_t read(byte*, Unix::size_t);
  17. Unix::ssize_t write(const byte* data, Unix::size_t);
  18. int stat(Unix::stat*);
  19. bool hasDataAvailableForRead();
  20. ssize_t get_dir_entries(byte* buffer, Unix::size_t);
  21. ByteBuffer readEntireFile();
  22. String absolute_path() const;
  23. bool isDirectory() const;
  24. #ifdef SERENITY
  25. bool isTTY() const;
  26. const TTY* tty() const;
  27. TTY* tty();
  28. #endif
  29. InodeMetadata metadata() const { return m_vnode->metadata(); }
  30. VirtualFileSystem::Node* vnode() { return m_vnode.ptr(); }
  31. #ifdef SERENITY
  32. bool isBlocking() const { return m_isBlocking; }
  33. void setBlocking(bool b) { m_isBlocking = b; }
  34. #endif
  35. ByteBuffer& generatorCache() { return m_generatorCache; }
  36. private:
  37. friend class VirtualFileSystem;
  38. explicit FileDescriptor(RetainPtr<VirtualFileSystem::Node>&&);
  39. RetainPtr<VirtualFileSystem::Node> m_vnode;
  40. Unix::off_t m_currentOffset { 0 };
  41. ByteBuffer m_generatorCache;
  42. #ifdef SERENITY
  43. bool m_isBlocking { true };
  44. #endif
  45. };