diff options
-rw-r--r-- | gui/fileselector.cpp | 11 | ||||
-rw-r--r-- | openrecoveryscript.cpp | 3 | ||||
-rw-r--r-- | twrp-functions.cpp | 21 | ||||
-rw-r--r-- | twrp-functions.hpp | 1 |
4 files changed, 33 insertions, 3 deletions
diff --git a/gui/fileselector.cpp b/gui/fileselector.cpp index aecdd253c..38eaadd20 100644 --- a/gui/fileselector.cpp +++ b/gui/fileselector.cpp @@ -31,6 +31,7 @@ extern "C" { #include "rapidxml.hpp" #include "objects.hpp" #include "../data.hpp" +#include "../twrp-functions.hpp" #define TW_FILESELECTOR_UP_A_LEVEL "(Up A Level)" @@ -787,9 +788,12 @@ int GUIFileSelector::GetFileList(const std::string folder) continue; if (data.fileName == ".." && folder == "/") continue; - if (data.fileName == "..") + if (data.fileName == "..") { data.fileName = TW_FILESELECTOR_UP_A_LEVEL; - data.fileType = de->d_type; + data.fileType = DT_DIR; + } else { + data.fileType = de->d_type; + } std::string path = folder + "/" + data.fileName; stat(path.c_str(), &st); @@ -801,6 +805,9 @@ int GUIFileSelector::GetFileList(const std::string folder) data.lastModified = st.st_mtime; data.lastStatChange = st.st_ctime; + if (data.fileType == DT_UNKNOWN) { + data.fileType = TWFunc::Get_D_Type_From_Stat(path); + } if (data.fileType == DT_DIR) { if (mShowNavFolders || (data.fileName != "." && data.fileName != TW_FILESELECTOR_UP_A_LEVEL)) diff --git a/openrecoveryscript.cpp b/openrecoveryscript.cpp index 6df1207b9..e319a9c61 100644 --- a/openrecoveryscript.cpp +++ b/openrecoveryscript.cpp @@ -75,6 +75,7 @@ int OpenRecoveryScript::run_script_file(void) { if (fp != NULL) { DataManager::SetValue(TW_SIMULATE_ACTIONS, 0); + DataManager::SetValue("ui_progress", 0); // Reset the progress bar while (fgets(script_line, SCRIPT_COMMAND_SIZE, fp) != NULL && ret_val == 0) { cindex = 0; line_len = strlen(script_line); @@ -572,4 +573,4 @@ void OpenRecoveryScript::Run_OpenRecoveryScript(void) { if (gui_startPage("action_page") != 0) { LOGE("Failed to load OpenRecoveryScript GUI page.\n"); } -}
\ No newline at end of file +} diff --git a/twrp-functions.cpp b/twrp-functions.cpp index edf4898b1..5473c8d66 100644 --- a/twrp-functions.cpp +++ b/twrp-functions.cpp @@ -453,3 +453,24 @@ int TWFunc::copy_file(string src, string dst, int mode) { dstfile.close(); return 0; } + +unsigned int TWFunc::Get_D_Type_From_Stat(string Path) { + struct stat st; + + stat(Path.c_str(), &st); + if (st.st_mode & S_IFDIR) + return DT_DIR; + else if (st.st_mode & S_IFBLK) + return DT_BLK; + else if (st.st_mode & S_IFCHR) + return DT_CHR; + else if (st.st_mode & S_IFIFO) + return DT_FIFO; + else if (st.st_mode & S_IFLNK) + return DT_LNK; + else if (st.st_mode & S_IFREG) + return DT_REG; + else if (st.st_mode & S_IFSOCK) + return DT_SOCK; + return DT_UNKNOWN; +}
\ No newline at end of file diff --git a/twrp-functions.hpp b/twrp-functions.hpp index 7cef37f31..8cd344557 100644 --- a/twrp-functions.hpp +++ b/twrp-functions.hpp @@ -39,6 +39,7 @@ public: static int Exec_Cmd(string cmd, string &result); //execute a command and return the result as a string by reference static int removeDir(const string path, bool removeParent); //recursively remove a directory static int copy_file(string src, string dst, int mode); //copy file from src to dst with mode permissions + static unsigned int Get_D_Type_From_Stat(string Path); // Returns a dirent dt_type value using stat instead of dirent private: static void check_and_fclose(FILE *fp, const char *name); |