| 1 | //===----------------------------------------------------------------------===// |
| 2 | // DuckDB |
| 3 | // |
| 4 | // duckdb/common/local_file_system.hpp |
| 5 | // |
| 6 | // |
| 7 | //===----------------------------------------------------------------------===// |
| 8 | |
| 9 | #pragma once |
| 10 | |
| 11 | #include "duckdb/common/file_system.hpp" |
| 12 | |
| 13 | namespace duckdb { |
| 14 | |
| 15 | class LocalFileSystem : public FileSystem { |
| 16 | public: |
| 17 | unique_ptr<FileHandle> OpenFile(const string &path, uint8_t flags, FileLockType lock = FileLockType::NO_LOCK, |
| 18 | FileCompressionType compression = FileCompressionType::UNCOMPRESSED, |
| 19 | FileOpener *opener = nullptr) override; |
| 20 | |
| 21 | //! Read exactly nr_bytes from the specified location in the file. Fails if nr_bytes could not be read. This is |
| 22 | //! equivalent to calling SetFilePointer(location) followed by calling Read(). |
| 23 | void Read(FileHandle &handle, void *buffer, int64_t nr_bytes, idx_t location) override; |
| 24 | //! Write exactly nr_bytes to the specified location in the file. Fails if nr_bytes could not be written. This is |
| 25 | //! equivalent to calling SetFilePointer(location) followed by calling Write(). |
| 26 | void Write(FileHandle &handle, void *buffer, int64_t nr_bytes, idx_t location) override; |
| 27 | //! Read nr_bytes from the specified file into the buffer, moving the file pointer forward by nr_bytes. Returns the |
| 28 | //! amount of bytes read. |
| 29 | int64_t Read(FileHandle &handle, void *buffer, int64_t nr_bytes) override; |
| 30 | //! Write nr_bytes from the buffer into the file, moving the file pointer forward by nr_bytes. |
| 31 | int64_t Write(FileHandle &handle, void *buffer, int64_t nr_bytes) override; |
| 32 | |
| 33 | //! Returns the file size of a file handle, returns -1 on error |
| 34 | int64_t GetFileSize(FileHandle &handle) override; |
| 35 | //! Returns the file last modified time of a file handle, returns timespec with zero on all attributes on error |
| 36 | time_t GetLastModifiedTime(FileHandle &handle) override; |
| 37 | //! Returns the file last modified time of a file handle, returns timespec with zero on all attributes on error |
| 38 | FileType GetFileType(FileHandle &handle) override; |
| 39 | //! Truncate a file to a maximum size of new_size, new_size should be smaller than or equal to the current size of |
| 40 | //! the file |
| 41 | void Truncate(FileHandle &handle, int64_t new_size) override; |
| 42 | |
| 43 | //! Check if a directory exists |
| 44 | bool DirectoryExists(const string &directory) override; |
| 45 | //! Create a directory if it does not exist |
| 46 | void CreateDirectory(const string &directory) override; |
| 47 | //! Recursively remove a directory and all files in it |
| 48 | void RemoveDirectory(const string &directory) override; |
| 49 | //! List files in a directory, invoking the callback method for each one with (filename, is_dir) |
| 50 | bool ListFiles(const string &directory, const std::function<void(const string &, bool)> &callback, |
| 51 | FileOpener *opener = nullptr) override; |
| 52 | //! Move a file from source path to the target, StorageManager relies on this being an atomic action for ACID |
| 53 | //! properties |
| 54 | void MoveFile(const string &source, const string &target) override; |
| 55 | //! Check if a file exists |
| 56 | bool FileExists(const string &filename) override; |
| 57 | |
| 58 | //! Check if path is a pipe |
| 59 | bool IsPipe(const string &filename) override; |
| 60 | //! Remove a file from disk |
| 61 | void RemoveFile(const string &filename) override; |
| 62 | //! Sync a file handle to disk |
| 63 | void FileSync(FileHandle &handle) override; |
| 64 | |
| 65 | //! Runs a glob on the file system, returning a list of matching files |
| 66 | vector<string> Glob(const string &path, FileOpener *opener = nullptr) override; |
| 67 | |
| 68 | bool CanHandleFile(const string &fpath) override { |
| 69 | //! Whether or not a sub-system can handle a specific file path |
| 70 | return false; |
| 71 | } |
| 72 | |
| 73 | //! Set the file pointer of a file handle to a specified location. Reads and writes will happen from this location |
| 74 | void Seek(FileHandle &handle, idx_t location) override; |
| 75 | //! Return the current seek posiiton in the file. |
| 76 | idx_t SeekPosition(FileHandle &handle) override; |
| 77 | |
| 78 | //! Whether or not we can seek into the file |
| 79 | bool CanSeek() override; |
| 80 | //! Whether or not the FS handles plain files on disk. This is relevant for certain optimizations, as random reads |
| 81 | //! in a file on-disk are much cheaper than e.g. random reads in a file over the network |
| 82 | bool OnDiskFile(FileHandle &handle) override; |
| 83 | |
| 84 | std::string GetName() const override { |
| 85 | return "LocalFileSystem" ; |
| 86 | } |
| 87 | |
| 88 | //! Returns the last Win32 error, in string format. Returns an empty string if there is no error, or on non-Windows |
| 89 | //! systems. |
| 90 | static std::string GetLastErrorAsString(); |
| 91 | |
| 92 | private: |
| 93 | //! Set the file pointer of a file handle to a specified location. Reads and writes will happen from this location |
| 94 | void SetFilePointer(FileHandle &handle, idx_t location); |
| 95 | idx_t GetFilePointer(FileHandle &handle); |
| 96 | |
| 97 | vector<string> FetchFileWithoutGlob(const string &path, FileOpener *opener, bool absolute_path); |
| 98 | }; |
| 99 | |
| 100 | } // namespace duckdb |
| 101 | |