diff options
author | heppocogne <83043568+heppocogne@users.noreply.github.com> | 2022-12-30 10:26:51 +0900 |
---|---|---|
committer | heppocogne <83043568+heppocogne@users.noreply.github.com> | 2022-12-30 10:31:12 +0900 |
commit | ea11ffc88c22dea2b71d7863808cd65f64f9eded (patch) | |
tree | 79436a3e3c4508ac5ccbf47a2cf0a29320c7a62d | |
parent | a75493091823020d858fabadbfa5994da0d658cb (diff) |
Fix `get_path()` is not working when files are opend with `open_compressed`
And also fixed `get_absolute_path()` in the same way
-rw-r--r-- | core/io/file_access_compressed.cpp | 16 | ||||
-rw-r--r-- | core/io/file_access_compressed.h | 3 |
2 files changed, 19 insertions, 0 deletions
diff --git a/core/io/file_access_compressed.cpp b/core/io/file_access_compressed.cpp index d2c8a88269..2a1847205c 100644 --- a/core/io/file_access_compressed.cpp +++ b/core/io/file_access_compressed.cpp @@ -184,6 +184,22 @@ bool FileAccessCompressed::is_open() const { return f.is_valid(); } +String FileAccessCompressed::get_path() const { + if (f.is_valid()) { + return f->get_path(); + } else { + return ""; + } +} + +String FileAccessCompressed::get_path_absolute() const { + if (f.is_valid()) { + return f->get_path_absolute(); + } else { + return ""; + } +} + void FileAccessCompressed::seek(uint64_t p_position) { ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use."); diff --git a/core/io/file_access_compressed.h b/core/io/file_access_compressed.h index ee114c2c65..9004ca4478 100644 --- a/core/io/file_access_compressed.h +++ b/core/io/file_access_compressed.h @@ -73,6 +73,9 @@ public: virtual Error open_internal(const String &p_path, int p_mode_flags) override; ///< open a file virtual bool is_open() const override; ///< true when file is open + virtual String get_path() const override; /// returns the path for the current open file + virtual String get_path_absolute() const override; /// returns the absolute path for the current open file + virtual void seek(uint64_t p_position) override; ///< seek to a given position virtual void seek_end(int64_t p_position = 0) override; ///< seek from the end of file virtual uint64_t get_position() const override; ///< get position in the file |