mirror of https://github.com/AxioDL/metaforce.git
windows ANSI console support
This commit is contained in:
parent
1091f93536
commit
4780960161
|
@ -159,38 +159,26 @@ public:
|
||||||
|
|
||||||
void printBold(const HECL::SystemChar* str)
|
void printBold(const HECL::SystemChar* str)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::FPrintf(m_sout, _S("%s"), str);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL ""), str);
|
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL ""), str);
|
||||||
else
|
else
|
||||||
HECL::FPrintf(m_sout, _S("%s"), str);
|
HECL::FPrintf(m_sout, _S("%s"), str);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void secHead(const HECL::SystemChar* headName)
|
void secHead(const HECL::SystemChar* headName)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::FPrintf(m_sout, _S("%s\n"), headName);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL "\n"), headName);
|
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL "\n"), headName);
|
||||||
else
|
else
|
||||||
HECL::FPrintf(m_sout, _S("%s\n"), headName);
|
HECL::FPrintf(m_sout, _S("%s\n"), headName);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void optionHead(const HECL::SystemChar* flag, const HECL::SystemChar* synopsis)
|
void optionHead(const HECL::SystemChar* flag, const HECL::SystemChar* synopsis)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::FPrintf(m_sout, _S("%s (%s)\n"), flag, synopsis);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL " (%s)\n"), flag, synopsis);
|
HECL::FPrintf(m_sout, _S("" BOLD "%s" NORMAL " (%s)\n"), flag, synopsis);
|
||||||
else
|
else
|
||||||
HECL::FPrintf(m_sout, _S("%s (%s)\n"), flag, synopsis);
|
HECL::FPrintf(m_sout, _S("%s (%s)\n"), flag, synopsis);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void beginWrap()
|
void beginWrap()
|
||||||
|
@ -205,15 +193,11 @@ public:
|
||||||
|
|
||||||
void wrapBold(const HECL::SystemChar* str)
|
void wrapBold(const HECL::SystemChar* str)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
m_wrapBuffer += str;
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
m_wrapBuffer += _S("" BOLD "");
|
m_wrapBuffer += _S("" BOLD "");
|
||||||
m_wrapBuffer += str;
|
m_wrapBuffer += str;
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
m_wrapBuffer += _S("" NORMAL "");
|
m_wrapBuffer += _S("" NORMAL "");
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void endWrap()
|
void endWrap()
|
||||||
|
|
|
@ -116,14 +116,11 @@ public:
|
||||||
{
|
{
|
||||||
for (int l=0 ; l<level ; ++l)
|
for (int l=0 ; l<level ; ++l)
|
||||||
HECL::Printf(_S(" "));
|
HECL::Printf(_S(" "));
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("%s"), rep.name.c_str());
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" BOLD "%s" NORMAL ""), rep.name.c_str());
|
HECL::Printf(_S("" BOLD "%s" NORMAL ""), rep.name.c_str());
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("%s"), rep.name.c_str());
|
HECL::Printf(_S("%s"), rep.name.c_str());
|
||||||
#endif
|
|
||||||
if (rep.desc.size())
|
if (rep.desc.size())
|
||||||
HECL::Printf(_S(" [%s]"), rep.desc.c_str());
|
HECL::Printf(_S(" [%s]"), rep.desc.c_str());
|
||||||
HECL::Printf(_S("\n"));
|
HECL::Printf(_S("\n"));
|
||||||
|
@ -135,25 +132,17 @@ public:
|
||||||
{
|
{
|
||||||
if (m_specPasses.empty())
|
if (m_specPasses.empty())
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("NOTHING TO EXTRACT\n"));
|
|
||||||
#else
|
|
||||||
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"));
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("NOTHING TO EXTRACT\n"));
|
HECL::Printf(_S("NOTHING TO EXTRACT\n"));
|
||||||
#endif
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("ABOUT TO EXTRACT:\n"));
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" GREEN BOLD "ABOUT TO EXTRACT:" NORMAL "\n"));
|
HECL::Printf(_S("" GREEN BOLD "ABOUT TO EXTRACT:" NORMAL "\n"));
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("ABOUT TO EXTRACT:\n"));
|
HECL::Printf(_S("ABOUT TO EXTRACT:\n"));
|
||||||
#endif
|
|
||||||
|
|
||||||
for (HECL::Database::IDataSpec::ExtractReport& rep : m_reps)
|
for (HECL::Database::IDataSpec::ExtractReport& rep : m_reps)
|
||||||
{
|
{
|
||||||
|
@ -161,14 +150,10 @@ public:
|
||||||
HECL::Printf(_S("\n"));
|
HECL::Printf(_S("\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("\nContinue? (Y/n) "));
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("\n" BLUE BOLD "Continue?" NORMAL " (Y/n) "));
|
HECL::Printf(_S("\n" BLUE BOLD "Continue?" NORMAL " (Y/n) "));
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("\nContinue? (Y/n) "));
|
HECL::Printf(_S("\nContinue? (Y/n) "));
|
||||||
#endif
|
|
||||||
|
|
||||||
int ch;
|
int ch;
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
|
@ -195,28 +180,19 @@ public:
|
||||||
|
|
||||||
for (SpecExtractPass& ds : m_specPasses)
|
for (SpecExtractPass& ds : m_specPasses)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("Using DataSpec %s:\n"), ds.m_entry->m_name);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" MAGENTA BOLD "Using DataSpec %s:" NORMAL "\n"), ds.m_entry->m_name);
|
HECL::Printf(_S("" MAGENTA BOLD "Using DataSpec %s:" NORMAL "\n"), ds.m_entry->m_name);
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("Using DataSpec %s:\n"), ds.m_entry->m_name);
|
HECL::Printf(_S("Using DataSpec %s:\n"), ds.m_entry->m_name);
|
||||||
#endif
|
|
||||||
|
|
||||||
int lineIdx = 0;
|
int lineIdx = 0;
|
||||||
int prevIFactor = -1;
|
|
||||||
ds.m_instance->doExtract(m_einfo,
|
ds.m_instance->doExtract(m_einfo,
|
||||||
[&lineIdx, &prevIFactor](const HECL::SystemChar* message, int lidx, float factor)
|
[&lineIdx](const HECL::SystemChar* message, const HECL::SystemChar* submessage,
|
||||||
|
int lidx, float factor)
|
||||||
{
|
{
|
||||||
int iFactor = factor * 100.0;
|
int iFactor = factor * 100.0;
|
||||||
if (iFactor == prevIFactor)
|
|
||||||
return;
|
|
||||||
prevIFactor = iFactor;
|
|
||||||
#ifndef _WIN32
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" HIDE_CURSOR ""));
|
HECL::Printf(_S("" HIDE_CURSOR ""));
|
||||||
#endif
|
|
||||||
|
|
||||||
if (lidx > lineIdx)
|
if (lidx > lineIdx)
|
||||||
{
|
{
|
||||||
|
@ -230,16 +206,34 @@ public:
|
||||||
int half = width / 2 - 2;
|
int half = width / 2 - 2;
|
||||||
|
|
||||||
size_t messageLen = HECL::StrLen(message);
|
size_t messageLen = HECL::StrLen(message);
|
||||||
if (messageLen > half)
|
size_t submessageLen = HECL::StrLen(submessage);
|
||||||
HECL::Printf(_S("%.*s... "), half-3, message);
|
if (half - messageLen < submessageLen-2)
|
||||||
|
submessageLen = 0;
|
||||||
|
|
||||||
|
if (submessageLen)
|
||||||
|
{
|
||||||
|
if (messageLen > half-submessageLen-1)
|
||||||
|
HECL::Printf(_S("%.*s... "), half-submessageLen-4, message);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
HECL::Printf(_S("%s"), message);
|
||||||
|
for (int i=half-messageLen-submessageLen-1 ; i>=0 ; --i)
|
||||||
|
HECL::Printf(_S(" "));
|
||||||
|
HECL::Printf(_S("%s "), submessage);
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
HECL::Printf(_S("%s"), message);
|
if (messageLen > half)
|
||||||
for (int i=half-messageLen ; i>=0 ; --i)
|
HECL::Printf(_S("%.*s... "), half-3, message);
|
||||||
HECL::Printf(_S(" "));
|
else
|
||||||
|
{
|
||||||
|
HECL::Printf(_S("%s"), message);
|
||||||
|
for (int i=half-messageLen ; i>=0 ; --i)
|
||||||
|
HECL::Printf(_S(" "));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef _WIN32
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
{
|
{
|
||||||
size_t blocks = half - 7;
|
size_t blocks = half - 7;
|
||||||
|
@ -254,7 +248,6 @@ public:
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#endif
|
|
||||||
size_t blocks = half - 7;
|
size_t blocks = half - 7;
|
||||||
size_t filled = blocks * factor;
|
size_t filled = blocks * factor;
|
||||||
size_t rem = blocks - filled;
|
size_t rem = blocks - filled;
|
||||||
|
@ -264,15 +257,11 @@ public:
|
||||||
for (int b=0 ; b<rem ; ++b)
|
for (int b=0 ; b<rem ; ++b)
|
||||||
HECL::Printf(_S("-"), message);
|
HECL::Printf(_S("-"), message);
|
||||||
HECL::Printf(_S("]"));
|
HECL::Printf(_S("]"));
|
||||||
#ifndef _WIN32
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
HECL::Printf(_S("\r"));
|
HECL::Printf(_S("\r"));
|
||||||
#ifndef _WIN32
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" SHOW_CURSOR ""));
|
HECL::Printf(_S("" SHOW_CURSOR ""));
|
||||||
#endif
|
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
});
|
});
|
||||||
HECL::Printf(_S("\n\n"));
|
HECL::Printf(_S("\n\n"));
|
||||||
|
|
|
@ -95,15 +95,11 @@ public:
|
||||||
{
|
{
|
||||||
for (const HECL::Database::DataSpecEntry* spec : HECL::Database::DATA_SPEC_REGISTRY)
|
for (const HECL::Database::DataSpecEntry* spec : HECL::Database::DATA_SPEC_REGISTRY)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("%s\n %s\n"), spec->m_name, spec->m_desc);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" BOLD CYAN "%s" NORMAL "\n"), spec->m_name);
|
HECL::Printf(_S("" BOLD CYAN "%s" NORMAL "\n"), spec->m_name);
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("%s\n"), spec->m_name);
|
HECL::Printf(_S("%s\n"), spec->m_name);
|
||||||
HECL::Printf(_S(" %s\n"), spec->m_desc);
|
HECL::Printf(_S(" %s\n"), spec->m_desc);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -113,12 +109,6 @@ public:
|
||||||
{
|
{
|
||||||
for (auto& spec : specs)
|
for (auto& spec : specs)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("%s"), spec.spec.m_name);
|
|
||||||
if (spec.active)
|
|
||||||
HECL::Printf(_S(" [ENABLED]"));
|
|
||||||
HECL::Printf(_S("\n %s\n"), spec.spec.m_desc);
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" BOLD CYAN "%s" NORMAL ""), spec.spec.m_name);
|
HECL::Printf(_S("" BOLD CYAN "%s" NORMAL ""), spec.spec.m_name);
|
||||||
else
|
else
|
||||||
|
@ -131,7 +121,6 @@ public:
|
||||||
HECL::Printf(_S(" [ENABLED]"));
|
HECL::Printf(_S(" [ENABLED]"));
|
||||||
}
|
}
|
||||||
HECL::Printf(_S("\n %s\n"), spec.spec.m_desc);
|
HECL::Printf(_S("\n %s\n"), spec.spec.m_desc);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,14 +46,10 @@ bool XTERM_COLOR = false;
|
||||||
/* Main usage message */
|
/* Main usage message */
|
||||||
static void printHelp(const HECL::SystemChar* pname)
|
static void printHelp(const HECL::SystemChar* pname)
|
||||||
{
|
{
|
||||||
#if _WIN32
|
|
||||||
HECL::Printf(_S("HECL"));
|
|
||||||
#else
|
|
||||||
if (XTERM_COLOR)
|
if (XTERM_COLOR)
|
||||||
HECL::Printf(_S("" BOLD "HECL" NORMAL ""));
|
HECL::Printf(_S("" BOLD "HECL" NORMAL ""));
|
||||||
else
|
else
|
||||||
HECL::Printf(_S("HECL"));
|
HECL::Printf(_S("HECL"));
|
||||||
#endif
|
|
||||||
#if HECL_GIT
|
#if HECL_GIT
|
||||||
HECL::Printf(_S(" Commit " HECL_GIT_S " " HECL_BRANCH_S "\nUsage: %s init|add|remove|group|cook|clean|package|help\n"), pname);
|
HECL::Printf(_S(" Commit " HECL_GIT_S " " HECL_BRANCH_S "\nUsage: %s init|add|remove|group|cook|clean|package|help\n"), pname);
|
||||||
#elif HECL_VER
|
#elif HECL_VER
|
||||||
|
@ -75,6 +71,9 @@ static void SIGINTHandler(int sig)
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* SIGWINCH should do nothing */
|
||||||
|
static void SIGWINCHHandler(int sig) {}
|
||||||
|
|
||||||
static LogVisor::LogModule AthenaLog("Athena");
|
static LogVisor::LogModule AthenaLog("Athena");
|
||||||
static void AthenaExc(const Athena::error::Level& level, const char* file,
|
static void AthenaExc(const Athena::error::Level& level, const char* file,
|
||||||
const char*, int line, const char* fmt, ...)
|
const char*, int line, const char* fmt, ...)
|
||||||
|
@ -98,11 +97,18 @@ int main(int argc, const char** argv)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Xterm check */
|
/* Xterm check */
|
||||||
|
#if _WIN32
|
||||||
|
const char* conemuANSI = getenv("ConEmuANSI");
|
||||||
|
if (conemuANSI && !strcmp(conemuANSI, "ON"))
|
||||||
|
XTERM_COLOR = true;
|
||||||
|
#else
|
||||||
const char* term = getenv("TERM");
|
const char* term = getenv("TERM");
|
||||||
if (term && !strncmp(term, "xterm", 5))
|
if (term && !strncmp(term, "xterm", 5))
|
||||||
XTERM_COLOR = true;
|
XTERM_COLOR = true;
|
||||||
|
#endif
|
||||||
|
|
||||||
signal(SIGINT, SIGINTHandler);
|
signal(SIGINT, SIGINTHandler);
|
||||||
|
signal(SIGWINCH, SIGWINCHHandler);
|
||||||
|
|
||||||
LogVisor::RegisterConsoleLogger();
|
LogVisor::RegisterConsoleLogger();
|
||||||
atSetExceptionHandler(AthenaExc);
|
atSetExceptionHandler(AthenaExc);
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 7be764c387951cabfc86d52f48bd3dab54127aeb
|
Subproject commit d133a8cdd46eececcc6c1cb63248166e23791bce
|
|
@ -91,7 +91,7 @@ public:
|
||||||
std::vector<ExtractReport> childOpts;
|
std::vector<ExtractReport> childOpts;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::function<void(const HECL::SystemChar*, int, float)> FExtractProgress;
|
typedef std::function<void(const HECL::SystemChar*, const HECL::SystemChar*, int, float)> FExtractProgress;
|
||||||
|
|
||||||
virtual bool canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps)
|
virtual bool canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps)
|
||||||
{(void)info;LogModule.report(LogVisor::Error, "not implemented");return false;}
|
{(void)info;LogModule.report(LogVisor::Error, "not implemented");return false;}
|
||||||
|
|
Loading…
Reference in New Issue