Fix Find in Files:
- FileAccess was accessed null (remains of GDScript port) - `_current_file` wasn't going up correctly in case a scanned directory had no subdirectories - Paths stored in `_files_to_scan` were not full paths
This commit is contained in:
parent
7d6f210ccb
commit
4c415001b2
|
@ -154,9 +154,7 @@ void FindInFiles::_iterate() {
|
|||
PoolStringArray sub_dirs;
|
||||
_scan_dir(_root_prefix + _current_dir, sub_dirs);
|
||||
|
||||
if (sub_dirs.size() != 0) {
|
||||
_folders_stack.push_back(sub_dirs);
|
||||
}
|
||||
_folders_stack.push_back(sub_dirs);
|
||||
|
||||
} else {
|
||||
// Go back one level
|
||||
|
@ -176,7 +174,7 @@ void FindInFiles::_iterate() {
|
|||
|
||||
String fpath = _files_to_scan[_files_to_scan.size() - 1];
|
||||
pop_back(_files_to_scan);
|
||||
_scan_file(_root_prefix + fpath);
|
||||
_scan_file(fpath);
|
||||
|
||||
} else {
|
||||
print_line("Search complete");
|
||||
|
@ -202,8 +200,6 @@ void FindInFiles::_scan_dir(String path, PoolStringArray &out_folders) {
|
|||
return;
|
||||
}
|
||||
|
||||
//print_line(String("Scanning ") + path);
|
||||
|
||||
dir->list_dir_begin();
|
||||
|
||||
for (int i = 0; i < 1000; ++i) {
|
||||
|
@ -222,7 +218,7 @@ void FindInFiles::_scan_dir(String path, PoolStringArray &out_folders) {
|
|||
else {
|
||||
String file_ext = file.get_extension();
|
||||
if (_extension_filter.has(file_ext)) {
|
||||
_files_to_scan.push_back(file);
|
||||
_files_to_scan.push_back(path.plus_file(file));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -232,7 +228,6 @@ void FindInFiles::_scan_file(String fpath) {
|
|||
|
||||
FileAccess *f = FileAccess::open(fpath, FileAccess::READ);
|
||||
if (f == NULL) {
|
||||
f->close();
|
||||
print_line(String("Cannot open file ") + fpath);
|
||||
return;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue