X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fidentity.cpp;h=0569178ade8b86b0fbc150c2cbe322d3d64ecb1b;hb=3f354bcce2cecfe88a46de90cbf94ffd1bc7c506;hp=9359264f4b6943c12ef77b737a65fc8759507e34;hpb=ce6529a3ea1566d5d013f54608617e0c4fd982e0;p=quassel.git diff --git a/src/common/identity.cpp b/src/common/identity.cpp index 9359264f..0569178a 100644 --- a/src/common/identity.cpp +++ b/src/common/identity.cpp @@ -22,6 +22,7 @@ #include #include +#include #ifdef Q_OS_MAC # include @@ -88,7 +89,10 @@ QString Identity::defaultNick() { nick = shortUserName; #elif defined(Q_OS_UNIX) - QString userName = getlogin(); + QString userName; + struct passwd *pwd = getpwuid(getuid()); + if(pwd) + userName = pwd->pw_name; if(!userName.isEmpty()) nick = userName; @@ -108,7 +112,7 @@ QString Identity::defaultNick() { #endif // cleaning forbidden characters from nick - QRegExp rx(QString("(^[\\d-]+|[^A-Za-z\x5b-\x60\x7b-\x7d])")); + QRegExp rx(QString("(^[\\d-]+|[^A-Za-z0-9\x5b-\x60\x7b-\x7d])")); nick.remove(rx); return nick; } @@ -123,7 +127,7 @@ QString Identity::defaultRealName() { QString realName; struct passwd *pwd = getpwuid(getuid()); if(pwd) - realName = pwd->pw_gecos; + realName = QString::fromUtf8(pwd->pw_gecos); if(!realName.isEmpty()) return realName; else @@ -144,8 +148,7 @@ QString Identity::defaultRealName() { void Identity::setToDefaults() { setIdentityName(tr("")); setRealName(defaultRealName()); - QStringList n; - n << defaultNick() << defaultNick() + "_" << defaultNick() + "__"; + QStringList n = QStringList() << defaultNick(); setNicks(n); setAwayNick(""); setAwayNickEnabled(false);