From 94aa57d698a6400ae9c9d46991193d8ee844bb83 Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Thu, 20 Feb 2020 17:15:22 +0000 Subject: trackchange: feature to start command on application startup/exit (#202) git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@9235 90c681e8-e032-0410-971d-27865f9a5e38 --- src/plugins/General/trackchange/trackchange.cpp | 34 +++++++++++++++++-------- 1 file changed, 23 insertions(+), 11 deletions(-) (limited to 'src/plugins/General/trackchange/trackchange.cpp') diff --git a/src/plugins/General/trackchange/trackchange.cpp b/src/plugins/General/trackchange/trackchange.cpp index cbe5009f7..5c8168129 100644 --- a/src/plugins/General/trackchange/trackchange.cpp +++ b/src/plugins/General/trackchange/trackchange.cpp @@ -18,16 +18,9 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#include #include #include -#include -#include -#include -#include #include -#include -#include #include #include #include @@ -45,10 +38,17 @@ TrackChange::TrackChange(QObject *parent) : QObject(parent) connect(m_core, SIGNAL(trackInfoChanged()), SLOT(onTrackInfoChanged())); connect(m_core, SIGNAL(finished()), SLOT(onFinised())); QSettings settings(Qmmp::configFile(), QSettings::IniFormat); - m_newTrackCommand = settings.value("TrackChange/new_track_command").toString(); - m_endOfTrackCommand = settings.value("TrackChange/end_of_track_command").toString(); - m_endOfPlCommand = settings.value("TrackChange/end_of_pl_command").toString(); - m_titleChangeCommand = settings.value("TrackChange/title_change_command").toString(); + settings.beginGroup("TrackChange"); + m_newTrackCommand = settings.value("new_track_command").toString(); + m_endOfTrackCommand = settings.value("end_of_track_command").toString(); + m_endOfPlCommand = settings.value("end_of_pl_command").toString(); + m_titleChangeCommand = settings.value("title_change_command").toString(); + m_appStartupCommand = settings.value("title_change_command").toString(); + m_appExitCommand = settings.value("title_change_command").toString(); + settings.endGroup(); + + connect(qApp, SIGNAL(aboutToQuit()), SLOT(onAppExit())); + onAppStartup(); } TrackChange::~TrackChange() @@ -104,6 +104,18 @@ void TrackChange::onFinised() } } +void TrackChange::onAppStartup() +{ + if(QApplication::allWindows().count() == 1 && !m_appStartupCommand.isEmpty()) //detect startup + QProcess::startDetached(m_appStartupCommand); +} + +void TrackChange::onAppExit() +{ + if(!m_appExitCommand.isEmpty()) + QProcess::startDetached(m_appExitCommand); +} + bool TrackChange::executeCommand(const TrackInfo &info, const QString &format) { TrackInfo tmp = info; -- cgit v1.2.3-13-gbd6f