diff --git a/README.md b/README.md index c851379..9744788 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,4 @@ -SingleApplication -================= - -This is a replacement of QSingleApplication for Qt5. - -P.S. I will document it dome day, when I have time. -Otherwise it is pretty straighforward. I added a signal to notify the root proccess that another instance had been started. You can use it to raise the Main window of the root app, for example. +SingleApplication +================= + +This is a replacement of QSingleApplication for Qt5. diff --git a/localserver.cpp b/localserver.cpp deleted file mode 100644 index f3adcb9..0000000 --- a/localserver.cpp +++ /dev/null @@ -1,129 +0,0 @@ -#include "localserver.h" - -#include -#include - -/** - * @brief LocalServer::LocalServer - * Constructor - */ -LocalServer::LocalServer() -{ - -} - -/** - * @brief LocalServer::~LocalServer - * Destructor - */ -LocalServer::~LocalServer() -{ - server->close(); - for(int i = 0; i < clients.size(); ++i) - { - clients[i]->close(); - } -} - -/** - * ----------------------- - * QThread requred methods - * ----------------------- - */ - -/** - * @brief run - * Initiate the thread. - */ -void LocalServer::run() -{ - server = new QLocalServer(); - - QObject::connect(server, SIGNAL(newConnection()), this, SLOT(slotNewConnection())); - QObject::connect(this, SIGNAL(privateDataReceived(QString)), this, SLOT(slotOnData(QString))); - -#ifdef Q_OS_UNIX - // Make sure the temp address file is deleted - QFile address(QString("/tmp/" LOCAL_SERVER_NAME)); - if(address.exists()){ - address.remove(); - } -#endif - - QString serverName = QString(LOCAL_SERVER_NAME); - server->listen(serverName); - while(server->isListening() == false){ - server->listen(serverName); - msleep(100); - } - exec(); -} - -/** - * @brief LocalServer::exec - * Keeps the thread alive. Waits for incomming connections - */ -void LocalServer::exec() -{ - while(server->isListening()) - { - msleep(100); - server->waitForNewConnection(100); - for(int i = 0; i < clients.size(); ++i) - { - if(clients[i]->waitForReadyRead(100)){ - QByteArray data = clients[i]->readAll(); - emit privateDataReceived(data); - } - } - } -} - -/** - * ------- - * SLOTS - * ------- - */ - -/** - * @brief LocalServer::slotNewConnection - * Executed when a new connection is available - */ -void LocalServer::slotNewConnection() -{ - clients.push_front(server->nextPendingConnection()); -} - -/** - * @brief LocalServer::slotOnData - * Executed when data is received - * @param data - */ -void LocalServer::slotOnData(QString data) -{ - if(data.contains("CMD:", Qt::CaseInsensitive)){ - onSGC(data); - } else { - emit dataReceived(data); - } -} - -/** - * ------- - * Helper methods - * ------- - */ - -void LocalServer::onCMD(QString data) -{ - // Trim the leading part from the command - data.replace(0, 4, ""); - - QStringList commands; - commands << "showUp"; - - switch(commands.indexOf(data)){ - case 0: - emit showUp(); - } -} diff --git a/localserver.h b/localserver.h deleted file mode 100644 index 92c9bb1..0000000 --- a/localserver.h +++ /dev/null @@ -1,37 +0,0 @@ -#ifndef LOCALSERVER_H -#define LOCALSERVER_H - -#include -#include -#include -#include - -class LocalServer : public QThread -{ - Q_OBJECT -public: - LocalServer(); - ~LocalServer(); - void shut(); - -protected: - void run(); - void exec(); - -signals: - void dataReceived(QString data); - void privateDataReceived(QString data); - void showUp(); - -private slots: - void slotNewConnection(); - void slotOnData(QString data); - -private: - QLocalServer* server; - QVector clients; - void onCMD(QString data); - -}; - -#endif // LOCALSERVER_H diff --git a/main.cpp b/main.cpp deleted file mode 100644 index 101534f..0000000 --- a/main.cpp +++ /dev/null @@ -1,11 +0,0 @@ -#include "singleapplication.h" - -int main(int argc, char *argv[]) -{ - SingleApplication app(argc, argv); - - // Is another instance of the program is already running - if(!app.shouldContinue())return 0; - - return app.exec(); -} diff --git a/singleapplication.cpp b/singleapplication.cpp index 7e63371..5a4d37a 100644 --- a/singleapplication.cpp +++ b/singleapplication.cpp @@ -1,61 +1,52 @@ #include "singleapplication.h" +#include /** - * @brief SingleApplication::SingleApplication - * Constructor. Checks and fires up LocalServer or closes the program - * if another instance already exists + * @brief Constructor. Checks and fires up LocalServer or closes the +program + * if another instance already exists * @param argc * @param argv */ -SingleApplication::SingleApplication(int argc, char *argv[]) : - QGuiApplication(argc, argv) +SingleApplication::SingleApplication(int argc, char *argv[]) + : QApplication(argc, argv) { - _shouldContinue = false; // By default this is not the main process + QString serverName = QApplication::organizationName() + +QApplication::applicationName(); + serverName.replace(QRegExp("\\s"), ""); - socket = new QLocalSocket(); - - // Attempt to connect to the LocalServer - socket->connectToServer(LOCAL_SERVER_NAME); - if(socket->waitForConnected(100)){ - socket->write("CMD:showUp"); - socket->flush(); - QThread::msleep(100); - socket->close(); - } else { - // The attempt was insuccessful, so we continue the program - _shouldContinue = true; - server = new LocalServer(); - server->start(); - QObject::connect(server, SIGNAL(showUp()), this, SLOT(slotShowUp())); - } + // Attempt to connect to the LocalServer + socket = new QLocalSocket(); + socket->connectToServer(serverName); + if(socket->waitForConnected(1000)){ + socket->close(); + ::exit(EXIT_SUCCESS); // Terminate the program using STDLib's +exit function + } else { + // If the connection is insuccessful, this is the main process + // So we create a Local Server + server = new QLocalServer(); + server->removeServer(serverName); + server->listen(serverName); + QObject::connect(server, SIGNAL(newConnection()), this, +SLOT(slotConnectionEstablished())); + } } /** - * @brief SingleApplication::~SingleApplication - * Destructor + * @brief Destructor */ -Application::~SingleApplication() +SingleApplication::~SingleApplication() { - if(_shouldContinue){ - server->terminate(); - } + server->close(); } /** - * @brief SingleApplication::shouldContinue - * Weather the program should be terminated - * @return bool + * @brief Executed when the showUp command is sent to LocalServer */ -bool SingleApplication::shouldContinue() +void SingleApplication::slotConnectionEstablished() { - return _shouldContinue; + server->nextPendingConnection(); + emit showUp(); } -/** - * @brief SingleApplication::slotShowUp - * Executed when the showUp command is sent to LocalServer - */ -void SingleApplication::slotShowUp() -{ - emit showUp(); -} diff --git a/singleapplication.h b/singleapplication.h index 03ac69c..2fabfbd 100644 --- a/singleapplication.h +++ b/singleapplication.h @@ -1,33 +1,33 @@ -#ifndef APPLICATION_H -#define APPLICATION_H +#ifndef SINGLE_APPLICATION_H +#define SINGLE_APPLICATION_H -#include "localserver.h" - -#include +#include #include +#include /** - * @brief The Application class handles trivial application initialization procedures + * @brief The SingleApplication class handles multipe instances of the +same Application + * @see QApplication */ -class SingleApplication : public QGuiApplication +class SingleApplication : public QApplication { Q_OBJECT public: explicit SingleApplication(int, char *[]); ~SingleApplication(); - bool shouldContinue(); signals: void showUp(); private slots: - void slotShowUp(); - + void slotConnectionEstablished(); + private: - QLocalSocket* socket; - LocalServer* server; - bool _shouldContinue; + QLocalSocket *socket; + QLocalServer *server; }; -#endif // APPLICATION_H +#endif // SINGLE_APPLICATION_H +