From ea11ffc88c22dea2b71d7863808cd65f64f9eded Mon Sep 17 00:00:00 2001 From: heppocogne <83043568+heppocogne@users.noreply.github.com> Date: Fri, 30 Dec 2022 10:26:51 +0900 Subject: Fix `get_path()` is not working when files are opend with `open_compressed` And also fixed `get_absolute_path()` in the same way --- core/io/file_access_compressed.cpp | 16 ++++++++++++++++ core/io/file_access_compressed.h | 3 +++ 2 files changed, 19 insertions(+) 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 -- cgit v1.2.3