From ff693807afb57c857b7c9e1f0caff3bdba92cc0a Mon Sep 17 00:00:00 2001 From: novist Date: Wed, 17 Dec 2014 15:44:23 +0200 Subject: [PATCH] Autorun on OS startup --- qtox.pro | 5 ++ src/misc/settings.cpp | 19 +++++ src/misc/settings.h | 3 + src/platform/autorun.h | 31 ++++++++ src/platform/autorun_osx.cpp | 31 ++++++++ src/platform/autorun_win.cpp | 82 +++++++++++++++++++++ src/platform/autorun_xdg.cpp | 69 +++++++++++++++++ src/widget/form/settings/generalform.cpp | 10 +++ src/widget/form/settings/generalform.h | 1 + src/widget/form/settings/generalsettings.ui | 60 +++++++++------ src/widget/form/settings/identityform.cpp | 4 + 11 files changed, 292 insertions(+), 23 deletions(-) create mode 100644 src/platform/autorun.h create mode 100644 src/platform/autorun_osx.cpp create mode 100644 src/platform/autorun_win.cpp create mode 100644 src/platform/autorun_xdg.cpp diff --git a/qtox.pro b/qtox.pro index 7de0f7811..f67f2c619 100644 --- a/qtox.pro +++ b/qtox.pro @@ -287,4 +287,9 @@ contains(DEFINES, QTOX_PLATFORM_EXT) { SOURCES += src/platform/timer_osx.cpp \ src/platform/timer_win.cpp \ src/platform/timer_x11.cpp + + HEADERS += src/platform/autorun.h + SOURCES += src/platform/autorun_win.cpp \ + src/platform/autorun_xdg.cpp \ + src/platform/autorun_osx.cpp } diff --git a/src/misc/settings.cpp b/src/misc/settings.cpp index 196202865..211ee5f40 100644 --- a/src/misc/settings.cpp +++ b/src/misc/settings.cpp @@ -18,6 +18,9 @@ #include "smileypack.h" #include "src/corestructs.h" #include "src/misc/db/plaindb.h" +#ifdef QTOX_PLATFORM_EXT +#include "src/platform/autorun.h" +#endif #include #include @@ -479,6 +482,22 @@ void Settings::setMakeToxPortable(bool newValue) save(); } +bool Settings::getAutorun() const +{ +#ifdef QTOX_PLATFORM_EXT + return Platform::getAutorun(); +#else + return false; +#endif +} + +void Settings::setAutorun(bool newValue) +{ +#ifdef QTOX_PLATFORM_EXT + Platform::setAutorun(newValue); +#endif +} + bool Settings::getAutostartInTray() const { return autostartInTray; diff --git a/src/misc/settings.h b/src/misc/settings.h index 391fe1c58..d267a0ffe 100644 --- a/src/misc/settings.h +++ b/src/misc/settings.h @@ -56,6 +56,9 @@ public: bool getMakeToxPortable() const; void setMakeToxPortable(bool newValue); + bool getAutorun() const; + void setAutorun(bool newValue); + bool getAutostartInTray() const; void setAutostartInTray(bool newValue); diff --git a/src/platform/autorun.h b/src/platform/autorun.h new file mode 100644 index 000000000..6bdfbf22f --- /dev/null +++ b/src/platform/autorun.h @@ -0,0 +1,31 @@ +/* + Copyright (C) 2014 by Project Tox + + This file is part of qTox, a Qt-based graphical interface for Tox. + + This program is libre 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 3 of the License, or + (at your option) any later version. + 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 COPYING file for more details. +*/ + +#ifdef QTOX_PLATFORM_EXT + +#ifndef PLATFORM_AUTORUN_H +#define PLATFORM_AUTORUN_H + + +namespace Platform +{ + bool setAutorun(bool on); + bool getAutorun(); +} + +#endif // PLATFORM_AUTORUN_H + +#endif // QTOX_PLATFORM_EXT diff --git a/src/platform/autorun_osx.cpp b/src/platform/autorun_osx.cpp new file mode 100644 index 000000000..5578556dc --- /dev/null +++ b/src/platform/autorun_osx.cpp @@ -0,0 +1,31 @@ +/* + Copyright (C) 2014 by Project Tox + + This file is part of qTox, a Qt-based graphical interface for Tox. + + This program is libre 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 3 of the License, or + (at your option) any later version. + 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 COPYING file for more details. +*/ + +#if defined(__APPLE__) && defined(__MACH__) +#include "src/platform/autorun.h" + + +bool Platform::setAutorun(bool on) +{ + return false; +} + +bool Platform::getAutorun() +{ + return false; +} + +#endif // defined(__APPLE__) && defined(__MACH__) diff --git a/src/platform/autorun_win.cpp b/src/platform/autorun_win.cpp new file mode 100644 index 000000000..f0d46f597 --- /dev/null +++ b/src/platform/autorun_win.cpp @@ -0,0 +1,82 @@ +/* + Copyright (C) 2014 by Project Tox + + This file is part of qTox, a Qt-based graphical interface for Tox. + + This program is libre 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 3 of the License, or + (at your option) any later version. + 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 COPYING file for more details. +*/ + +#include +#ifdef Q_OS_WIN32 +#include "src/platform/autorun.h" +#include "src/misc/settings.h" +#include +#include + +namespace Platform +{ + inline std::wstring currentCommandLine() + { + return ("\"" + QApplication::applicationFilePath().replace('/', '\\') + "\" -P \"" + + Settings::getInstance().getCurrentProfile() + "\"").toStdWString(); + } + + inline std::wstring currentRegistryKeyName() + { + return (QString("qTox - ") + Settings::getInstance().getCurrentProfile()).toStdWString(); + } +} + +bool Platform::setAutorun(bool on) +{ + HKEY key = 0; + if (RegOpenKeyEx(HKEY_CURRENT_USER, L"Software\\Microsoft\\Windows\\CurrentVersion\\Run", + 0, KEY_ALL_ACCESS, &key) != ERROR_SUCCESS) + return false; + + bool result = false; + std::wstring keyName = currentRegistryKeyName(); + + if (on) + { + std::wstring path = currentCommandLine(); + result = RegSetValueEx(key, keyName.c_str(), 0, REG_SZ, (PBYTE)path.c_str(), + path.length() * sizeof(wchar_t)) == ERROR_SUCCESS; + } + else + result = RegDeleteValue(key, keyName.c_str()) == ERROR_SUCCESS; + + RegCloseKey(key); + return result; +} + +bool Platform::getAutorun() +{ + HKEY key = 0; + if (RegOpenKeyEx(HKEY_CURRENT_USER, L"Software\\Microsoft\\Windows\\CurrentVersion\\Run", + 0, KEY_ALL_ACCESS, &key) != ERROR_SUCCESS) + return false; + + std::wstring keyName = currentRegistryKeyName();; + + wchar_t path[MAX_PATH] = { 0 }; + DWORD length = sizeof(path); + DWORD type = REG_SZ; + bool result = false; + + if (RegQueryValueEx(key, keyName.c_str(), 0, &type, (PBYTE)path, &length) == ERROR_SUCCESS && type == REG_SZ) + result = true; + + RegCloseKey(key); + return result; +} + +#endif // Q_OS_WIN32 diff --git a/src/platform/autorun_xdg.cpp b/src/platform/autorun_xdg.cpp new file mode 100644 index 000000000..99d83e5e0 --- /dev/null +++ b/src/platform/autorun_xdg.cpp @@ -0,0 +1,69 @@ +/* + Copyright (C) 2014 by Project Tox + + This file is part of qTox, a Qt-based graphical interface for Tox. + + This program is libre 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 3 of the License, or + (at your option) any later version. + 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 COPYING file for more details. +*/ + +#include +#if defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) +#include "src/platform/autorun.h" +#include "src/misc/settings.h" +#include +#include + +namespace Platform +{ + QString getAutostartFilePath() + { + QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); + QString config = env.value("XDG_CONFIG_HOME"); + if (config.isEmpty()) + config = QDir::homePath() + "/" + ".config"; + return config + "/" + "autostart/qTox - " + + Settings::getInstance().getCurrentProfile() + ".desktop"; + } + + inline QString currentCommandLine() + { + return "\"" + QApplication::applicationFilePath() + "\" -P \"" + + Settings::getInstance().getCurrentProfile() + "\""; + } +} + +bool Platform::setAutorun(bool on) +{ + + QFile desktop(getAutostartFilePath()); + if (on) + { + if (!desktop.open(QFile::WriteOnly | QFile::Truncate)) + return false; + desktop.write("[Desktop Entry]\n"); + desktop.write("Type=Application\n"); + desktop.write("Name=qTox\n"); + desktop.write("Exec="); + desktop.write(currentCommandLine().toUtf8()); + desktop.write("\n"); + desktop.close(); + return true; + } + else + return desktop.remove(); +} + +bool Platform::getAutorun() +{ + return QFile(getAutostartFilePath()).exists(); +} + +#endif // defined(Q_OS_UNIX) && !defined(__APPLE__) && !defined(__MACH__) diff --git a/src/widget/form/settings/generalform.cpp b/src/widget/form/settings/generalform.cpp index 333d9a561..865627062 100644 --- a/src/widget/form/settings/generalform.cpp +++ b/src/widget/form/settings/generalform.cpp @@ -50,6 +50,10 @@ GeneralForm::GeneralForm(SettingsWidget *myParent) : for (int i = 0; i < langs.size(); i++) bodyUI->transComboBox->insertItem(i, langs[i]); bodyUI->transComboBox->setCurrentIndex(locales.indexOf(Settings::getInstance().getTranslation())); + bodyUI->cbAutorun->setChecked(Settings::getInstance().getAutorun()); +#if defined(__APPLE__) && defined(__MACH__) + bodyUI->cbAutorun->setEnabled(False); +#endif bool showSystemTray = Settings::getInstance().getShowSystemTray(); @@ -118,6 +122,7 @@ GeneralForm::GeneralForm(SettingsWidget *myParent) : //general connect(bodyUI->checkUpdates, &QCheckBox::stateChanged, this, &GeneralForm::onCheckUpdateChanged); connect(bodyUI->transComboBox, SIGNAL(currentIndexChanged(int)), this, SLOT(onTranslationUpdated())); + connect(bodyUI->cbAutorun, &QCheckBox::stateChanged, this, &GeneralForm::onAutorunUpdated); connect(bodyUI->showSystemTray, &QCheckBox::stateChanged, this, &GeneralForm::onSetShowSystemTray); connect(bodyUI->startInTray, &QCheckBox::stateChanged, this, &GeneralForm::onSetAutostartInTray); connect(bodyUI->closeToTray, &QCheckBox::stateChanged, this, &GeneralForm::onSetCloseToTray); @@ -170,6 +175,11 @@ void GeneralForm::onTranslationUpdated() Widget::getInstance()->setTranslation(); } +void GeneralForm::onAutorunUpdated() +{ + Settings::getInstance().setAutorun(bodyUI->cbAutorun->isChecked()); +} + void GeneralForm::onSetShowSystemTray() { Settings::getInstance().setShowSystemTray(bodyUI->showSystemTray->isChecked()); diff --git a/src/widget/form/settings/generalform.h b/src/widget/form/settings/generalform.h index d21f5fd52..b383cbcfb 100644 --- a/src/widget/form/settings/generalform.h +++ b/src/widget/form/settings/generalform.h @@ -33,6 +33,7 @@ public: private slots: void onEnableIPv6Updated(); void onTranslationUpdated(); + void onAutorunUpdated(); void onSetShowSystemTray(); void onSetAutostartInTray(); void onSetCloseToTray(); diff --git a/src/widget/form/settings/generalsettings.ui b/src/widget/form/settings/generalsettings.ui index c67f7b0be..9b0c85cf4 100644 --- a/src/widget/form/settings/generalsettings.ui +++ b/src/widget/form/settings/generalsettings.ui @@ -114,12 +114,12 @@ - - Light icon - Enable light tray icon. + + Light icon + @@ -130,12 +130,12 @@ 0 - - Start in tray - qTox will start minimized in tray. + + Start in tray + @@ -146,13 +146,13 @@ 0 - - Close to tray - After pressing close (X) qTox will minimize to tray, instead of closing itself. + + Close to tray + @@ -163,13 +163,13 @@ instead of closing itself. 0 - - Minimize to tray - After pressing minimize (_) qTox will minimize itself to tray, instead of system taskbar. + + Minimize to tray + @@ -189,11 +189,25 @@ instead of system taskbar. - - - Check for updates on startup - - + + + + + <html><head/><body><p>Start qTox on operating system startup (current profile).</p></body></html> + + + Start automatically + + + + + + + Check for updates on startup + + + + @@ -202,12 +216,12 @@ instead of system taskbar. - - Save to: - Set where files will be saved. + + Save to: + @@ -228,12 +242,12 @@ instead of system taskbar. 0 - - PushButton - Set where files will be saved. + + PushButton + diff --git a/src/widget/form/settings/identityform.cpp b/src/widget/form/settings/identityform.cpp index 8d067b606..f82227e5f 100644 --- a/src/widget/form/settings/identityform.cpp +++ b/src/widget/form/settings/identityform.cpp @@ -158,7 +158,11 @@ void IdentityForm::onRenameClicked() QFile::rename(dir.filePath(cur+".ini"), dir.filePath(name+".ini")); bodyUI->profiles->setItemText(bodyUI->profiles->currentIndex(), name); HistoryKeeper::renameHistory(cur, name); + bool resetAutorun = Settings::getInstance().getAutorun(); + Settings::getInstance().setAutorun(false); Settings::getInstance().setCurrentProfile(name); + if (resetAutorun) + Settings::getInstance().setAutorun(true); // fixes -P flag in autostart command line break; } } while (true);