|
@@ -992,636 +992,6 @@ void Geometry3D::_bind_methods() {
|
|
|
ClassDB::bind_method(D_METHOD("clip_polygon", "points", "plane"), &Geometry3D::clip_polygon);
|
|
|
}
|
|
|
|
|
|
-////// File //////
|
|
|
-
|
|
|
-Error File::open_encrypted(const String &p_path, ModeFlags p_mode_flags, const Vector<uint8_t> &p_key) {
|
|
|
- Error err = open(p_path, p_mode_flags);
|
|
|
- if (err) {
|
|
|
- return err;
|
|
|
- }
|
|
|
-
|
|
|
- Ref<FileAccessEncrypted> fae;
|
|
|
- fae.instantiate();
|
|
|
- err = fae->open_and_parse(f, p_key, (p_mode_flags == WRITE) ? FileAccessEncrypted::MODE_WRITE_AES256 : FileAccessEncrypted::MODE_READ);
|
|
|
- if (err) {
|
|
|
- close();
|
|
|
- return err;
|
|
|
- }
|
|
|
- f = fae;
|
|
|
- return OK;
|
|
|
-}
|
|
|
-
|
|
|
-Error File::open_encrypted_pass(const String &p_path, ModeFlags p_mode_flags, const String &p_pass) {
|
|
|
- Error err = open(p_path, p_mode_flags);
|
|
|
- if (err) {
|
|
|
- return err;
|
|
|
- }
|
|
|
-
|
|
|
- Ref<FileAccessEncrypted> fae;
|
|
|
- fae.instantiate();
|
|
|
- err = fae->open_and_parse_password(f, p_pass, (p_mode_flags == WRITE) ? FileAccessEncrypted::MODE_WRITE_AES256 : FileAccessEncrypted::MODE_READ);
|
|
|
- if (err) {
|
|
|
- close();
|
|
|
- return err;
|
|
|
- }
|
|
|
-
|
|
|
- f = fae;
|
|
|
- return OK;
|
|
|
-}
|
|
|
-
|
|
|
-Error File::open_compressed(const String &p_path, ModeFlags p_mode_flags, CompressionMode p_compress_mode) {
|
|
|
- Ref<FileAccessCompressed> fac;
|
|
|
- fac.instantiate();
|
|
|
- fac->configure("GCPF", (Compression::Mode)p_compress_mode);
|
|
|
-
|
|
|
- Error err = fac->_open(p_path, p_mode_flags);
|
|
|
-
|
|
|
- if (err) {
|
|
|
- return err;
|
|
|
- }
|
|
|
-
|
|
|
- f = fac;
|
|
|
- return OK;
|
|
|
-}
|
|
|
-
|
|
|
-Error File::open(const String &p_path, ModeFlags p_mode_flags) {
|
|
|
- Error err;
|
|
|
- f = FileAccess::open(p_path, p_mode_flags, &err);
|
|
|
- if (f.is_valid()) {
|
|
|
- f->set_big_endian(big_endian);
|
|
|
- }
|
|
|
- return err;
|
|
|
-}
|
|
|
-
|
|
|
-void File::flush() {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before flushing.");
|
|
|
- f->flush();
|
|
|
-}
|
|
|
-
|
|
|
-void File::close() {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened.");
|
|
|
- f.unref();
|
|
|
-}
|
|
|
-
|
|
|
-bool File::is_open() const {
|
|
|
- return f != nullptr;
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_path() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), "", "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_path();
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_path_absolute() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), "", "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_path_absolute();
|
|
|
-}
|
|
|
-
|
|
|
-void File::seek(int64_t p_position) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- ERR_FAIL_COND_MSG(p_position < 0, "Seek position must be a positive integer.");
|
|
|
- f->seek(p_position);
|
|
|
-}
|
|
|
-
|
|
|
-void File::seek_end(int64_t p_position) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- f->seek_end(p_position);
|
|
|
-}
|
|
|
-
|
|
|
-uint64_t File::get_position() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_position();
|
|
|
-}
|
|
|
-
|
|
|
-uint64_t File::get_length() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_length();
|
|
|
-}
|
|
|
-
|
|
|
-bool File::eof_reached() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), false, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->eof_reached();
|
|
|
-}
|
|
|
-
|
|
|
-uint8_t File::get_8() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_8();
|
|
|
-}
|
|
|
-
|
|
|
-uint16_t File::get_16() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_16();
|
|
|
-}
|
|
|
-
|
|
|
-uint32_t File::get_32() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_32();
|
|
|
-}
|
|
|
-
|
|
|
-uint64_t File::get_64() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_64();
|
|
|
-}
|
|
|
-
|
|
|
-float File::get_float() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_float();
|
|
|
-}
|
|
|
-
|
|
|
-double File::get_double() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_double();
|
|
|
-}
|
|
|
-
|
|
|
-real_t File::get_real() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), 0, "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_real();
|
|
|
-}
|
|
|
-
|
|
|
-Vector<uint8_t> File::get_buffer(int64_t p_length) const {
|
|
|
- Vector<uint8_t> data;
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), data, "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- ERR_FAIL_COND_V_MSG(p_length < 0, data, "Length of buffer cannot be smaller than 0.");
|
|
|
- if (p_length == 0) {
|
|
|
- return data;
|
|
|
- }
|
|
|
-
|
|
|
- Error err = data.resize(p_length);
|
|
|
- ERR_FAIL_COND_V_MSG(err != OK, data, "Can't resize data to " + itos(p_length) + " elements.");
|
|
|
-
|
|
|
- uint8_t *w = data.ptrw();
|
|
|
- int64_t len = f->get_buffer(&w[0], p_length);
|
|
|
-
|
|
|
- if (len < p_length) {
|
|
|
- data.resize(len);
|
|
|
- }
|
|
|
-
|
|
|
- return data;
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_as_text(bool p_skip_cr) const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), String(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- uint64_t original_pos = f->get_position();
|
|
|
- const_cast<FileAccess *>(*f)->seek(0);
|
|
|
-
|
|
|
- String text = f->get_as_utf8_string(p_skip_cr);
|
|
|
-
|
|
|
- const_cast<FileAccess *>(*f)->seek(original_pos);
|
|
|
-
|
|
|
- return text;
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_md5(const String &p_path) const {
|
|
|
- return FileAccess::get_md5(p_path);
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_sha256(const String &p_path) const {
|
|
|
- return FileAccess::get_sha256(p_path);
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_line() const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), String(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_line();
|
|
|
-}
|
|
|
-
|
|
|
-Vector<String> File::get_csv_line(const String &p_delim) const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), Vector<String>(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- return f->get_csv_line(p_delim);
|
|
|
-}
|
|
|
-
|
|
|
-/**< use this for files WRITTEN in _big_ endian machines (i.e. amiga/mac)
|
|
|
- * It's not about the current CPU type but file formats.
|
|
|
- * These flags get reset to false (little endian) on each open
|
|
|
- */
|
|
|
-
|
|
|
-void File::set_big_endian(bool p_big_endian) {
|
|
|
- big_endian = p_big_endian;
|
|
|
- if (f.is_valid()) {
|
|
|
- f->set_big_endian(p_big_endian);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-bool File::is_big_endian() {
|
|
|
- return big_endian;
|
|
|
-}
|
|
|
-
|
|
|
-Error File::get_error() const {
|
|
|
- if (f.is_null()) {
|
|
|
- return ERR_UNCONFIGURED;
|
|
|
- }
|
|
|
- return f->get_error();
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_8(uint8_t p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_8(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_16(uint16_t p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_16(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_32(uint32_t p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_32(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_64(uint64_t p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_64(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_float(float p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_float(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_double(double p_dest) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_double(p_dest);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_real(real_t p_real) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_real(p_real);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_string(const String &p_string) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_string(p_string);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_pascal_string(const String &p_string) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- f->store_pascal_string(p_string);
|
|
|
-}
|
|
|
-
|
|
|
-String File::get_pascal_string() {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), "", "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- return f->get_pascal_string();
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_line(const String &p_string) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- f->store_line(p_string);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_csv_line(const Vector<String> &p_values, const String &p_delim) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- f->store_csv_line(p_values, p_delim);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_buffer(const Vector<uint8_t> &p_buffer) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
-
|
|
|
- uint64_t len = p_buffer.size();
|
|
|
- if (len == 0) {
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- const uint8_t *r = p_buffer.ptr();
|
|
|
-
|
|
|
- f->store_buffer(&r[0], len);
|
|
|
-}
|
|
|
-
|
|
|
-bool File::file_exists(const String &p_name) {
|
|
|
- return FileAccess::exists(p_name);
|
|
|
-}
|
|
|
-
|
|
|
-void File::store_var(const Variant &p_var, bool p_full_objects) {
|
|
|
- ERR_FAIL_COND_MSG(f.is_null(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- int len;
|
|
|
- Error err = encode_variant(p_var, nullptr, len, p_full_objects);
|
|
|
- ERR_FAIL_COND_MSG(err != OK, "Error when trying to encode Variant.");
|
|
|
-
|
|
|
- Vector<uint8_t> buff;
|
|
|
- buff.resize(len);
|
|
|
-
|
|
|
- uint8_t *w = buff.ptrw();
|
|
|
- err = encode_variant(p_var, &w[0], len, p_full_objects);
|
|
|
- ERR_FAIL_COND_MSG(err != OK, "Error when trying to encode Variant.");
|
|
|
-
|
|
|
- store_32(len);
|
|
|
- store_buffer(buff);
|
|
|
-}
|
|
|
-
|
|
|
-Variant File::get_var(bool p_allow_objects) const {
|
|
|
- ERR_FAIL_COND_V_MSG(f.is_null(), Variant(), "File must be opened before use, or is lacking read-write permission.");
|
|
|
- uint32_t len = get_32();
|
|
|
- Vector<uint8_t> buff = get_buffer(len);
|
|
|
- ERR_FAIL_COND_V((uint32_t)buff.size() != len, Variant());
|
|
|
-
|
|
|
- const uint8_t *r = buff.ptr();
|
|
|
-
|
|
|
- Variant v;
|
|
|
- Error err = decode_variant(v, &r[0], len, nullptr, p_allow_objects);
|
|
|
- ERR_FAIL_COND_V_MSG(err != OK, Variant(), "Error when trying to encode Variant.");
|
|
|
-
|
|
|
- return v;
|
|
|
-}
|
|
|
-
|
|
|
-uint64_t File::get_modified_time(const String &p_file) const {
|
|
|
- return FileAccess::get_modified_time(p_file);
|
|
|
-}
|
|
|
-
|
|
|
-void File::_bind_methods() {
|
|
|
- ClassDB::bind_method(D_METHOD("open_encrypted", "path", "mode_flags", "key"), &File::open_encrypted);
|
|
|
- ClassDB::bind_method(D_METHOD("open_encrypted_with_pass", "path", "mode_flags", "pass"), &File::open_encrypted_pass);
|
|
|
- ClassDB::bind_method(D_METHOD("open_compressed", "path", "mode_flags", "compression_mode"), &File::open_compressed, DEFVAL(0));
|
|
|
-
|
|
|
- ClassDB::bind_method(D_METHOD("open", "path", "flags"), &File::open);
|
|
|
- ClassDB::bind_method(D_METHOD("flush"), &File::flush);
|
|
|
- ClassDB::bind_method(D_METHOD("close"), &File::close);
|
|
|
- ClassDB::bind_method(D_METHOD("get_path"), &File::get_path);
|
|
|
- ClassDB::bind_method(D_METHOD("get_path_absolute"), &File::get_path_absolute);
|
|
|
- ClassDB::bind_method(D_METHOD("is_open"), &File::is_open);
|
|
|
- ClassDB::bind_method(D_METHOD("seek", "position"), &File::seek);
|
|
|
- ClassDB::bind_method(D_METHOD("seek_end", "position"), &File::seek_end, DEFVAL(0));
|
|
|
- ClassDB::bind_method(D_METHOD("get_position"), &File::get_position);
|
|
|
- ClassDB::bind_method(D_METHOD("get_length"), &File::get_length);
|
|
|
- ClassDB::bind_method(D_METHOD("eof_reached"), &File::eof_reached);
|
|
|
- ClassDB::bind_method(D_METHOD("get_8"), &File::get_8);
|
|
|
- ClassDB::bind_method(D_METHOD("get_16"), &File::get_16);
|
|
|
- ClassDB::bind_method(D_METHOD("get_32"), &File::get_32);
|
|
|
- ClassDB::bind_method(D_METHOD("get_64"), &File::get_64);
|
|
|
- ClassDB::bind_method(D_METHOD("get_float"), &File::get_float);
|
|
|
- ClassDB::bind_method(D_METHOD("get_double"), &File::get_double);
|
|
|
- ClassDB::bind_method(D_METHOD("get_real"), &File::get_real);
|
|
|
- ClassDB::bind_method(D_METHOD("get_buffer", "length"), &File::get_buffer);
|
|
|
- ClassDB::bind_method(D_METHOD("get_line"), &File::get_line);
|
|
|
- ClassDB::bind_method(D_METHOD("get_csv_line", "delim"), &File::get_csv_line, DEFVAL(","));
|
|
|
- ClassDB::bind_method(D_METHOD("get_as_text", "skip_cr"), &File::get_as_text, DEFVAL(false));
|
|
|
- ClassDB::bind_method(D_METHOD("get_md5", "path"), &File::get_md5);
|
|
|
- ClassDB::bind_method(D_METHOD("get_sha256", "path"), &File::get_sha256);
|
|
|
- ClassDB::bind_method(D_METHOD("is_big_endian"), &File::is_big_endian);
|
|
|
- ClassDB::bind_method(D_METHOD("set_big_endian", "big_endian"), &File::set_big_endian);
|
|
|
- ClassDB::bind_method(D_METHOD("get_error"), &File::get_error);
|
|
|
- ClassDB::bind_method(D_METHOD("get_var", "allow_objects"), &File::get_var, DEFVAL(false));
|
|
|
-
|
|
|
- ClassDB::bind_method(D_METHOD("store_8", "value"), &File::store_8);
|
|
|
- ClassDB::bind_method(D_METHOD("store_16", "value"), &File::store_16);
|
|
|
- ClassDB::bind_method(D_METHOD("store_32", "value"), &File::store_32);
|
|
|
- ClassDB::bind_method(D_METHOD("store_64", "value"), &File::store_64);
|
|
|
- ClassDB::bind_method(D_METHOD("store_float", "value"), &File::store_float);
|
|
|
- ClassDB::bind_method(D_METHOD("store_double", "value"), &File::store_double);
|
|
|
- ClassDB::bind_method(D_METHOD("store_real", "value"), &File::store_real);
|
|
|
- ClassDB::bind_method(D_METHOD("store_buffer", "buffer"), &File::store_buffer);
|
|
|
- ClassDB::bind_method(D_METHOD("store_line", "line"), &File::store_line);
|
|
|
- ClassDB::bind_method(D_METHOD("store_csv_line", "values", "delim"), &File::store_csv_line, DEFVAL(","));
|
|
|
- ClassDB::bind_method(D_METHOD("store_string", "string"), &File::store_string);
|
|
|
- ClassDB::bind_method(D_METHOD("store_var", "value", "full_objects"), &File::store_var, DEFVAL(false));
|
|
|
-
|
|
|
- ClassDB::bind_method(D_METHOD("store_pascal_string", "string"), &File::store_pascal_string);
|
|
|
- ClassDB::bind_method(D_METHOD("get_pascal_string"), &File::get_pascal_string);
|
|
|
-
|
|
|
- ClassDB::bind_static_method("File", D_METHOD("file_exists", "path"), &File::file_exists);
|
|
|
- ClassDB::bind_method(D_METHOD("get_modified_time", "file"), &File::get_modified_time);
|
|
|
-
|
|
|
- ADD_PROPERTY(PropertyInfo(Variant::BOOL, "big_endian"), "set_big_endian", "is_big_endian");
|
|
|
-
|
|
|
- BIND_ENUM_CONSTANT(READ);
|
|
|
- BIND_ENUM_CONSTANT(WRITE);
|
|
|
- BIND_ENUM_CONSTANT(READ_WRITE);
|
|
|
- BIND_ENUM_CONSTANT(WRITE_READ);
|
|
|
-
|
|
|
- BIND_ENUM_CONSTANT(COMPRESSION_FASTLZ);
|
|
|
- BIND_ENUM_CONSTANT(COMPRESSION_DEFLATE);
|
|
|
- BIND_ENUM_CONSTANT(COMPRESSION_ZSTD);
|
|
|
- BIND_ENUM_CONSTANT(COMPRESSION_GZIP);
|
|
|
-}
|
|
|
-
|
|
|
-////// Directory //////
|
|
|
-
|
|
|
-Error Directory::open(const String &p_path) {
|
|
|
- Error err;
|
|
|
- Ref<DirAccess> alt = DirAccess::open(p_path, &err);
|
|
|
- if (alt.is_null()) {
|
|
|
- return err;
|
|
|
- }
|
|
|
- d = alt;
|
|
|
- dir_open = true;
|
|
|
-
|
|
|
- return OK;
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::is_open() const {
|
|
|
- return d.is_valid() && dir_open;
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::list_dir_begin() {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), ERR_UNCONFIGURED, "Directory must be opened before use.");
|
|
|
- return d->list_dir_begin();
|
|
|
-}
|
|
|
-
|
|
|
-String Directory::get_next() {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), "", "Directory must be opened before use.");
|
|
|
-
|
|
|
- String next = d->get_next();
|
|
|
- while (!next.is_empty() && ((!include_navigational && (next == "." || next == "..")) || (!include_hidden && d->current_is_hidden()))) {
|
|
|
- next = d->get_next();
|
|
|
- }
|
|
|
- return next;
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::current_is_dir() const {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), false, "Directory must be opened before use.");
|
|
|
- return d->current_is_dir();
|
|
|
-}
|
|
|
-
|
|
|
-void Directory::list_dir_end() {
|
|
|
- ERR_FAIL_COND_MSG(!is_open(), "Directory must be opened before use.");
|
|
|
- d->list_dir_end();
|
|
|
-}
|
|
|
-
|
|
|
-PackedStringArray Directory::get_files() {
|
|
|
- return _get_contents(false);
|
|
|
-}
|
|
|
-
|
|
|
-PackedStringArray Directory::get_directories() {
|
|
|
- return _get_contents(true);
|
|
|
-}
|
|
|
-
|
|
|
-PackedStringArray Directory::_get_contents(bool p_directories) {
|
|
|
- PackedStringArray ret;
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), ret, "Directory must be opened before use.");
|
|
|
-
|
|
|
- list_dir_begin();
|
|
|
- String s = get_next();
|
|
|
- while (!s.is_empty()) {
|
|
|
- if (current_is_dir() == p_directories) {
|
|
|
- ret.append(s);
|
|
|
- }
|
|
|
- s = get_next();
|
|
|
- }
|
|
|
-
|
|
|
- ret.sort();
|
|
|
- return ret;
|
|
|
-}
|
|
|
-
|
|
|
-void Directory::set_include_navigational(bool p_enable) {
|
|
|
- include_navigational = p_enable;
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::get_include_navigational() const {
|
|
|
- return include_navigational;
|
|
|
-}
|
|
|
-
|
|
|
-void Directory::set_include_hidden(bool p_enable) {
|
|
|
- include_hidden = p_enable;
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::get_include_hidden() const {
|
|
|
- return include_hidden;
|
|
|
-}
|
|
|
-
|
|
|
-int Directory::get_drive_count() {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), 0, "Directory must be opened before use.");
|
|
|
- return d->get_drive_count();
|
|
|
-}
|
|
|
-
|
|
|
-String Directory::get_drive(int p_drive) {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), "", "Directory must be opened before use.");
|
|
|
- return d->get_drive(p_drive);
|
|
|
-}
|
|
|
-
|
|
|
-int Directory::get_current_drive() {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), 0, "Directory must be opened before use.");
|
|
|
- return d->get_current_drive();
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::change_dir(String p_dir) {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), ERR_UNCONFIGURED, "Directory is not configured properly.");
|
|
|
- Error err = d->change_dir(p_dir);
|
|
|
-
|
|
|
- if (err != OK) {
|
|
|
- return err;
|
|
|
- }
|
|
|
- dir_open = true;
|
|
|
-
|
|
|
- return OK;
|
|
|
-}
|
|
|
-
|
|
|
-String Directory::get_current_dir() {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), "", "Directory must be opened before use.");
|
|
|
- return d->get_current_dir();
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::make_dir(String p_dir) {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), ERR_UNCONFIGURED, "Directory is not configured properly.");
|
|
|
- if (!p_dir.is_relative_path()) {
|
|
|
- Ref<DirAccess> da = DirAccess::create_for_path(p_dir);
|
|
|
- return da->make_dir(p_dir);
|
|
|
- }
|
|
|
- return d->make_dir(p_dir);
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::make_dir_recursive(String p_dir) {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), ERR_UNCONFIGURED, "Directory is not configured properly.");
|
|
|
- if (!p_dir.is_relative_path()) {
|
|
|
- Ref<DirAccess> da = DirAccess::create_for_path(p_dir);
|
|
|
- return da->make_dir_recursive(p_dir);
|
|
|
- }
|
|
|
- return d->make_dir_recursive(p_dir);
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::file_exists(String p_file) {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), false, "Directory is not configured properly.");
|
|
|
- if (!p_file.is_relative_path()) {
|
|
|
- return FileAccess::exists(p_file);
|
|
|
- }
|
|
|
- return d->file_exists(p_file);
|
|
|
-}
|
|
|
-
|
|
|
-bool Directory::dir_exists(String p_dir) {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), false, "Directory is not configured properly.");
|
|
|
- if (!p_dir.is_relative_path()) {
|
|
|
- return DirAccess::exists(p_dir);
|
|
|
- }
|
|
|
- return d->dir_exists(p_dir);
|
|
|
-}
|
|
|
-
|
|
|
-uint64_t Directory::get_space_left() {
|
|
|
- ERR_FAIL_COND_V_MSG(d.is_null(), 0, "Directory must be opened before use.");
|
|
|
- return d->get_space_left() / 1024 * 1024; // Truncate to closest MiB.
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::copy(String p_from, String p_to) {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), ERR_UNCONFIGURED, "Directory must be opened before use.");
|
|
|
- return d->copy(p_from, p_to);
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::rename(String p_from, String p_to) {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), ERR_UNCONFIGURED, "Directory must be opened before use.");
|
|
|
- ERR_FAIL_COND_V_MSG(p_from.is_empty() || p_from == "." || p_from == "..", ERR_INVALID_PARAMETER, "Invalid path to rename.");
|
|
|
-
|
|
|
- if (!p_from.is_relative_path()) {
|
|
|
- Ref<DirAccess> da = DirAccess::create_for_path(p_from);
|
|
|
- ERR_FAIL_COND_V_MSG(!da->file_exists(p_from) && !da->dir_exists(p_from), ERR_DOES_NOT_EXIST, "File or directory does not exist.");
|
|
|
- return da->rename(p_from, p_to);
|
|
|
- }
|
|
|
-
|
|
|
- ERR_FAIL_COND_V_MSG(!d->file_exists(p_from) && !d->dir_exists(p_from), ERR_DOES_NOT_EXIST, "File or directory does not exist.");
|
|
|
- return d->rename(p_from, p_to);
|
|
|
-}
|
|
|
-
|
|
|
-Error Directory::remove(String p_name) {
|
|
|
- ERR_FAIL_COND_V_MSG(!is_open(), ERR_UNCONFIGURED, "Directory must be opened before use.");
|
|
|
- if (!p_name.is_relative_path()) {
|
|
|
- Ref<DirAccess> da = DirAccess::create_for_path(p_name);
|
|
|
- return da->remove(p_name);
|
|
|
- }
|
|
|
-
|
|
|
- return d->remove(p_name);
|
|
|
-}
|
|
|
-
|
|
|
-void Directory::_bind_methods() {
|
|
|
- ClassDB::bind_method(D_METHOD("open", "path"), &Directory::open);
|
|
|
- ClassDB::bind_method(D_METHOD("list_dir_begin"), &Directory::list_dir_begin, DEFVAL(false), DEFVAL(false));
|
|
|
- ClassDB::bind_method(D_METHOD("get_next"), &Directory::get_next);
|
|
|
- ClassDB::bind_method(D_METHOD("current_is_dir"), &Directory::current_is_dir);
|
|
|
- ClassDB::bind_method(D_METHOD("list_dir_end"), &Directory::list_dir_end);
|
|
|
- ClassDB::bind_method(D_METHOD("get_files"), &Directory::get_files);
|
|
|
- ClassDB::bind_method(D_METHOD("get_directories"), &Directory::get_directories);
|
|
|
- ClassDB::bind_method(D_METHOD("get_drive_count"), &Directory::get_drive_count);
|
|
|
- ClassDB::bind_method(D_METHOD("get_drive", "idx"), &Directory::get_drive);
|
|
|
- ClassDB::bind_method(D_METHOD("get_current_drive"), &Directory::get_current_drive);
|
|
|
- ClassDB::bind_method(D_METHOD("change_dir", "todir"), &Directory::change_dir);
|
|
|
- ClassDB::bind_method(D_METHOD("get_current_dir"), &Directory::get_current_dir);
|
|
|
- ClassDB::bind_method(D_METHOD("make_dir", "path"), &Directory::make_dir);
|
|
|
- ClassDB::bind_method(D_METHOD("make_dir_recursive", "path"), &Directory::make_dir_recursive);
|
|
|
- ClassDB::bind_method(D_METHOD("file_exists", "path"), &Directory::file_exists);
|
|
|
- ClassDB::bind_method(D_METHOD("dir_exists", "path"), &Directory::dir_exists);
|
|
|
- ClassDB::bind_method(D_METHOD("get_space_left"), &Directory::get_space_left);
|
|
|
- ClassDB::bind_method(D_METHOD("copy", "from", "to"), &Directory::copy);
|
|
|
- ClassDB::bind_method(D_METHOD("rename", "from", "to"), &Directory::rename);
|
|
|
- ClassDB::bind_method(D_METHOD("remove", "path"), &Directory::remove);
|
|
|
-
|
|
|
- ClassDB::bind_method(D_METHOD("set_include_navigational", "enable"), &Directory::set_include_navigational);
|
|
|
- ClassDB::bind_method(D_METHOD("get_include_navigational"), &Directory::get_include_navigational);
|
|
|
- ClassDB::bind_method(D_METHOD("set_include_hidden", "enable"), &Directory::set_include_hidden);
|
|
|
- ClassDB::bind_method(D_METHOD("get_include_hidden"), &Directory::get_include_hidden);
|
|
|
-
|
|
|
- ADD_PROPERTY(PropertyInfo(Variant::BOOL, "include_navigational"), "set_include_navigational", "get_include_navigational");
|
|
|
- ADD_PROPERTY(PropertyInfo(Variant::BOOL, "include_hidden"), "set_include_hidden", "get_include_hidden");
|
|
|
-}
|
|
|
-
|
|
|
-Directory::Directory() {
|
|
|
- d = DirAccess::create(DirAccess::ACCESS_RESOURCES);
|
|
|
-}
|
|
|
-
|
|
|
////// Marshalls //////
|
|
|
|
|
|
Marshalls *Marshalls::singleton = nullptr;
|