Added progress bars to extract tool

This commit is contained in:
Jack Andersen 2015-07-20 13:27:22 -10:00
parent 7a5fc8236a
commit 4d4636f2e7
6 changed files with 111 additions and 25 deletions

View File

@ -4,7 +4,6 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include <stdio.h> #include <stdio.h>
#include <sys/ioctl.h>
#include <unistd.h> #include <unistd.h>
#include <string.h> #include <string.h>
@ -45,6 +44,9 @@ public:
#define BOLD "\033[1m" #define BOLD "\033[1m"
#define NORMAL "\033[0m" #define NORMAL "\033[0m"
#define HIDE_CURSOR "\033[?25l"
#define SHOW_CURSOR "\033[?25h"
#define WRAP_INDENT 4 #define WRAP_INDENT 4
extern bool XTERM_COLOR; extern bool XTERM_COLOR;
@ -119,21 +121,8 @@ private:
public: public:
HelpOutput(HelpFunc helpFunc) HelpOutput(HelpFunc helpFunc)
: m_sout(NULL), m_helpFunc(helpFunc) : m_sout(NULL), m_helpFunc(helpFunc), m_lineWidth(HECL::ConsoleWidth())
{ {}
#if _WIN32
CONSOLE_SCREEN_BUFFER_INFO info;
GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &info);
m_lineWidth = info.dwSize.X;
#else
struct winsize w;
m_lineWidth = 80;
if (ioctl(STDOUT_FILENO, TIOCGWINSZ, &w) != -1)
m_lineWidth = w.ws_col;
#endif
if (m_lineWidth < 10)
m_lineWidth = 10;
}
void go() void go()
{ {

View File

@ -7,7 +7,14 @@
class ToolExtract final : public ToolBase class ToolExtract final : public ToolBase
{ {
HECL::Database::IDataSpec::ExtractPassInfo m_einfo; HECL::Database::IDataSpec::ExtractPassInfo m_einfo;
std::vector<std::unique_ptr<HECL::Database::IDataSpec>> m_dataSpecs; struct SpecExtractPass
{
const HECL::Database::DataSpecEntry* m_entry;
std::unique_ptr<HECL::Database::IDataSpec> m_instance;
SpecExtractPass(const HECL::Database::DataSpecEntry* entry, HECL::Database::IDataSpec* instance)
: m_entry(entry), m_instance(instance) {}
};
std::vector<SpecExtractPass> m_specPasses;
std::vector<HECL::Database::IDataSpec::ExtractReport> m_reps; std::vector<HECL::Database::IDataSpec::ExtractReport> m_reps;
public: public:
ToolExtract(const ToolPassInfo& info) ToolExtract(const ToolPassInfo& info)
@ -32,7 +39,7 @@ public:
if (ds) if (ds)
{ {
if (ds->canExtract(*m_info.project, m_einfo, m_reps)) if (ds->canExtract(*m_info.project, m_einfo, m_reps))
m_dataSpecs.emplace_back(ds); m_specPasses.emplace_back(entry, ds);
else else
delete ds; delete ds;
} }
@ -85,7 +92,7 @@ public:
int run() int run()
{ {
if (m_dataSpecs.empty()) if (m_specPasses.empty())
{ {
if (XTERM_COLOR) if (XTERM_COLOR)
HECL::Printf(_S("" RED BOLD "NOTHING TO EXTRACT" NORMAL "\n")); HECL::Printf(_S("" RED BOLD "NOTHING TO EXTRACT" NORMAL "\n"));
@ -119,8 +126,72 @@ public:
break; break;
} }
for (std::unique_ptr<HECL::Database::IDataSpec>& ds : m_dataSpecs) for (SpecExtractPass& ds : m_specPasses)
ds->doExtract(*m_info.project, m_einfo); {
if (XTERM_COLOR)
HECL::Printf(_S("" MAGENTA BOLD "Using DataSpec %s:" NORMAL "\n"), ds.m_entry->m_name.c_str());
else
HECL::Printf(_S("Using DataSpec %s:\n"), ds.m_entry->m_name.c_str());
int lineIdx = 0;
ds.m_instance->doExtract(*m_info.project, m_einfo,
[&lineIdx](const HECL::SystemChar* message, int lidx, float factor)
{
if (XTERM_COLOR)
HECL::Printf(_S("" HIDE_CURSOR ""));
if (lidx > lineIdx)
{
HECL::Printf(_S("\n "));
lineIdx = lidx;
}
else
HECL::Printf(_S(" "));
int width = HECL::ConsoleWidth();
int half = width / 2 - 2;
size_t messageLen = HECL::StrLen(message);
if (messageLen > half)
HECL::Printf(_S("%.*s... "), half-3, message);
else
{
HECL::Printf(_S("%s"), message);
for (int i=half-messageLen ; i>=0 ; --i)
HECL::Printf(_S(" "));
}
if (XTERM_COLOR)
{
size_t blocks = half - 7;
size_t filled = blocks * factor;
size_t rem = blocks - filled;
HECL::Printf(_S("" BOLD "%3d%% ["), (int)(factor * 100.0));
for (int b=0 ; b<filled ; ++b)
HECL::Printf(_S("#"), message);
for (int b=0 ; b<rem ; ++b)
HECL::Printf(_S("-"), message);
HECL::Printf(_S("]" NORMAL ""));
}
else
{
size_t blocks = half - 7;
size_t filled = blocks * factor;
size_t rem = blocks - filled;
HECL::Printf(_S("%3d%% ["), (int)(factor * 100.0));
for (int b=0 ; b<filled ; ++b)
HECL::Printf(_S("#"), message);
for (int b=0 ; b<rem ; ++b)
HECL::Printf(_S("-"), message);
HECL::Printf(_S("]"));
}
HECL::Printf(_S("\r"));
if (XTERM_COLOR)
HECL::Printf(_S("" SHOW_CURSOR ""));
});
HECL::Printf(_S("\n\n"));
}
return 0; return 0;
} }

2
hecl/extern/Athena vendored

@ -1 +1 @@
Subproject commit 7442d618e7f82acdc8f986baca040033c1f411f9 Subproject commit 6405bffdd20d9b4c5e61a9600c69ca7bde5bc582

@ -1 +1 @@
Subproject commit 149165ee97f1ab310e8fc6f8643c501297a18fe2 Subproject commit a4d6e32e4848b2b33c9e95104b7259d24067b0b9

View File

@ -216,10 +216,12 @@ public:
std::vector<ExtractReport> childOpts; std::vector<ExtractReport> childOpts;
}; };
typedef std::function<void(const HECL::SystemChar*, int, float)> FExtractProgress;
virtual bool canExtract(Project& project, const ExtractPassInfo& info, std::vector<ExtractReport>& reps) virtual bool canExtract(Project& project, const ExtractPassInfo& info, std::vector<ExtractReport>& reps)
{(void)project;(void)info;LogModule.report(LogVisor::Error, "not implemented");return false;} {(void)project;(void)info;LogModule.report(LogVisor::Error, "not implemented");return false;}
virtual void doExtract(Project& project, const ExtractPassInfo& info) virtual void doExtract(Project& project, const ExtractPassInfo& info, FExtractProgress progress)
{(void)project;(void)info;} {(void)project;(void)info;(void)progress;}
/** /**
* @brief Cook Task Info * @brief Cook Task Info

View File

@ -6,6 +6,7 @@
#include <sys/param.h> #include <sys/param.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/file.h> #include <sys/file.h>
#include <sys/ioctl.h>
#include <dirent.h> #include <dirent.h>
#include <fcntl.h> #include <fcntl.h>
#include <unistd.h> #include <unistd.h>
@ -37,6 +38,7 @@ std::wstring UTF8ToWide(const std::string& src);
#if HECL_UCS2 #if HECL_UCS2
typedef wchar_t SystemChar; typedef wchar_t SystemChar;
static inline size_t StrLen(const SystemChar* str) {return wcslen(str);}
typedef std::wstring SystemString; typedef std::wstring SystemString;
static inline void ToLower(SystemString& str) static inline void ToLower(SystemString& str)
{std::transform(str.begin(), str.end(), str.begin(), towlower);} {std::transform(str.begin(), str.end(), str.begin(), towlower);}
@ -49,6 +51,7 @@ public:
SystemUTF8View(const SystemString& str) SystemUTF8View(const SystemString& str)
: m_utf8(WideToUTF8(str)) {} : m_utf8(WideToUTF8(str)) {}
inline operator const std::string&() const {return m_utf8;} inline operator const std::string&() const {return m_utf8;}
inline const std::string& str() const {return m_utf8;}
inline std::string operator+(const std::string& other) const {return m_utf8 + other;} inline std::string operator+(const std::string& other) const {return m_utf8 + other;}
inline std::string operator+(const char* other) const {return m_utf8 + other;} inline std::string operator+(const char* other) const {return m_utf8 + other;}
}; };
@ -61,6 +64,7 @@ public:
SystemStringView(const std::string& str) SystemStringView(const std::string& str)
: m_sys(UTF8ToWide(str)) {} : m_sys(UTF8ToWide(str)) {}
inline operator const std::wstring&() const {return m_sys;} inline operator const std::wstring&() const {return m_sys;}
inline const std::wstring& sys_str() const {return m_sys;}
inline std::wstring operator+(const std::wstring& other) const {return m_sys + other;} inline std::wstring operator+(const std::wstring& other) const {return m_sys + other;}
inline std::wstring operator+(const wchar_t* other) const {return m_sys + other;} inline std::wstring operator+(const wchar_t* other) const {return m_sys + other;}
}; };
@ -71,6 +75,7 @@ inline std::wstring operator+(const wchar_t* lhs, const SystemStringView& rhs) {
#endif #endif
#else #else
typedef char SystemChar; typedef char SystemChar;
static inline size_t StrLen(const SystemChar* str) {return strlen(str);}
typedef std::string SystemString; typedef std::string SystemString;
static inline void ToLower(SystemString& str) static inline void ToLower(SystemString& str)
{std::transform(str.begin(), str.end(), str.begin(), tolower);} {std::transform(str.begin(), str.end(), str.begin(), tolower);}
@ -83,6 +88,7 @@ public:
SystemUTF8View(const SystemString& str) SystemUTF8View(const SystemString& str)
: m_utf8(str) {} : m_utf8(str) {}
inline operator const std::string&() const {return m_utf8;} inline operator const std::string&() const {return m_utf8;}
inline const std::string& str() const {return m_utf8;}
inline std::string operator+(const std::string& other) const {return std::string(m_utf8) + other;} inline std::string operator+(const std::string& other) const {return std::string(m_utf8) + other;}
inline std::string operator+(const char* other) const {return std::string(m_utf8) + other;} inline std::string operator+(const char* other) const {return std::string(m_utf8) + other;}
}; };
@ -95,6 +101,7 @@ public:
SystemStringView(const std::string& str) SystemStringView(const std::string& str)
: m_sys(str) {} : m_sys(str) {}
inline operator const std::string&() const {return m_sys;} inline operator const std::string&() const {return m_sys;}
inline const std::string& sys_str() const {return m_sys;}
inline std::string operator+(const std::string& other) const {return m_sys + other;} inline std::string operator+(const std::string& other) const {return m_sys + other;}
inline std::string operator+(const char* other) const {return m_sys + other;} inline std::string operator+(const char* other) const {return m_sys + other;}
}; };
@ -230,6 +237,23 @@ static inline std::string Format(const char* format, ...)
return std::string(resultBuf, printSz); return std::string(resultBuf, printSz);
} }
static inline int ConsoleWidth()
{
int retval = 80;
#if _WIN32
CONSOLE_SCREEN_BUFFER_INFO info;
GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &info);
m_lineWidth = info.dwSize.X;
#else
struct winsize w;
if (ioctl(STDOUT_FILENO, TIOCGWINSZ, &w) != -1)
retval = w.ws_col;
#endif
if (retval < 10)
return 10;
return retval;
}
typedef std::basic_regex<SystemChar> SystemRegex; typedef std::basic_regex<SystemChar> SystemRegex;
typedef std::regex_token_iterator<SystemString::const_iterator> SystemRegexTokenIterator; typedef std::regex_token_iterator<SystemString::const_iterator> SystemRegexTokenIterator;
typedef std::match_results<SystemString::const_iterator> SystemRegexMatch; typedef std::match_results<SystemString::const_iterator> SystemRegexMatch;