Add cli parameter to disable file logging completely

This commit is contained in:
phl0 2017-07-18 15:31:23 +02:00
parent 035df6b2e0
commit 077df35a4d
3 changed files with 28 additions and 11 deletions

4
.gitignore vendored
View file

@ -1,7 +1,6 @@
Debug
Release
x64
MMDVMHost
*.o
*.opendb
*.bak
@ -14,3 +13,6 @@ MMDVMHost
*.user
*.VC.db
.vs
YSFGateway/YSFGateway
YSFParrot/YSFParrot
YSFReflector/YSFReflector

View file

@ -32,16 +32,22 @@
int main(int argc, char** argv)
{
if (argc == 1) {
::fprintf(stderr, "Usage: YSFParrot [-d|--debug] <port>\n");
::fprintf(stderr, "Usage: YSFParrot [-d|--debug] [-n|--nolog] <port>\n");
return 1;
}
unsigned int n = 1U;
int n = 1U;
bool debug = false;
if (::strcmp(argv[1], "-d") == 0 || ::strcmp(argv[1], "--debug") == 0) {
debug = true;
n = 2U;
bool log = true;
for (; n < argc-1; n++) {
if (::strcmp(argv[n], "-d") == 0 || ::strcmp(argv[n], "--debug") == 0) {
debug = true;
}
if (::strcmp(argv[n], "-n") == 0 || ::strcmp(argv[n], "--nolog") == 0) {
log = false;
}
}
unsigned int port = ::atoi(argv[n]);
@ -50,15 +56,16 @@ int main(int argc, char** argv)
return 1;
}
CYSFParrot parrot(port, debug);
CYSFParrot parrot(port, debug, log);
parrot.run();
return 0;
}
CYSFParrot::CYSFParrot(unsigned int port, bool debug) :
CYSFParrot::CYSFParrot(unsigned int port, bool debug, bool log) :
m_port(port),
m_debug(debug)
m_debug(debug),
m_log(log)
{
}
@ -68,12 +75,19 @@ CYSFParrot::~CYSFParrot()
void CYSFParrot::run()
{
bool ret = ::LogInitialise(".", "YSFParrot", m_debug ? 1U : 2U, m_debug ? 1U : 2U);
int fileLevel = 0U;
if (m_log) {
fileLevel = m_debug ? 1U : 2U;
}
bool ret = ::LogInitialise(".", "YSFParrot", fileLevel, m_debug ? 1U : 2U);
if (!ret) {
::fprintf(stderr, "YSFParrot: unable to open the log file\n");
return;
}
LogInfo("Debug: %s", m_debug ? "Enabled" : "Disabled");
LogInfo("Logging to file: %s", m_log ? "Enabled" : "Disabled");
CParrot parrot(180U);
CNetwork network(m_port);

View file

@ -22,7 +22,7 @@
class CYSFParrot
{
public:
CYSFParrot(unsigned int port, bool debug);
CYSFParrot(unsigned int port, bool debug, bool log);
~CYSFParrot();
void run();
@ -30,6 +30,7 @@ public:
private:
unsigned int m_port;
bool m_debug;
bool m_log;
};
#endif