/* * Copyright (C) 2018-2019 QuasarApp. * Distributed under the lgplv3 software license, see the accompanying * Everyone is permitted to copy and distribute verbatim copies * of this license document, but changing it is not allowed. */ #include "params.h" #include #include #include #include #ifdef Q_OS_WIN #include "windows.h" #else #include #include #endif using namespace QuasarAppUtils; static QVariantMap params = QVariantMap(); bool Params::isEndable(const QString& key) { return params.contains(key); } void Params::verboseLog(const QString &log, VerboseLvl vLvl) { if (!writeLoginFile(log, vLvl)) { qWarning() << "Warning: Write log in file fail!"; } if (isEndable("verbose")) { auto lvl = static_cast(getArg("verbose").toInt()); if (vLvl <= lvl) { switch (vLvl) { case VerboseLvl::Error: { qCritical() << lvlToString(vLvl) + ": " + log; break; } case VerboseLvl::Warning: { qWarning() << lvlToString(vLvl) + ": " + log; break; } case VerboseLvl::Info: { qInfo() << lvlToString(vLvl) + ": " + log; break; } default: { qDebug() << lvlToString(vLvl) + ": " + log; break; } } } } } QStringList Params::getparamsHelp() { return { {""}, { " -verbose (level 1 - 3) : Shows debug log"}, { " -fileLog (path to file) : Sets path of log file"}, { " : Default it is path to executable file"}, { " : with suffix '.log' "}, { " noWriteInFileLog : Disables loging into file"}, { ""} }; } void Params::showHelp(const QStringList &help) { for (const QString& line : help) { std::cout << line.toStdString() << std::endl; } } QString Params::lvlToString(VerboseLvl vLvl) { switch (vLvl) { case VerboseLvl::Error: { return "Error"; } case VerboseLvl::Warning: { return "Warning"; } case VerboseLvl::Info: { return "Info"; } case VerboseLvl::Debug: { return "Verbose log"; } } return ""; } bool Params::writeLoginFile(const QString &log, VerboseLvl vLvl) { if (!isEndable("noWriteInFileLog")) { QString path = getStrArg("appPath") + "/" + getStrArg("appName") + ".log"; if (isEndable("fileLog")) { QString path = getStrArg("fileLog"); } QFile logFile(path); if (logFile.open(QIODevice::WriteOnly | QIODevice::Append)) { QTextStream stream(&logFile); stream << lvlToString(vLvl) + ": " + log; logFile.close(); } else { return false; } } return true; } bool Params::parseParams(int argc,const char *argv[]) { params.clear(); #ifdef Q_OS_WIN char buffer[MAX_PATH]; GetModuleFileNameA(nullptr, buffer, MAX_PATH); params ["appPath"] = QFileInfo(buffer).absolutePath(); params ["appName"] = QFileInfo(buffer).fileName(); #else char path[2048]; if (readlink("/proc/self/exe", path, 2048) < 0) { qWarning() << "parseParams can't get self path!" ; return false; } params ["appPath"] = QFileInfo(path).absolutePath(); params ["appName"] = QFileInfo(path).fileName(); #endif if (!getStrArg("appPath").size()) { return false; } for (int i = 1; i < argc; i++) { if (argv[i][0] == '-' && i ) { if (i < (argc - 1) && argv[i + 1][0] != '-') { params[&(argv[i][1])] = argv[i + 1]; i++; } else { qWarning() << "Missing argument for " + QString(argv[i]) ; } } else { params[argv[i]] = ""; } } return true; } QString Params::getStrArg(const QString& key) { return params.value(key, "").toString(); } QVariant Params::getArg(const QString& key) { return params.value(key, ""); } void Params::setArg(const QString &key, const QVariant &val) { params.insert(key, val); } void Params::setEnable(const QString &key, bool enable) { if (enable) { params.insert(key, ""); } else { params.remove(key); } }