mirror of https://github.com/AxioDL/metaforce.git
Added progress bars to extract tool
This commit is contained in:
parent
7a5fc8236a
commit
4d4636f2e7
|
@ -4,7 +4,6 @@
|
|||
#include <string>
|
||||
#include <vector>
|
||||
#include <stdio.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
|
||||
|
@ -45,6 +44,9 @@ public:
|
|||
#define BOLD "\033[1m"
|
||||
#define NORMAL "\033[0m"
|
||||
|
||||
#define HIDE_CURSOR "\033[?25l"
|
||||
#define SHOW_CURSOR "\033[?25h"
|
||||
|
||||
#define WRAP_INDENT 4
|
||||
|
||||
extern bool XTERM_COLOR;
|
||||
|
@ -119,21 +121,8 @@ private:
|
|||
public:
|
||||
|
||||
HelpOutput(HelpFunc helpFunc)
|
||||
: m_sout(NULL), m_helpFunc(helpFunc)
|
||||
{
|
||||
#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;
|
||||
}
|
||||
: m_sout(NULL), m_helpFunc(helpFunc), m_lineWidth(HECL::ConsoleWidth())
|
||||
{}
|
||||
|
||||
void go()
|
||||
{
|
||||
|
|
|
@ -7,7 +7,14 @@
|
|||
class ToolExtract final : public ToolBase
|
||||
{
|
||||
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;
|
||||
public:
|
||||
ToolExtract(const ToolPassInfo& info)
|
||||
|
@ -32,7 +39,7 @@ public:
|
|||
if (ds)
|
||||
{
|
||||
if (ds->canExtract(*m_info.project, m_einfo, m_reps))
|
||||
m_dataSpecs.emplace_back(ds);
|
||||
m_specPasses.emplace_back(entry, ds);
|
||||
else
|
||||
delete ds;
|
||||
}
|
||||
|
@ -85,7 +92,7 @@ public:
|
|||
|
||||
int run()
|
||||
{
|
||||
if (m_dataSpecs.empty())
|
||||
if (m_specPasses.empty())
|
||||
{
|
||||
if (XTERM_COLOR)
|
||||
HECL::Printf(_S("" RED BOLD "NOTHING TO EXTRACT" NORMAL "\n"));
|
||||
|
@ -119,8 +126,72 @@ public:
|
|||
break;
|
||||
}
|
||||
|
||||
for (std::unique_ptr<HECL::Database::IDataSpec>& ds : m_dataSpecs)
|
||||
ds->doExtract(*m_info.project, m_einfo);
|
||||
for (SpecExtractPass& ds : m_specPasses)
|
||||
{
|
||||
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;
|
||||
}
|
||||
|
|
|
@ -1 +1 @@
|
|||
Subproject commit 7442d618e7f82acdc8f986baca040033c1f411f9
|
||||
Subproject commit 6405bffdd20d9b4c5e61a9600c69ca7bde5bc582
|
|
@ -1 +1 @@
|
|||
Subproject commit 149165ee97f1ab310e8fc6f8643c501297a18fe2
|
||||
Subproject commit a4d6e32e4848b2b33c9e95104b7259d24067b0b9
|
|
@ -216,10 +216,12 @@ public:
|
|||
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)
|
||||
{(void)project;(void)info;LogModule.report(LogVisor::Error, "not implemented");return false;}
|
||||
virtual void doExtract(Project& project, const ExtractPassInfo& info)
|
||||
{(void)project;(void)info;}
|
||||
virtual void doExtract(Project& project, const ExtractPassInfo& info, FExtractProgress progress)
|
||||
{(void)project;(void)info;(void)progress;}
|
||||
|
||||
/**
|
||||
* @brief Cook Task Info
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
#include <sys/param.h>
|
||||
#include <sys/stat.h>
|
||||
#include <sys/file.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <dirent.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
|
@ -37,6 +38,7 @@ std::wstring UTF8ToWide(const std::string& src);
|
|||
|
||||
#if HECL_UCS2
|
||||
typedef wchar_t SystemChar;
|
||||
static inline size_t StrLen(const SystemChar* str) {return wcslen(str);}
|
||||
typedef std::wstring SystemString;
|
||||
static inline void ToLower(SystemString& str)
|
||||
{std::transform(str.begin(), str.end(), str.begin(), towlower);}
|
||||
|
@ -49,6 +51,7 @@ public:
|
|||
SystemUTF8View(const SystemString& str)
|
||||
: m_utf8(WideToUTF8(str)) {}
|
||||
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 char* other) const {return m_utf8 + other;}
|
||||
};
|
||||
|
@ -61,6 +64,7 @@ public:
|
|||
SystemStringView(const std::string& str)
|
||||
: m_sys(UTF8ToWide(str)) {}
|
||||
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 wchar_t* other) const {return m_sys + other;}
|
||||
};
|
||||
|
@ -71,6 +75,7 @@ inline std::wstring operator+(const wchar_t* lhs, const SystemStringView& rhs) {
|
|||
#endif
|
||||
#else
|
||||
typedef char SystemChar;
|
||||
static inline size_t StrLen(const SystemChar* str) {return strlen(str);}
|
||||
typedef std::string SystemString;
|
||||
static inline void ToLower(SystemString& str)
|
||||
{std::transform(str.begin(), str.end(), str.begin(), tolower);}
|
||||
|
@ -83,6 +88,7 @@ public:
|
|||
SystemUTF8View(const SystemString& str)
|
||||
: m_utf8(str) {}
|
||||
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 char* other) const {return std::string(m_utf8) + other;}
|
||||
};
|
||||
|
@ -95,6 +101,7 @@ public:
|
|||
SystemStringView(const std::string& str)
|
||||
: m_sys(str) {}
|
||||
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 char* other) const {return m_sys + other;}
|
||||
};
|
||||
|
@ -230,6 +237,23 @@ static inline std::string Format(const char* format, ...)
|
|||
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::regex_token_iterator<SystemString::const_iterator> SystemRegexTokenIterator;
|
||||
typedef std::match_results<SystemString::const_iterator> SystemRegexMatch;
|
||||
|
|
Loading…
Reference in New Issue