mirror of https://github.com/mgba-emu/mgba.git
Qt: More flexible argv parsing
This commit is contained in:
parent
ce7e53d53d
commit
b10a5b7f02
|
@ -13,6 +13,11 @@
|
||||||
|
|
||||||
#include <mgba/feature/commandline.h>
|
#include <mgba/feature/commandline.h>
|
||||||
|
|
||||||
|
static const mOption s_frontendOptions[] = {
|
||||||
|
{ "ecard", true, '\0' },
|
||||||
|
{ 0 }
|
||||||
|
};
|
||||||
|
|
||||||
using namespace QGBA;
|
using namespace QGBA;
|
||||||
|
|
||||||
ConfigOption::ConfigOption(const QString& name, QObject* parent)
|
ConfigOption::ConfigOption(const QString& name, QObject* parent)
|
||||||
|
@ -129,24 +134,27 @@ ConfigController::ConfigController(QObject* parent)
|
||||||
mSubParserGraphicsInit(&m_subparsers[0], &m_graphicsOpts);
|
mSubParserGraphicsInit(&m_subparsers[0], &m_graphicsOpts);
|
||||||
|
|
||||||
m_subparsers[1].usage = "Frontend options:\n"
|
m_subparsers[1].usage = "Frontend options:\n"
|
||||||
" --ecard FILENAME Scan an e-Reader card in the first loaded game\n"
|
" --ecard FILE Scan an e-Reader card in the first loaded game\n"
|
||||||
" Can be paassed multiple times for multiple cards";
|
" Can be paassed multiple times for multiple cards\n"
|
||||||
m_subparsers[1].parse = nullptr;
|
m_subparsers[1].parse = nullptr;
|
||||||
m_subparsers[1].parseLong = [](struct mSubParser* parser, const char* option, const char* arg) {
|
m_subparsers[1].parseLong = [](struct mSubParser* parser, const char* option, const char* arg) {
|
||||||
if (option == QLatin1String("ecard")) {
|
ConfigController* self = static_cast<ConfigController*>(parser->opts);
|
||||||
QStringList* eCards = static_cast<QStringList*>(parser->opts);
|
QString optionName(QString::fromUtf8(option));
|
||||||
eCards->append(QString::fromUtf8(arg));
|
if (optionName == QLatin1String("ecard")) {
|
||||||
|
QStringList ecards;
|
||||||
|
if (self->m_argvOptions.contains(optionName)) {
|
||||||
|
ecards = self->m_argvOptions[optionName].toStringList();
|
||||||
|
}
|
||||||
|
ecards.append(QString::fromUtf8(arg));
|
||||||
|
self->m_argvOptions[optionName] = ecards;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
m_subparsers[1].apply = nullptr;
|
m_subparsers[1].apply = nullptr;
|
||||||
m_subparsers[1].extraOptions = nullptr;
|
m_subparsers[1].extraOptions = nullptr;
|
||||||
m_subparsers[1].longOptions = (const mOption[]) {
|
m_subparsers[1].longOptions = s_frontendOptions;
|
||||||
{ "ecard", true, '\0' },
|
m_subparsers[1].opts = this;
|
||||||
{ 0 }
|
|
||||||
};
|
|
||||||
m_subparsers[1].opts = &m_eCards;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ConfigController::~ConfigController() {
|
ConfigController::~ConfigController() {
|
||||||
|
@ -223,6 +231,14 @@ QVariant ConfigController::getQtOption(const QString& key, const QString& group)
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QVariant ConfigController::getArgvOption(const QString& key) const {
|
||||||
|
return m_argvOptions.value(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant ConfigController::takeArgvOption(const QString& key) {
|
||||||
|
return m_argvOptions.take(key);
|
||||||
|
}
|
||||||
|
|
||||||
void ConfigController::saveOverride(const Override& override) {
|
void ConfigController::saveOverride(const Override& override) {
|
||||||
override.save(overrides());
|
override.save(overrides());
|
||||||
write();
|
write();
|
||||||
|
@ -334,10 +350,6 @@ void ConfigController::usage(const char* arg0) const {
|
||||||
::usage(arg0, nullptr, nullptr, m_subparsers.data(), m_subparsers.size());
|
::usage(arg0, nullptr, nullptr, m_subparsers.data(), m_subparsers.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
QStringList ConfigController::takeECardList() {
|
|
||||||
return QStringList(std::move(m_eCards));
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ConfigController::isPortable() {
|
bool ConfigController::isPortable() {
|
||||||
return mCoreConfigIsPortable();
|
return mCoreConfigIsPortable();
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,6 +81,9 @@ public:
|
||||||
|
|
||||||
QVariant getQtOption(const QString& key, const QString& group = QString()) const;
|
QVariant getQtOption(const QString& key, const QString& group = QString()) const;
|
||||||
|
|
||||||
|
QVariant getArgvOption(const QString& key) const;
|
||||||
|
QVariant takeArgvOption(const QString& key);
|
||||||
|
|
||||||
QList<QString> getMRU() const;
|
QList<QString> getMRU() const;
|
||||||
void setMRU(const QList<QString>& mru);
|
void setMRU(const QList<QString>& mru);
|
||||||
|
|
||||||
|
@ -96,8 +99,6 @@ public:
|
||||||
const mGraphicsOpts* graphicsOpts() const { return &m_graphicsOpts; }
|
const mGraphicsOpts* graphicsOpts() const { return &m_graphicsOpts; }
|
||||||
void usage(const char* arg0) const;
|
void usage(const char* arg0) const;
|
||||||
|
|
||||||
QStringList takeECardList();
|
|
||||||
|
|
||||||
static const QString& configDir();
|
static const QString& configDir();
|
||||||
static bool isPortable();
|
static bool isPortable();
|
||||||
|
|
||||||
|
@ -113,6 +114,8 @@ public slots:
|
||||||
void write();
|
void write();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void addArgvOption(const QString& key, const QVariant& value);
|
||||||
|
|
||||||
Configuration* defaults() { return &m_config.defaultsTable; }
|
Configuration* defaults() { return &m_config.defaultsTable; }
|
||||||
|
|
||||||
mCoreConfig m_config;
|
mCoreConfig m_config;
|
||||||
|
@ -121,8 +124,8 @@ private:
|
||||||
mGraphicsOpts m_graphicsOpts{};
|
mGraphicsOpts m_graphicsOpts{};
|
||||||
std::array<mSubParser, 2> m_subparsers;
|
std::array<mSubParser, 2> m_subparsers;
|
||||||
bool m_parsed = false;
|
bool m_parsed = false;
|
||||||
QStringList m_eCards;
|
|
||||||
|
|
||||||
|
QHash<QString, QVariant> m_argvOptions;
|
||||||
QHash<QString, ConfigOption*> m_optionSet;
|
QHash<QString, ConfigOption*> m_optionSet;
|
||||||
std::unique_ptr<QSettings> m_settings;
|
std::unique_ptr<QSettings> m_settings;
|
||||||
static QString s_configDir;
|
static QString s_configDir;
|
||||||
|
|
|
@ -912,7 +912,7 @@ void CoreController::scanCard(const QString& path) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
QString filepath(QString::fromUtf8(line));
|
QString filepath(QString::fromUtf8(line));
|
||||||
if (filepath[0] == QChar('#')) {
|
if (filepath.isEmpty() || filepath[0] == QChar('#')) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (QFileInfo(filepath).isRelative()) {
|
if (QFileInfo(filepath).isRelative()) {
|
||||||
|
|
|
@ -931,7 +931,10 @@ void Window::gameStarted() {
|
||||||
|
|
||||||
#ifdef M_CORE_GBA
|
#ifdef M_CORE_GBA
|
||||||
if (m_controller->platform() == mPLATFORM_GBA) {
|
if (m_controller->platform() == mPLATFORM_GBA) {
|
||||||
m_controller->scanCards(m_config->takeECardList());
|
QVariant eCardList = m_config->takeArgvOption(QString("ecard"));
|
||||||
|
if (eCardList.canConvert(QMetaType::QStringList)) {
|
||||||
|
m_controller->scanCards(eCardList.toStringList());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue