-fix local and global usage for DirAccess, fixes #791

please test anyway..
This commit is contained in:
Juan Linietsky 2015-04-18 20:11:33 -03:00
parent b66b86b05e
commit 1de1a04b78
5 changed files with 93 additions and 176 deletions

View file

@ -87,7 +87,7 @@ bool DirAccessUnix::dir_exists(String p_dir) {
if (p_dir.is_rel_path()) if (p_dir.is_rel_path())
p_dir=current_dir+"/"+p_dir; p_dir=get_current_dir().plus_file(p_dir);
else else
p_dir=fix_path(p_dir); p_dir=fix_path(p_dir);
@ -278,8 +278,15 @@ String DirAccessUnix::get_current_dir() {
Error DirAccessUnix::rename(String p_path,String p_new_path) { Error DirAccessUnix::rename(String p_path,String p_new_path) {
p_path=fix_path(p_path); if (p_path.is_rel_path())
p_new_path=fix_path(p_new_path); p_path=get_current_dir().plus_file(p_path);
else
p_path=fix_path(p_path);
if (p_new_path.is_rel_path())
p_new_path=get_current_dir().plus_file(p_new_path);
else
p_new_path=fix_path(p_new_path);
return ::rename(p_path.utf8().get_data(),p_new_path.utf8().get_data())==0?OK:FAILED; return ::rename(p_path.utf8().get_data(),p_new_path.utf8().get_data())==0?OK:FAILED;
} }

View file

@ -70,21 +70,11 @@ bool DirAccessWindows::list_dir_begin() {
_cisdir=false; _cisdir=false;
_cishidden=false; _cishidden=false;
if (unicode) { list_dir_end();
list_dir_end(); p->h = FindFirstFileExW((current_dir+"\\*").c_str(), FindExInfoStandard, &p->fu, FindExSearchNameMatch, NULL, 0);
p->h = FindFirstFileExW((current_dir+"\\*").c_str(), FindExInfoStandard, &p->fu, FindExSearchNameMatch, NULL, 0);
return (p->h==INVALID_HANDLE_VALUE); return (p->h==INVALID_HANDLE_VALUE);
} else {
list_dir_end();
p->h = FindFirstFileExA((current_dir+"\\*").ascii().get_data(), FindExInfoStandard, &p->fu, FindExSearchNameMatch, NULL, 0);
return (p->h==INVALID_HANDLE_VALUE);
}
return false;
} }
@ -93,38 +83,20 @@ String DirAccessWindows::get_next() {
if (p->h==INVALID_HANDLE_VALUE) if (p->h==INVALID_HANDLE_VALUE)
return ""; return "";
if (unicode) {
_cisdir=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY); _cisdir=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY);
_cishidden=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_HIDDEN); _cishidden=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_HIDDEN);
String name=p->fu.cFileName; String name=p->fu.cFileName;
if (FindNextFileW(p->h, &p->fu) == 0) { if (FindNextFileW(p->h, &p->fu) == 0) {
FindClose(p->h); FindClose(p->h);
p->h=INVALID_HANDLE_VALUE; p->h=INVALID_HANDLE_VALUE;
}
return name;
} else {
#ifndef WINRT_ENABLED
_cisdir=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY);
_cishidden=(p->fu.dwFileAttributes & FILE_ATTRIBUTE_HIDDEN);
String name=p->f.cFileName;
if (FindNextFileA(p->h, &p->f) == 0) {
FindClose(p->h);
p->h=INVALID_HANDLE_VALUE;
}
return name;
#endif
return "";
} }
return name;
} }
bool DirAccessWindows::current_is_dir() const { bool DirAccessWindows::current_is_dir() const {
@ -174,63 +146,37 @@ Error DirAccessWindows::change_dir(String p_dir) {
p_dir=fix_path(p_dir); p_dir=fix_path(p_dir);
if (unicode) {
wchar_t real_current_dir_name[2048]; wchar_t real_current_dir_name[2048];
GetCurrentDirectoryW(2048,real_current_dir_name);
String prev_dir=real_current_dir_name;
SetCurrentDirectoryW(current_dir.c_str());
bool worked=(SetCurrentDirectoryW(p_dir.c_str())!=0);
String base = _get_root_path();
if (base!="") {
GetCurrentDirectoryW(2048,real_current_dir_name); GetCurrentDirectoryW(2048,real_current_dir_name);
String prev_dir=real_current_dir_name; String new_dir;
new_dir = String(real_current_dir_name).replace("\\","/");
SetCurrentDirectoryW(current_dir.c_str()); if (!new_dir.begins_with(base)) {
bool worked=(SetCurrentDirectoryW(p_dir.c_str())!=0); worked=false;
String base = _get_root_path();
if (base!="") {
GetCurrentDirectoryW(2048,real_current_dir_name);
String new_dir;
new_dir = String(real_current_dir_name).replace("\\","/");
if (!new_dir.begins_with(base)) {
worked=false;
}
} }
if (worked) {
GetCurrentDirectoryW(2048,real_current_dir_name);
current_dir=real_current_dir_name; // TODO, utf8 parser
current_dir=current_dir.replace("\\","/");
} //else {
SetCurrentDirectoryW(prev_dir.c_str());
//}
return worked?OK:ERR_INVALID_PARAMETER;
} else {
char real_current_dir_name[2048];
GetCurrentDirectoryA(2048,real_current_dir_name);
String prev_dir=real_current_dir_name;
SetCurrentDirectoryA(current_dir.ascii().get_data());
bool worked=(SetCurrentDirectory(p_dir.ascii().get_data())!=0);
if (worked) {
GetCurrentDirectoryA(2048,real_current_dir_name);
current_dir=real_current_dir_name; // TODO, utf8 parser
current_dir=current_dir.replace("\\","/");
}// else {
SetCurrentDirectoryA(prev_dir.ascii().get_data());
//}
return worked?OK:ERR_INVALID_PARAMETER;
} }
return OK; if (worked) {
GetCurrentDirectoryW(2048,real_current_dir_name);
current_dir=real_current_dir_name; // TODO, utf8 parser
current_dir=current_dir.replace("\\","/");
} //else {
SetCurrentDirectoryW(prev_dir.c_str());
//}
return worked?OK:ERR_INVALID_PARAMETER;
#endif #endif
} }
@ -244,36 +190,22 @@ Error DirAccessWindows::make_dir(String p_dir) {
#else #else
p_dir=fix_path(p_dir); //p_dir=fix_path(p_dir);
p_dir.replace("/","\\"); p_dir.replace("/","\\");
bool success; bool success;
int err; int err;
if (unicode) { wchar_t real_current_dir_name[2048];
wchar_t real_current_dir_name[2048]; GetCurrentDirectoryW(2048,real_current_dir_name);
GetCurrentDirectoryW(2048,real_current_dir_name);
SetCurrentDirectoryW(current_dir.c_str()); SetCurrentDirectoryW(current_dir.c_str());
success=CreateDirectoryW(p_dir.c_str(), NULL); success=CreateDirectoryW(p_dir.c_str(), NULL);
err = GetLastError(); err = GetLastError();
SetCurrentDirectoryW(real_current_dir_name); SetCurrentDirectoryW(real_current_dir_name);
} else {
char real_current_dir_name[2048];
GetCurrentDirectoryA(2048,real_current_dir_name);
SetCurrentDirectoryA(current_dir.ascii().get_data());
success=CreateDirectoryA(p_dir.ascii().get_data(), NULL);
err = GetLastError();
SetCurrentDirectoryA(real_current_dir_name);
}
if (success) { if (success) {
return OK; return OK;
@ -313,7 +245,7 @@ bool DirAccessWindows::file_exists(String p_file) {
GLOBAL_LOCK_FUNCTION GLOBAL_LOCK_FUNCTION
if (!p_file.is_abs_path()) if (!p_file.is_abs_path())
p_file=get_current_dir()+"/"+p_file; p_file=get_current_dir().plus_file(p_file);
p_file=fix_path(p_file); p_file=fix_path(p_file);
@ -321,72 +253,51 @@ bool DirAccessWindows::file_exists(String p_file) {
WIN32_FILE_ATTRIBUTE_DATA fileInfo; WIN32_FILE_ATTRIBUTE_DATA fileInfo;
if (unicode) { DWORD fileAttr;
DWORD fileAttr; fileAttr = GetFileAttributesExW(p_file.c_str(), GetFileExInfoStandard, &fileInfo);
if (0 == fileAttr)
return false;
fileAttr = GetFileAttributesExW(p_file.c_str(), GetFileExInfoStandard, &fileInfo); return !(fileAttr&FILE_ATTRIBUTE_DIRECTORY);
if (0 == fileAttr)
return false;
return !(fileAttr&FILE_ATTRIBUTE_DIRECTORY);
} else {
DWORD fileAttr;
fileAttr = GetFileAttributesExA(p_file.ascii().get_data(), GetFileExInfoStandard, &fileInfo);
if (0 == fileAttr)
return false;
return !(fileAttr&FILE_ATTRIBUTE_DIRECTORY);
}
return false;
} }
bool DirAccessWindows::dir_exists(String p_dir) { bool DirAccessWindows::dir_exists(String p_dir) {
GLOBAL_LOCK_FUNCTION GLOBAL_LOCK_FUNCTION
if (!p_dir.is_abs_path()) if (p_dir.is_rel_path())
p_dir=get_current_dir()+"/"+p_dir; p_dir=get_current_dir().plus_file(p_dir);
else
p_dir=fix_path(p_dir); p_dir=fix_path(p_dir);
p_dir.replace("/","\\"); p_dir.replace("/","\\");
WIN32_FILE_ATTRIBUTE_DATA fileInfo; WIN32_FILE_ATTRIBUTE_DATA fileInfo;
if (unicode) {
DWORD fileAttr; DWORD fileAttr;
fileAttr = GetFileAttributesExW(p_dir.c_str(), GetFileExInfoStandard, &fileInfo); fileAttr = GetFileAttributesExW(p_dir.c_str(), GetFileExInfoStandard, &fileInfo);
if (0 == fileAttr) if (0 == fileAttr)
return false; return false;
return (fileAttr&FILE_ATTRIBUTE_DIRECTORY); return (fileAttr&FILE_ATTRIBUTE_DIRECTORY);
} else {
#ifndef WINRT_ENABLED
DWORD fileAttr;
fileAttr = GetFileAttributesExA(p_dir.ascii().get_data(), GetFileExInfoStandard, &fileInfo);
if (0 == fileAttr)
return false;
return (fileAttr&FILE_ATTRIBUTE_DIRECTORY);
#endif
}
return false;
} }
Error DirAccessWindows::rename(String p_path,String p_new_path) { Error DirAccessWindows::rename(String p_path,String p_new_path) {
p_path=fix_path(p_path); if (p_path.is_rel_path())
p_new_path=fix_path(p_new_path); p_path=get_current_dir().plus_file(p_path);
else
p_path=fix_path(p_path);
if (p_new_path.is_rel_path())
p_new_path=get_current_dir().plus_file(p_new_path);
else
p_new_path=fix_path(p_new_path);
if (file_exists(p_new_path)) { if (file_exists(p_new_path)) {
if (remove(p_new_path) != OK) { if (remove(p_new_path) != OK) {
@ -471,13 +382,6 @@ DirAccessWindows::DirAccessWindows() {
} }
} }
unicode=true;
/* We are running Windows 95/98/ME, so no unicode allowed */
if ( SetCurrentDirectoryW ( L"." ) == FALSE && GetLastError () == ERROR_CALL_NOT_IMPLEMENTED )
unicode=false;
change_dir("."); change_dir(".");
#endif #endif
} }

View file

@ -56,7 +56,7 @@ class DirAccessWindows : public DirAccess {
String current_dir; String current_dir;
bool unicode;
bool _cisdir; bool _cisdir;
bool _cishidden; bool _cishidden;

View file

@ -176,7 +176,7 @@ bool DirAccessJAndroid::file_exists(String p_file){
if (current_dir=="") if (current_dir=="")
sd=p_file; sd=p_file;
else else
sd=current_dir+"/"+p_file; sd=current_dir.plus_file(p_file);
FileAccessJAndroid *f = memnew(FileAccessJAndroid); FileAccessJAndroid *f = memnew(FileAccessJAndroid);
bool exists = f->file_exists(sd); bool exists = f->file_exists(sd);
@ -190,12 +190,19 @@ bool DirAccessJAndroid::dir_exists(String p_dir) {
JNIEnv *env = ThreadAndroid::get_env(); JNIEnv *env = ThreadAndroid::get_env();
String sd; String sd;
if (current_dir=="") if (current_dir=="")
sd=p_dir; sd=p_dir;
else else {
sd=current_dir+"/"+p_dir; if (p_dir.is_rel_path())
sd=current_dir.plus_file(p_dir);
else
sd=fix_path(p_dir);
}
String path=sd.simplify_path();
String path=fix_path(sd).simplify_path();
if (path.begins_with("/")) if (path.begins_with("/"))
path=path.substr(1,path.length()); path=path.substr(1,path.length());
else if (path.begins_with("res://")) else if (path.begins_with("res://"))

View file

@ -734,7 +734,6 @@ void EditorSceneImportDialog::_import(bool p_and_open) {
return; return;
} }
print_line("PI REFERENCES "+itos(scr->reference_get_count()));
} }