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 |