X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fcliparser.cpp;h=598fc484cb8128b90872eccf5c2bdaf7bbdb21a3;hp=e3b8addde38d83cec27a44021a21719a761f19d2;hb=eedb5d1c659cdc4390915654b2a9f08ae51271fa;hpb=6564dcd249b38c3eeee9cc53b161ba338cfa7379 diff --git a/src/common/cliparser.cpp b/src/common/cliparser.cpp index e3b8addd..598fc484 100644 --- a/src/common/cliparser.cpp +++ b/src/common/cliparser.cpp @@ -19,16 +19,18 @@ ***************************************************************************/ #include "cliparser.h" +#include +#include #include #include -#include -CliParser::CliParser(QStringList arguments) -{ - argsRaw = arguments; +CliParser::CliParser() : AbstractCliParser() { + } -void CliParser::addArgument(const QString &longName, const CliParserArg &arg) { +void CliParser::addArgument(const QString &longName_, const CliParserArg &arg) { + QString longName = longName_; + longName.remove(QRegExp("\\s*<.*>\\s*")); // KCmdLineArgs takes args of the form "arg " if(argsHash.contains(longName)) qWarning() << "Warning: Multiple definition of argument" << longName; if(arg.shortName != 0 && !lnameOfShortArg(arg.shortName).isNull()) qWarning().nospace() << "Warning: Redefining shortName '" << arg.shortName << "' for " << longName << " previously defined for " << lnameOfShortArg(arg.shortName); @@ -38,7 +40,7 @@ void CliParser::addArgument(const QString &longName, const CliParserArg &arg) { bool CliParser::addLongArg(const CliParserArg::CliArgType type, const QString &name, const QString &value) { if(argsHash.contains(name)){ if(type == CliParserArg::CliArgOption && argsHash.value(name).type == type) { - argsHash[name].value = value; + argsHash[name].value = escapedValue(value); return true; } else if (type == CliParserArg::CliArgSwitch && argsHash.value(name).type == type) { @@ -54,7 +56,7 @@ bool CliParser::addShortArg(const CliParserArg::CliArgType type, const char shor QString longName = lnameOfShortArg(shortName); if(!longName.isNull()) { if(type == CliParserArg::CliArgOption && argsHash.value(longName).type == type) { - argsHash[longName].value = value; + argsHash[longName].value = escapedValue(value); return true; } else if (type == CliParserArg::CliArgSwitch) { @@ -73,7 +75,16 @@ bool CliParser::addShortArg(const CliParserArg::CliArgType type, const char shor return false; } -bool CliParser::parse() { +QString CliParser::escapedValue(const QString &value) { + QString escapedValue = value; + if(escapedValue.startsWith("~")) + escapedValue.replace(0, 1, QDir::homePath()); + + return escapedValue; +} + +bool CliParser::init(const QStringList &args) { + argsRaw = args; QStringList::const_iterator currentArg; for (currentArg = argsRaw.constBegin(); currentArg != argsRaw.constEnd(); ++currentArg) { if(currentArg->startsWith("--")) { @@ -138,7 +149,7 @@ bool CliParser::parse() { void CliParser::usage() { qWarning() << "Usage:" << QFileInfo(argsRaw.at(0)).completeBaseName() << "[arguments]"; - + // get size of longName field QStringList keys = argsHash.keys(); uint lnameFieldSize = 0; @@ -152,12 +163,12 @@ void CliParser::usage() { size += 8; if(size > lnameFieldSize) lnameFieldSize = size; } - + QHash::const_iterator arg; for(arg = argsHash.constBegin(); arg != argsHash.constEnd(); ++arg) { QString output; QString lnameField; - + if(arg.value().shortName) { output.append(" -").append(arg.value().shortName).append(","); } @@ -173,7 +184,7 @@ void CliParser::usage() { if(arg.value().type == CliParserArg::CliArgOption && !arg.value().def.isNull()) { output.append(". Default is: ").append(arg.value().def); } - qWarning(output.toLatin1()); + qWarning() << qPrintable(output); } }