Remove magic chars from code - use more readable code style (#28)

This commit is contained in:
Evgeny 2017-02-22 16:27:48 +03:00 committed by Itay Grudev
parent 87a81e5780
commit d561026d83

View File

@ -45,6 +45,11 @@
#include "singleapplication.h" #include "singleapplication.h"
#include "singleapplication_p.h" #include "singleapplication_p.h"
static const char NewInstance = 'N';
static const char SecondaryInstance = 'S';
static const char Reconnect = 'R';
static const char InvalidConnection = '\0';
SingleApplicationPrivate::SingleApplicationPrivate( SingleApplication *q_ptr ) : q_ptr( q_ptr ) { SingleApplicationPrivate::SingleApplicationPrivate( SingleApplication *q_ptr ) : q_ptr( q_ptr ) {
server = nullptr; server = nullptr;
socket = nullptr; socket = nullptr;
@ -265,7 +270,7 @@ void SingleApplicationPrivate::slotConnectionEstablished()
QLocalSocket *nextConnSocket = server->nextPendingConnection(); QLocalSocket *nextConnSocket = server->nextPendingConnection();
// Verify that the new connection follows the SingleApplication protocol // Verify that the new connection follows the SingleApplication protocol
char connectionType = '\0'; // Invalid connection char connectionType = InvalidConnection;
quint32 instanceId; quint32 instanceId;
QByteArray initMsg, tmp; QByteArray initMsg, tmp;
if( nextConnSocket->waitForReadyRead( 100 ) ) { if( nextConnSocket->waitForReadyRead( 100 ) ) {
@ -273,13 +278,12 @@ void SingleApplicationPrivate::slotConnectionEstablished()
// Verify that the socket data start with blockServerName // Verify that the socket data start with blockServerName
if( tmp == blockServerName.toLatin1() ) { if( tmp == blockServerName.toLatin1() ) {
initMsg = tmp; initMsg = tmp;
// Verify that the next character is N/S/R (connection type)
// Stands for New Instance/Secondary Instance/Reconnect
connectionType = nextConnSocket->read( 1 )[0]; connectionType = nextConnSocket->read( 1 )[0];
switch( connectionType ) { switch( connectionType ) {
case 'N': case NewInstance:
case 'S': case SecondaryInstance:
case 'R': case Reconnect:
{ {
initMsg += connectionType; initMsg += connectionType;
tmp = nextConnSocket->read( sizeof(quint32) ); tmp = nextConnSocket->read( sizeof(quint32) );
@ -296,12 +300,12 @@ void SingleApplicationPrivate::slotConnectionEstablished()
break; // Otherwise set to invalid connection (next line) break; // Otherwise set to invalid connection (next line)
} }
default: default:
connectionType = '\0'; // Invalid connection connectionType = InvalidConnection;
} }
} }
} }
if( connectionType == '\0' ) { if( connectionType == InvalidConnection ) {
nextConnSocket->close(); nextConnSocket->close();
delete nextConnSocket; delete nextConnSocket;
return; return;
@ -325,8 +329,8 @@ void SingleApplicationPrivate::slotConnectionEstablished()
} }
); );
if( connectionType == 'N' || ( if( connectionType == NewInstance || (
connectionType == 'S' && connectionType == SecondaryInstance &&
options & SingleApplication::Mode::SecondaryNotification options & SingleApplication::Mode::SecondaryNotification
) )
) { ) {
@ -402,7 +406,7 @@ SingleApplication::SingleApplication( int &argc, char *argv[], bool allowSeconda
d->instanceNumber = inst->secondary; d->instanceNumber = inst->secondary;
d->startSecondary(); d->startSecondary();
if( d->options & Mode::SecondaryNotification ) { if( d->options & Mode::SecondaryNotification ) {
d->connectToPrimary( timeout, 'S' ); d->connectToPrimary( timeout, SecondaryInstance );
} }
d->memory->unlock(); d->memory->unlock();
return; return;
@ -412,7 +416,7 @@ SingleApplication::SingleApplication( int &argc, char *argv[], bool allowSeconda
} }
} }
d->connectToPrimary( timeout, 'N' ); d->connectToPrimary( timeout, NewInstance );
delete d; delete d;
::exit( EXIT_SUCCESS ); ::exit( EXIT_SUCCESS );
} }
@ -452,7 +456,7 @@ bool SingleApplication::sendMessage( QByteArray message, int timeout )
if( isPrimary() ) return false; if( isPrimary() ) return false;
// Make sure the socket is connected // Make sure the socket is connected
d->connectToPrimary( timeout, 'R' ); d->connectToPrimary( timeout, Reconnect );
d->socket->write( message ); d->socket->write( message );
bool dataWritten = d->socket->flush(); bool dataWritten = d->socket->flush();