First draft of an argument parser.

Possibility to set custom config path.
This commit is contained in:
Florian Geyer 2013-03-29 20:35:54 +01:00
parent bee570c3cf
commit 2558e6db79
9 changed files with 219 additions and 16 deletions

View File

@ -27,6 +27,7 @@ set(keepassx_SOURCES
autotype/WildcardMatcher.cpp autotype/WildcardMatcher.cpp
autotype/WindowSelectComboBox.cpp autotype/WindowSelectComboBox.cpp
autotype/test/AutoTypeTestInterface.h autotype/test/AutoTypeTestInterface.h
core/ArgumentParser.cpp
core/AutoTypeAssociations.cpp core/AutoTypeAssociations.cpp
core/Config.cpp core/Config.cpp
core/Database.cpp core/Database.cpp

View File

@ -0,0 +1,51 @@
/*
* Copyright (C) 2013 Florian Geyer <blueice@fobos.de>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 or (at your option)
* version 3 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "ArgumentParser.h"
QHash<QString, QString> ArgumentParser::parseArguments(const QStringList& args)
{
QStringList argumentKeys = QStringList() << "password" << "config" << "filename";
QHash<QString, QString> argumentMap;
// TODO: needs refactoring, too much nesting
for (int i = 1; i < args.size(); i++) {
if (args[i].startsWith("--")) {
if (args.size() > (i + 1)) {
QString argument(args[i].mid(2));
if (argumentKeys.contains(argument)) {
argumentMap.insert(argument, args[i + 1]);
}
else {
qWarning("Unknown option \"%s\" with value \"%s\"", qPrintable(args[i]), qPrintable(args[i+1]));
}
i++;
} else {
qWarning("No value given for option \"%s\"", qPrintable(args[i]));
}
}
else if (!args[i].startsWith("-")) {
argumentMap.insert("filename", args[i]);
}
else {
qWarning("Unknown argument \"%s\"", qPrintable(args[i]));
}
}
return argumentMap;
}

34
src/core/ArgumentParser.h Normal file
View File

@ -0,0 +1,34 @@
/*
* Copyright (C) 2013 Florian Geyer <blueice@fobos.de>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 or (at your option)
* version 3 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef KEEPASSX_ARGUMENT_PARSER_H
#define KEEPASSX_ARGUMENT_PARSER_H
#include "core/Global.h"
#include <QtCore/QHash>
#include <QtCore/QStringList>
class ArgumentParser
{
public:
static QHash<QString, QString> parseArguments(const QStringList& args);
};
#endif // KEEPASSX_ARGUMENT_PARSER_H

View File

@ -105,6 +105,12 @@ Config* Config::instance()
return m_instance; return m_instance;
} }
void Config::createConfigFromFile(QString file)
{
Q_ASSERT(!m_instance);
m_instance = new Config(file, qApp);
}
void Config::createTempFileInstance() void Config::createTempFileInstance()
{ {
Q_ASSERT(!m_instance); Q_ASSERT(!m_instance);

View File

@ -36,6 +36,7 @@ public:
void set(const QString& key, const QVariant& value); void set(const QString& key, const QVariant& value);
static Config* instance(); static Config* instance();
static void createConfigFromFile(QString file);
static void createTempFileInstance(); static void createTempFileInstance();
private: private:

View File

@ -17,6 +17,8 @@
#include <QtCore/QFile> #include <QtCore/QFile>
#include "core/ArgumentParser.h"
#include "core/Config.h"
#include "core/Tools.h" #include "core/Tools.h"
#include "crypto/Crypto.h" #include "crypto/Crypto.h"
#include "gui/Application.h" #include "gui/Application.h"
@ -34,21 +36,11 @@ int main(int argc, char** argv)
Crypto::init(); Crypto::init();
QString filename;
QString password;
const QStringList args = app.arguments(); const QStringList args = app.arguments();
for (int i = 1; i < args.size(); i++) { QHash<QString, QString> argumentMap = ArgumentParser::parseArguments(args);
if (args[i] == "--password" && args.size() > (i + 1)) {
password = args[i + 1]; if (!argumentMap.value("config").isEmpty()) {
i++; Config::createConfigFromFile(argumentMap.value("config"));
}
else if (!args[i].startsWith("-") && QFile::exists(args[i])) {
filename = args[i];
}
else {
qWarning("Unknown argument \"%s\"", qPrintable(args[i]));
}
} }
MainWindow mainWindow; MainWindow mainWindow;
@ -56,8 +48,9 @@ int main(int argc, char** argv)
QObject::connect(&app, SIGNAL(openFile(QString)), &mainWindow, SLOT(openDatabase(QString))); QObject::connect(&app, SIGNAL(openFile(QString)), &mainWindow, SLOT(openDatabase(QString)));
if (!filename.isEmpty()) { QString filename(argumentMap.value("filename"));
mainWindow.openDatabase(filename, password, QString()); if (!filename.isEmpty() && QFile::exists(filename)) {
mainWindow.openDatabase(filename, argumentMap.value("password"), QString());
} }
return app.exec(); return app.exec();

View File

@ -159,6 +159,9 @@ set_target_properties(testautotype PROPERTIES ENABLE_EXPORTS ON)
add_unit_test(NAME testentry SOURCES TestEntry.cpp MOCS TestEntry.h add_unit_test(NAME testentry SOURCES TestEntry.cpp MOCS TestEntry.h
LIBS ${TEST_LIBRARIES}) LIBS ${TEST_LIBRARIES})
add_unit_test(NAME testargumentparser SOURCES TestArgumentParser.cpp MOCS TestArgumentParser.h
LIBS ${TEST_LIBRARIES})
if(WITH_GUI_TESTS) if(WITH_GUI_TESTS)
add_subdirectory(gui) add_subdirectory(gui)
endif(WITH_GUI_TESTS) endif(WITH_GUI_TESTS)

View File

@ -0,0 +1,72 @@
/*
* Copyright (C) 2013 Felix Geyer <debfx@fobos.de>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 or (at your option)
* version 3 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "TestArgumentParser.h"
#include <QtTest/QTest>
#include "tests.h"
#include "core/ArgumentParser.h"
// TODO: test qWarning with own message handler?
void TestArgumentParser::testNoArguments()
{
parse(QStringList());
QVERIFY(argumentMap.isEmpty());
}
void TestArgumentParser::testUnknownArgument()
{
parse(QStringList() << "--foo" << "bar");
QVERIFY(argumentMap.isEmpty());
}
void TestArgumentParser::testFilename()
{
parse(QStringList() << "--filename" << "foo");
QCOMPARE(argumentMap.size(), 1);
QCOMPARE(argumentMap.value("filename"), QString("foo"));
}
void TestArgumentParser::testMultipleArguments()
{
parse(QStringList() << "--config" << "myconfig.ini" << "--filename" << "myfilename" << "--password" << "mypassword");
QCOMPARE(argumentMap.size(), 3);
QCOMPARE(argumentMap.value("config"), QString("myconfig.ini"));
QCOMPARE(argumentMap.value("filename"), QString("myfilename"));
QCOMPARE(argumentMap.value("password"), QString("mypassword"));
}
void TestArgumentParser::testFilenameWithoutOption()
{
parse(QStringList() << "foo");
QCOMPARE(argumentMap.size(), 1);
QCOMPARE(argumentMap.value("filename"), QString("foo"));
}
void TestArgumentParser::parse(const QStringList& arguments)
{
argumentMap = ArgumentParser::parseArguments(QStringList() << "keepassx" << arguments);
}
QTEST_GUILESS_MAIN(TestArgumentParser)

View File

@ -0,0 +1,42 @@
/*
* Copyright (C) 2013 Felix Geyer <debfx@fobos.de>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 or (at your option)
* version 3 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef KEEPASSX_TEST_ARGUMENT_PARSER_H
#define KEEPASSX_TEST_ARGUMENT_PARSER_H
#include <QtCore/QObject>
#include <QtCore/QHash>
class TestArgumentParser : public QObject
{
Q_OBJECT
private Q_SLOTS:
void testNoArguments();
void testUnknownArgument();
void testFilename();
void testMultipleArguments();
void testFilenameWithoutOption();
private:
void parse(const QStringList& arguments);
QHash<QString, QString> argumentMap;
};
#endif // KEEPASSX_TEST_ARGUMENT_PARSER_H