diff options
author | Leander Schulten <Leander.Schulten@rwth-aachen.de> | 2020-03-27 07:52:48 +0100 |
---|---|---|
committer | Leander Schulten <Leander.Schulten@rwth-aachen.de> | 2020-03-27 07:52:48 +0100 |
commit | 49c282a64c2e357185cce851f7ce02f426a58afb (patch) | |
tree | 24455aff3ea8fe029b8090f35edcc18eb74d7e1a /singleapplication_p.cpp | |
parent | Merge pull request #96 from itay-grudev/primary_user (diff) | |
download | singleapplication-49c282a64c2e357185cce851f7ce02f426a58afb.tar.xz |
The codec for string from qgetenv and pw->pw_name is not necessarily utf8. So use QString::fromLocal8Bit and QStrings.
Diffstat (limited to 'singleapplication_p.cpp')
-rw-r--r-- | singleapplication_p.cpp | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/singleapplication_p.cpp b/singleapplication_p.cpp index 8eb49ab..705a980 100644 --- a/singleapplication_p.cpp +++ b/singleapplication_p.cpp @@ -84,23 +84,24 @@ SingleApplicationPrivate::~SingleApplicationPrivate() delete memory; } -QByteArray SingleApplicationPrivate::getUsername(){ +QString SingleApplicationPrivate::getUsername() +{ #ifdef Q_OS_WIN wchar_t username[UNLEN + 1]; // Specifies size of the buffer on input DWORD usernameLength = UNLEN + 1; if( GetUserNameW( username, &usernameLength ) ) - return QString::fromWCharArray( username ).toUtf8(); - return qgetenv( "USERNAME" ); + return QString::fromWCharArray( username ); + return qEnvironmentVariable( "USERNAME" ); #endif #ifdef Q_OS_UNIX - QByteArray username; + QString username; uid_t uid = geteuid(); struct passwd *pw = getpwuid( uid ); if( pw ) - username = pw->pw_name; + username = QString::fromLocal8Bit( pw->pw_name ); if( username.isEmpty() ) - username = qgetenv( "USER" ); + username = qEnvironmentVariable( "USER" ); return username; #endif } @@ -127,7 +128,7 @@ void SingleApplicationPrivate::genBlockServerName() // User level block requires a user specific data in the hash if( options & SingleApplication::Mode::User ) { - appData.addData( getUsername() ); + appData.addData( getUsername().toUtf8() ); } // Replace the backslash in RFC 2045 Base64 [a-zA-Z0-9+/=] to comply with @@ -175,7 +176,7 @@ void SingleApplicationPrivate::startPrimary() inst->primary = true; inst->primaryPid = q->applicationPid(); - strncpy( inst->primaryUser, getUsername().data(), 127 ); + strncpy( inst->primaryUser, getUsername().toUtf8().data(), 127 ); inst->primaryUser[127] = '\0'; inst->checksum = blockChecksum(); |