more default nick and realname improvements
authorMarcus Eggenberger <egs@quassel-irc.org>
Sat, 7 Feb 2009 17:42:25 +0000 (18:42 +0100)
committerMarcus Eggenberger <egs@quassel-irc.org>
Sat, 7 Feb 2009 17:42:25 +0000 (18:42 +0100)
CMakeLists.txt
src/common/identity.cpp

index 26a3e9a..9b69168 100644 (file)
@@ -248,7 +248,7 @@ endif(STATIC AND CMAKE_COMPILER_IS_GNUCXX)
 
 if(WIN32)
   #if(STATIC)
-  link_libraries(imm32 winmm dbghelp)  # missing by default :/
+  link_libraries(imm32 winmm dbghelp Secur32)  # missing by default :/
   #endif(STATIC)
   if(HAVE_SSL)
      link_libraries(${OPENSSL_LIBRARIES} libeay32MD)
index 31b8a4a..aafb1fa 100644 (file)
 #  include "mac_utils.h"
 #endif
 
+#ifdef Q_OS_WIN32
+#  include <windows.h>
+#  include <Winbase.h>
+#  define SECURITY_WIN32
+#  include <Security.h>
+#endif
+
 Identity::Identity(IdentityId id, QObject *parent)
   : SyncableObject(parent),
     _identityId(id)
@@ -67,18 +74,43 @@ void Identity::init() {
 }
 
 QString Identity::defaultNick() {
+  QString generalDefault = QString("quassel%1").arg(qrand() & 0xff); // FIXME provide more sensible default nicks
 #ifdef Q_OS_MAC
   return CFStringToQString(CSCopyUserName(true));
+#elif defined(Q_OS_WIN32)
+  TCHAR  infoBuf[128];
+  DWORD  bufCharCount = 128;
+  //if(GetUserNameEx(/* NameSamCompatible */ 1, infoBuf, &bufCharCount))
+  if(!GetUserNameEx(NameSamCompatible, infoBuf, &bufCharCount))
+    return generalDefault;
+
+  QString nickName(infoBuf);
+  int lastBs = nickName.lastIndexOf('\\');
+  if(lastBs != -1) {
+    nickName = nickName.mid(lastBs + 1);
+  }
+  if(nickName.isEmpty())
+    return generalDefault;
+  else
+    return nickName;
 #else
-  return QString("quassel%1").arg(qrand() & 0xff); // FIXME provide more sensible default nicks
+  return generalDefault;
 #endif
 }
 
 QString Identity::defaultRealName() {
+  QString generalDefault = tr("Quassel IRC User");
 #ifdef Q_OS_MAC
   return CFStringToQString(CSCopyUserName(false));
+#elif defined(Q_OS_WIN32)
+  TCHAR  infoBuf[128];
+  DWORD  bufCharCount = 128;
+  if(GetUserName(infoBuf, &bufCharCount))
+    return QString(infoBuf);
+  else
+    return generalDefault;
 #else
-  return tr("Quassel IRC User");
+  return generalDefault;
 #endif
 }