Compare commits
4 Commits
wip/termin
...
883b71e8a8
Author | SHA1 | Date | |
---|---|---|---|
883b71e8a8 | |||
ac5498990b | |||
38cc87fbcd | |||
2d14b01c5c |
@ -13,6 +13,11 @@ EntryProvider::EntryProvider(QStringList userEntriesDirsPaths, QStringList syste
|
|||||||
<< "%u";
|
<< "%u";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool EntryProvider::isSavable(const EntryConfig &config) const
|
||||||
|
{
|
||||||
|
return ! config.entryPath.isEmpty() && (config.type == EntryType::USER || config.type == EntryType::INHERIT);
|
||||||
|
}
|
||||||
|
|
||||||
EntryConfig EntryProvider::readFromDesktopFile(const QString &path)
|
EntryConfig EntryProvider::readFromDesktopFile(const QString &path)
|
||||||
{
|
{
|
||||||
EntryConfig result;
|
EntryConfig result;
|
||||||
@ -223,6 +228,7 @@ EntryConfig EntryProvider::readqsrunFile(const QString &path)
|
|||||||
}
|
}
|
||||||
result.col = map["col"].toInt();
|
result.col = map["col"].toInt();
|
||||||
result.row = map["row"].toInt();
|
result.row = map["row"].toInt();
|
||||||
|
result.isTerminalCommand = map["terminal"] == "true";
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,7 +290,7 @@ QVector<EntryConfig> EntryProvider::getSystemEntries()
|
|||||||
|
|
||||||
void EntryProvider::saveUserEntry(const EntryConfig &config)
|
void EntryProvider::saveUserEntry(const EntryConfig &config)
|
||||||
{
|
{
|
||||||
if(config.type == EntryType::SYSTEM || config.entryPath.isEmpty())
|
if(!isSavable(config))
|
||||||
{
|
{
|
||||||
throw std::runtime_error("Only user/inherited entries can be saved");
|
throw std::runtime_error("Only user/inherited entries can be saved");
|
||||||
}
|
}
|
||||||
@ -338,7 +344,7 @@ void EntryProvider::saveUserEntry(const EntryConfig &config)
|
|||||||
|
|
||||||
bool EntryProvider::deleteUserEntry(const EntryConfig &config)
|
bool EntryProvider::deleteUserEntry(const EntryConfig &config)
|
||||||
{
|
{
|
||||||
if(config.type == EntryType::SYSTEM || config.entryPath.isEmpty())
|
if(!isSavable(config))
|
||||||
{
|
{
|
||||||
throw std::runtime_error("Only user/inherited entries can be deleted");
|
throw std::runtime_error("Only user/inherited entries can be deleted");
|
||||||
}
|
}
|
||||||
|
@ -55,6 +55,7 @@ class EntryProvider
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
EntryProvider(QStringList userEntriesDirsPaths, QStringList systemEntriesDirsPaths);
|
EntryProvider(QStringList userEntriesDirsPaths, QStringList systemEntriesDirsPaths);
|
||||||
|
bool isSavable(const EntryConfig &config) const;
|
||||||
QVector<EntryConfig> getUserEntries();
|
QVector<EntryConfig> getUserEntries();
|
||||||
QVector<EntryConfig> getSystemEntries();
|
QVector<EntryConfig> getSystemEntries();
|
||||||
void saveUserEntry(const EntryConfig &config);
|
void saveUserEntry(const EntryConfig &config);
|
||||||
|
@ -23,7 +23,15 @@ EntryPushButton::EntryPushButton(const EntryConfig &config) : QPushButton()
|
|||||||
{
|
{
|
||||||
this->setText(config.name);
|
this->setText(config.name);
|
||||||
this->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
this->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
||||||
QIcon icon = resolveIcon(config.iconPath);
|
QIcon icon;
|
||||||
|
if(config.isTerminalCommand && config.iconPath.isEmpty())
|
||||||
|
{
|
||||||
|
icon = resolveIcon("utilities-terminal");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
icon = resolveIcon(config.iconPath);
|
||||||
|
}
|
||||||
this->setIcon(icon);
|
this->setIcon(icon);
|
||||||
if(!icon.availableSizes().isEmpty())
|
if(!icon.availableSizes().isEmpty())
|
||||||
{
|
{
|
||||||
|
18
main.cpp
18
main.cpp
@ -14,6 +14,7 @@
|
|||||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
*/
|
*/
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
|
#include <QCommandLineParser>
|
||||||
#include <QFuture>
|
#include <QFuture>
|
||||||
#include <QFutureWatcher>
|
#include <QFutureWatcher>
|
||||||
#include <QtConcurrent/QtConcurrentRun>
|
#include <QtConcurrent/QtConcurrentRun>
|
||||||
@ -32,7 +33,15 @@ int main(int argc, char *argv[])
|
|||||||
QDir dir;
|
QDir dir;
|
||||||
if(argc >= 2)
|
if(argc >= 2)
|
||||||
{
|
{
|
||||||
configDirectoryPath = QCoreApplication::arguments().at(1);
|
QCommandLineParser parser;
|
||||||
|
parser.addOptions({
|
||||||
|
{"new-instance", "Launch a new instance, ignoring any running ones"},
|
||||||
|
{"kill-instances", "Kill all running instances"},
|
||||||
|
{"config", "Use supplied config dir instead of default"},
|
||||||
|
});
|
||||||
|
parser.addHelpOption();
|
||||||
|
parser.process(app.arguments());
|
||||||
|
configDirectoryPath = parser.value("config");
|
||||||
if(!dir.exists(configDirectoryPath))
|
if(!dir.exists(configDirectoryPath))
|
||||||
{
|
{
|
||||||
QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found");
|
QMessageBox::warning(nullptr, "Directory not found", configDirectoryPath + " was not found");
|
||||||
@ -45,12 +54,12 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
qRegisterMetaType<QVector<QString>>("QVector<QString>");
|
qRegisterMetaType<QVector<QString>>("QVector<QString>");
|
||||||
|
|
||||||
|
|
||||||
if(!dir.exists(configDirectoryPath))
|
if(!dir.exists(configDirectoryPath))
|
||||||
{
|
{
|
||||||
if(!dir.mkdir(configDirectoryPath))
|
if(!dir.mkdir(configDirectoryPath))
|
||||||
{
|
{
|
||||||
QMessageBox::warning(nullptr, "Failed to create dir", configDirectoryPath + " was not found and could not be created!");
|
QMessageBox::warning(nullptr, "Failed to create dir",
|
||||||
|
configDirectoryPath + " was not found and could not be created!");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -91,10 +100,7 @@ int main(int argc, char *argv[])
|
|||||||
});
|
});
|
||||||
w->showMaximized();
|
w->showMaximized();
|
||||||
w->focusInput();
|
w->focusInput();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return app.exec();
|
return app.exec();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user