diff --git a/CMakeLists.txt b/CMakeLists.txt
index 71d94e673..07a859ca3 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -10,6 +10,7 @@ set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/Modules)
 include(CheckIncludeFiles)
 include(CheckFunctionExists)
 include(CheckLibraryExists)
+include(CheckVariableExists)
 include(CheckTypeSize)
 include(CheckCSourceCompiles)
 include(CheckCXXSourceCompiles)
@@ -69,12 +70,16 @@ IF(CMAKE_BUILD_TYPE MATCHES Debug)
   add_definitions(-D_DEBUG)
 ENDIF()
 
-# Make sure we get a sane C version
+# Make sure we get a sane C and C++ version
 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++11")
 
 # Tell the compiler to be stringent
 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wextra -Wformat=2 -Wvla")
 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -Wformat=2 -Wvla")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wzero-as-null-pointer-constant")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wsuggest-override")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wshadow")
 # Make sure we catch these issues whilst developing
 IF(CMAKE_BUILD_TYPE MATCHES Debug)
   set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror")
@@ -182,6 +187,13 @@ if(ENABLE_H264)
     add_definitions("-DHAVE_H264")
     set(H264_LIBS "WIN")  # may be LIBAV in the future
     set(H264_LIBRARIES ole32 mfplat mfuuid wmcodecdspuuid)
+
+    set(CMAKE_REQUIRED_LIBRARIES ${H264_LIBRARIES})
+    check_variable_exists(CLSID_VideoProcessorMFT HAVE_VIDEO_PROCESSOR_MFT)
+    set(CMAKE_REQUIRED_LIBRARIES)
+    if(HAVE_VIDEO_PROCESSOR_MFT)
+      add_definitions("-DHAVE_VIDEO_PROCESSOR_MFT")
+    endif()
   else()
     find_package(Ffmpeg)
     if (AVCODEC_FOUND AND AVUTIL_FOUND AND SWSCALE_FOUND)
diff --git a/common/network/Socket.cxx b/common/network/Socket.cxx
index 78484f51c..8da443667 100644
--- a/common/network/Socket.cxx
+++ b/common/network/Socket.cxx
@@ -71,7 +71,7 @@ bool network::isSocketListening(int sock)
 }
 
 Socket::Socket(int fd)
-  : instream(0), outstream(0),
+  : instream(nullptr), outstream(nullptr),
     isShutdown_(false), queryConnection(false)
 {
   initSockets();
@@ -79,7 +79,7 @@ Socket::Socket(int fd)
 }
 
 Socket::Socket()
-  : instream(0), outstream(0),
+  : instream(nullptr), outstream(nullptr),
     isShutdown_(false), queryConnection(false)
 {
   initSockets();
@@ -128,14 +128,14 @@ void Socket::setFd(int fd)
   isShutdown_ = false;
 }
 
-SocketListener::SocketListener(int fd)
-  : fd(fd), filter(0)
+SocketListener::SocketListener(int fd_)
+  : fd(fd_), filter(nullptr)
 {
   initSockets();
 }
 
 SocketListener::SocketListener()
-  : fd(-1), filter(0)
+  : fd(-1), filter(nullptr)
 {
   initSockets();
 }
@@ -160,14 +160,14 @@ Socket* SocketListener::accept() {
   int new_sock = -1;
 
   // Accept an incoming connection
-  if ((new_sock = ::accept(fd, 0, 0)) < 0)
+  if ((new_sock = ::accept(fd, nullptr, nullptr)) < 0)
     throw SocketException("unable to accept new connection", errorNumber);
 
   // Create the socket object & check connection is allowed
   Socket* s = createSocket(new_sock);
   if (filter && !filter->verifyConnection(s)) {
     delete s;
-    return NULL;
+    return nullptr;
   }
 
   return s;
diff --git a/common/network/TcpSocket.cxx b/common/network/TcpSocket.cxx
index 15730cfdc..3f2f0f1fd 100644
--- a/common/network/TcpSocket.cxx
+++ b/common/network/TcpSocket.cxx
@@ -129,17 +129,17 @@ TcpSocket::TcpSocket(const char *host, int port)
   memset(&hints, 0, sizeof(struct addrinfo));
   hints.ai_family = AF_UNSPEC;
   hints.ai_socktype = SOCK_STREAM;
-  hints.ai_canonname = NULL;
-  hints.ai_addr = NULL;
-  hints.ai_next = NULL;
+  hints.ai_canonname = nullptr;
+  hints.ai_addr = nullptr;
+  hints.ai_next = nullptr;
 
-  if ((result = getaddrinfo(host, NULL, &hints, &ai)) != 0) {
+  if ((result = getaddrinfo(host, nullptr, &hints, &ai)) != 0) {
     throw GAIException("unable to resolve host by name", result);
   }
 
   sock = -1;
   err = 0;
-  for (current = ai; current != NULL; current = current->ai_next) {
+  for (current = ai; current != nullptr; current = current->ai_next) {
     int family;
     vnc_sockaddr_t sa;
     socklen_t salen;
@@ -168,7 +168,7 @@ TcpSocket::TcpSocket(const char *host, int port)
     else
       sa.u.sin6.sin6_port = htons(port);
 
-    getnameinfo(&sa.u.sa, salen, ntop, sizeof(ntop), NULL, 0, NI_NUMERICHOST);
+    getnameinfo(&sa.u.sa, salen, ntop, sizeof(ntop), nullptr, 0, NI_NUMERICHOST);
     vlog.debug("Connecting to %s [%s] port %d", host, ntop, port);
 
     sock = socket (family, SOCK_STREAM, 0);
@@ -228,7 +228,7 @@ const char* TcpSocket::getPeerAddress() {
     buffer[0] = '[';
 
     ret = getnameinfo(&sa.u.sa, sizeof(sa.u.sin6),
-                      buffer + 1, sizeof(buffer) - 2, NULL, 0,
+                      buffer + 1, sizeof(buffer) - 2, nullptr, 0,
                       NI_NUMERICHOST);
     if (ret != 0) {
       vlog.error("unable to convert peer name to a string");
@@ -244,7 +244,7 @@ const char* TcpSocket::getPeerAddress() {
     char *name;
 
     name = inet_ntoa(sa.u.sin.sin_addr);
-    if (name == NULL) {
+    if (name == nullptr) {
       vlog.error("unable to convert peer name to a string");
       return "(N/A)";
     }
@@ -338,8 +338,8 @@ TcpListener::TcpListener(const struct sockaddr *listenaddr,
   listen(sock);
 }
 
-Socket* TcpListener::createSocket(int fd) {
-  return new TcpSocket(fd);
+Socket* TcpListener::createSocket(int fd_) {
+  return new TcpSocket(fd_);
 }
 
 std::list<std::string> TcpListener::getMyAddresses() {
@@ -352,15 +352,15 @@ std::list<std::string> TcpListener::getMyAddresses() {
   hints.ai_flags = AI_PASSIVE | AI_NUMERICSERV;
   hints.ai_family = AF_UNSPEC;
   hints.ai_socktype = SOCK_STREAM;
-  hints.ai_canonname = NULL;
-  hints.ai_addr = NULL;
-  hints.ai_next = NULL;
+  hints.ai_canonname = nullptr;
+  hints.ai_addr = nullptr;
+  hints.ai_next = nullptr;
 
   // Windows doesn't like NULL for service, so specify something
-  if ((getaddrinfo(NULL, "1", &hints, &ai)) != 0)
+  if ((getaddrinfo(nullptr, "1", &hints, &ai)) != 0)
     return result;
 
-  for (current= ai; current != NULL; current = current->ai_next) {
+  for (current= ai; current != nullptr; current = current->ai_next) {
     char addr[INET6_ADDRSTRLEN];
 
     switch (current->ai_family) {
@@ -377,7 +377,7 @@ std::list<std::string> TcpListener::getMyAddresses() {
     }
 
     getnameinfo(current->ai_addr, current->ai_addrlen, addr, INET6_ADDRSTRLEN,
-                NULL, 0, NI_NUMERICHOST);
+                nullptr, 0, NI_NUMERICHOST);
 
     result.push_back(addr);
   }
@@ -417,7 +417,7 @@ void network::createLocalTcpListeners(std::list<SocketListener*> *listeners,
   ai[1].ai_family = sa[1].u.sin6.sin6_family;
   ai[1].ai_addr = &sa[1].u.sa;
   ai[1].ai_addrlen = sizeof(sa[1].u.sin6);
-  ai[1].ai_next = NULL;
+  ai[1].ai_next = nullptr;
 
   createTcpListeners(listeners, ai);
 }
@@ -436,9 +436,9 @@ void network::createTcpListeners(std::list<SocketListener*> *listeners,
   hints.ai_flags = AI_PASSIVE | AI_NUMERICSERV;
   hints.ai_family = AF_UNSPEC;
   hints.ai_socktype = SOCK_STREAM;
-  hints.ai_canonname = NULL;
-  hints.ai_addr = NULL;
-  hints.ai_next = NULL;
+  hints.ai_canonname = nullptr;
+  hints.ai_addr = nullptr;
+  hints.ai_next = nullptr;
 
   snprintf (service, sizeof (service) - 1, "%d", port);
   service[sizeof (service) - 1] = '\0';
@@ -463,7 +463,7 @@ void network::createTcpListeners(std::list<SocketListener*> *listeners,
 
   initSockets();
 
-  for (current = ai; current != NULL; current = current->ai_next) {
+  for (current = ai; current != nullptr; current = current->ai_next) {
     switch (current->ai_family) {
     case AF_INET:
       if (!UseIPv4)
@@ -629,7 +629,7 @@ TcpFilter::Pattern TcpFilter::parsePattern(const char* p) {
         parts[0].erase(parts.size()-1, 1);
     }
 
-    if ((result = getaddrinfo (parts[0].c_str(), NULL, &hints, &ai)) != 0) {
+    if ((result = getaddrinfo (parts[0].c_str(), nullptr, &hints, &ai)) != 0) {
       throw GAIException("unable to resolve host by name", result);
     }
 
@@ -711,11 +711,11 @@ std::string TcpFilter::patternToStr(const TcpFilter::Pattern& p) {
 
   if (p.address.u.sa.sa_family == AF_INET) {
     getnameinfo(&p.address.u.sa, sizeof(p.address.u.sin),
-                addr, sizeof(addr), NULL, 0, NI_NUMERICHOST);
+                addr, sizeof(addr), nullptr, 0, NI_NUMERICHOST);
   } else if (p.address.u.sa.sa_family == AF_INET6) {
     addr[0] = '[';
     getnameinfo(&p.address.u.sa, sizeof(p.address.u.sin6),
-                addr + 1, sizeof(addr) - 2, NULL, 0, NI_NUMERICHOST);
+                addr + 1, sizeof(addr) - 2, nullptr, 0, NI_NUMERICHOST);
     strcat(addr, "]");
   } else
     addr[0] = '\0';
diff --git a/common/network/TcpSocket.h b/common/network/TcpSocket.h
index c62dd78bc..b029bff26 100644
--- a/common/network/TcpSocket.h
+++ b/common/network/TcpSocket.h
@@ -56,8 +56,8 @@ namespace network {
     TcpSocket(int sock);
     TcpSocket(const char *name, int port);
 
-    virtual const char* getPeerAddress();
-    virtual const char* getPeerEndpoint();
+    const char* getPeerAddress() override;
+    const char* getPeerEndpoint() override;
 
   protected:
     bool enableNagles(bool enable);
@@ -68,12 +68,12 @@ namespace network {
     TcpListener(const struct sockaddr *listenaddr, socklen_t listenaddrlen);
     TcpListener(int sock);
 
-    virtual int getMyPort();
+    int getMyPort() override;
 
     static std::list<std::string> getMyAddresses();
 
   protected:
-    virtual Socket* createSocket(int fd);
+    Socket* createSocket(int fd) override;
   };
 
   void createLocalTcpListeners(std::list<SocketListener*> *listeners,
@@ -97,7 +97,7 @@ namespace network {
     TcpFilter(const char* filter);
     virtual ~TcpFilter();
 
-    virtual bool verifyConnection(Socket* s);
+    bool verifyConnection(Socket* s) override;
 
     typedef enum {Accept, Reject, Query} Action;
     struct Pattern {
diff --git a/common/network/UnixSocket.cxx b/common/network/UnixSocket.cxx
index e77938496..3a422b6c2 100644
--- a/common/network/UnixSocket.cxx
+++ b/common/network/UnixSocket.cxx
@@ -157,8 +157,8 @@ UnixListener::~UnixListener()
     unlink(addr.sun_path);
 }
 
-Socket* UnixListener::createSocket(int fd) {
-  return new UnixSocket(fd);
+Socket* UnixListener::createSocket(int fd_) {
+  return new UnixSocket(fd_);
 }
 
 int UnixListener::getMyPort() {
diff --git a/common/network/UnixSocket.h b/common/network/UnixSocket.h
index e66afcd1f..3ecc6179a 100644
--- a/common/network/UnixSocket.h
+++ b/common/network/UnixSocket.h
@@ -38,8 +38,8 @@ namespace network {
     UnixSocket(int sock);
     UnixSocket(const char *name);
 
-    virtual const char* getPeerAddress();
-    virtual const char* getPeerEndpoint();
+    const char* getPeerAddress() override;
+    const char* getPeerEndpoint() override;
   };
 
   class UnixListener : public SocketListener {
@@ -47,10 +47,10 @@ namespace network {
     UnixListener(const char *listenaddr, int mode);
     virtual ~UnixListener();
 
-    int getMyPort();
+    int getMyPort() override;
 
   protected:
-    virtual Socket* createSocket(int fd);
+    Socket* createSocket(int fd) override;
   };
 
 }
diff --git a/common/os/Mutex.cxx b/common/os/Mutex.cxx
index e6532a7de..2a768b4c8 100644
--- a/common/os/Mutex.cxx
+++ b/common/os/Mutex.cxx
@@ -41,7 +41,7 @@ Mutex::Mutex()
   int ret;
 
   systemMutex = new pthread_mutex_t;
-  ret = pthread_mutex_init((pthread_mutex_t*)systemMutex, NULL);
+  ret = pthread_mutex_init((pthread_mutex_t*)systemMutex, nullptr);
   if (ret != 0)
     throw rdr::SystemException("Failed to create mutex", ret);
 #endif
@@ -84,9 +84,9 @@ void Mutex::unlock()
 #endif
 }
 
-Condition::Condition(Mutex* mutex)
+Condition::Condition(Mutex* mutex_)
 {
-  this->mutex = mutex;
+  this->mutex = mutex_;
 
 #ifdef WIN32
   systemCondition = new CONDITION_VARIABLE;
@@ -95,7 +95,7 @@ Condition::Condition(Mutex* mutex)
   int ret;
 
   systemCondition = new pthread_cond_t;
-  ret = pthread_cond_init((pthread_cond_t*)systemCondition, NULL);
+  ret = pthread_cond_init((pthread_cond_t*)systemCondition, nullptr);
   if (ret != 0)
     throw rdr::SystemException("Failed to create condition variable", ret);
 #endif
diff --git a/common/os/Thread.cxx b/common/os/Thread.cxx
index 92cc68d53..91f7fd077 100644
--- a/common/os/Thread.cxx
+++ b/common/os/Thread.cxx
@@ -35,7 +35,7 @@
 
 using namespace os;
 
-Thread::Thread() : running(false), threadId(NULL)
+Thread::Thread() : running(false), threadId(nullptr)
 {
   mutex = new Mutex;
 
@@ -64,8 +64,8 @@ void Thread::start()
   AutoMutex a(mutex);
 
 #ifdef WIN32
-  *(HANDLE*)threadId = CreateThread(NULL, 0, startRoutine, this, 0, NULL);
-  if (*(HANDLE*)threadId == NULL)
+  *(HANDLE*)threadId = CreateThread(nullptr, 0, startRoutine, this, 0, nullptr);
+  if (*(HANDLE*)threadId == nullptr)
     throw rdr::SystemException("Failed to create thread", GetLastError());
 #else
   int ret;
@@ -78,9 +78,9 @@ void Thread::start()
   if (ret != 0)
     throw rdr::SystemException("Failed to mask signals", ret);
 
-  ret = pthread_create((pthread_t*)threadId, NULL, startRoutine, this);
+  ret = pthread_create((pthread_t*)threadId, nullptr, startRoutine, this);
 
-  pthread_sigmask(SIG_SETMASK, &old, NULL);
+  pthread_sigmask(SIG_SETMASK, &old, nullptr);
 
   if (ret != 0)
     throw rdr::SystemException("Failed to create thread", ret);
@@ -103,7 +103,7 @@ void Thread::wait()
 #else
   int ret;
 
-  ret = pthread_join(*(pthread_t*)threadId, NULL);
+  ret = pthread_join(*(pthread_t*)threadId, nullptr);
   if (ret != 0)
     throw rdr::SystemException("Failed to join thread", ret);
 #endif
@@ -165,5 +165,9 @@ void* Thread::startRoutine(void* data)
   self->running = false;
   self->mutex->unlock();
 
+#ifdef WIN32
   return 0;
+#else
+  return nullptr;
+#endif
 }
diff --git a/common/os/os.cxx b/common/os/os.cxx
index 83995d0d3..2ac70550e 100644
--- a/common/os/os.cxx
+++ b/common/os/os.cxx
@@ -58,12 +58,12 @@ static const char* getvncdir(bool userDir, const char *xdg_env, const char *xdg_
 
 #ifndef WIN32
   homedir = getenv("HOME");
-  if (homedir == NULL) {
+  if (homedir == nullptr) {
     uid = getuid();
     passwd = getpwuid(uid);
-    if (passwd == NULL) {
+    if (passwd == nullptr) {
       /* Do we want emit error msg here? */
-      return NULL;
+      return nullptr;
     }
     homedir = passwd->pw_dir;
   }
@@ -72,7 +72,7 @@ static const char* getvncdir(bool userDir, const char *xdg_env, const char *xdg_
     return homedir;
 
   xdgdir = getenv(xdg_env);
-  if (xdgdir != NULL && xdgdir[0] == '/')
+  if (xdgdir != nullptr && xdgdir[0] == '/')
     snprintf(dir, sizeof(dir), "%s/tigervnc", xdgdir);
   else
     snprintf(dir, sizeof(dir), "%s/%s/tigervnc", homedir, xdg_def);
@@ -83,25 +83,25 @@ static const char* getvncdir(bool userDir, const char *xdg_env, const char *xdg_
   (void) xdg_env;
 
   if (userDir)
-    ret = SHGetSpecialFolderPath(NULL, dir, CSIDL_PROFILE, FALSE);
+    ret = SHGetSpecialFolderPath(nullptr, dir, CSIDL_PROFILE, FALSE);
   else
-    ret = SHGetSpecialFolderPath(NULL, dir, CSIDL_APPDATA, FALSE);
+    ret = SHGetSpecialFolderPath(nullptr, dir, CSIDL_APPDATA, FALSE);
 
   if (ret == FALSE)
-    return NULL;
+    return nullptr;
 
   if (userDir)
     return dir;
 
-  ret = SHGetSpecialFolderPath(NULL, legacy, CSIDL_APPDATA, FALSE);
+  ret = SHGetSpecialFolderPath(nullptr, legacy, CSIDL_APPDATA, FALSE);
 
   if (ret == FALSE)
-    return NULL;
+    return nullptr;
 
   if (strlen(dir) + strlen("\\TigerVNC") >= sizeof(dir))
-    return NULL;
+    return nullptr;
   if (strlen(legacy) + strlen("\\vnc") >= sizeof(legacy))
-    return NULL;
+    return nullptr;
 
   strcat(dir, "\\TigerVNC");
   strcat(legacy, "\\vnc");
@@ -111,7 +111,7 @@ static const char* getvncdir(bool userDir, const char *xdg_env, const char *xdg_
 
 const char* os::getuserhomedir()
 {
-  return getvncdir(true, NULL, NULL);
+  return getvncdir(true, nullptr, nullptr);
 }
 
 const char* os::getvncconfigdir()
diff --git a/common/rdr/AESInStream.cxx b/common/rdr/AESInStream.cxx
index de91a3dfa..d6d944a33 100644
--- a/common/rdr/AESInStream.cxx
+++ b/common/rdr/AESInStream.cxx
@@ -45,15 +45,15 @@ bool AESInStream::fillBuffer()
 {
   if (!in->hasData(2))
     return false;
-  const uint8_t* ptr = in->getptr(2);
-  size_t length = ((int)ptr[0] << 8) | (int)ptr[1];
+  const uint8_t* buf = in->getptr(2);
+  size_t length = ((int)buf[0] << 8) | (int)buf[1];
   if (!in->hasData(2 + length + 16))
     return false;
   ensureSpace(length);
-  ptr = in->getptr(2 + length + 16);
-  const uint8_t* ad = ptr;
-  const uint8_t* data = ptr + 2;
-  const uint8_t* mac = ptr + 2 + length;
+  buf = in->getptr(2 + length + 16);
+  const uint8_t* ad = buf;
+  const uint8_t* data = buf + 2;
+  const uint8_t* mac = buf + 2 + length;
   uint8_t macComputed[16];
 
   if (keySize == 128) {
diff --git a/common/rdr/AESInStream.h b/common/rdr/AESInStream.h
index 6069bb710..f0e6de53c 100644
--- a/common/rdr/AESInStream.h
+++ b/common/rdr/AESInStream.h
@@ -33,7 +33,7 @@ namespace rdr {
     virtual ~AESInStream();
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
     int keySize;
     InStream* in;
diff --git a/common/rdr/AESOutStream.h b/common/rdr/AESOutStream.h
index f9e4f4da4..c84ee2b8f 100644
--- a/common/rdr/AESOutStream.h
+++ b/common/rdr/AESOutStream.h
@@ -31,11 +31,11 @@ namespace rdr {
     AESOutStream(OutStream* out, const uint8_t* key, int keySize);
     virtual ~AESOutStream();
 
-    virtual void flush();
-    virtual void cork(bool enable);
+    void flush() override;
+    void cork(bool enable) override;
 
   private:
-    virtual bool flushBuffer();
+    bool flushBuffer() override;
     void writeMessage(const uint8_t* data, size_t length);
 
     int keySize;
diff --git a/common/rdr/BufferedInStream.cxx b/common/rdr/BufferedInStream.cxx
index 5978a8c94..3c04bafc3 100644
--- a/common/rdr/BufferedInStream.cxx
+++ b/common/rdr/BufferedInStream.cxx
@@ -35,7 +35,7 @@ BufferedInStream::BufferedInStream()
   : bufSize(DEFAULT_BUF_SIZE), offset(0)
 {
   ptr = end = start = new uint8_t[bufSize];
-  gettimeofday(&lastSizeCheck, NULL);
+  gettimeofday(&lastSizeCheck, nullptr);
   peakUsage = 0;
 }
 
@@ -80,7 +80,7 @@ void BufferedInStream::ensureSpace(size_t needed)
     end = newBuffer + (end - ptr);
     ptr = start = newBuffer;
 
-    gettimeofday(&lastSizeCheck, NULL);
+    gettimeofday(&lastSizeCheck, nullptr);
     peakUsage = needed;
   }
 
@@ -88,7 +88,7 @@ void BufferedInStream::ensureSpace(size_t needed)
     peakUsage = needed;
 
   // Time to shrink an excessive buffer?
-  gettimeofday(&now, NULL);
+  gettimeofday(&now, nullptr);
   if ((avail() == 0) && (bufSize > DEFAULT_BUF_SIZE) &&
       ((now.tv_sec < lastSizeCheck.tv_sec) ||
        (now.tv_sec > (lastSizeCheck.tv_sec + 5)))) {
@@ -105,7 +105,7 @@ void BufferedInStream::ensureSpace(size_t needed)
       bufSize = newSize;
     }
 
-    gettimeofday(&lastSizeCheck, NULL);
+    gettimeofday(&lastSizeCheck, nullptr);
     peakUsage = needed;
   }
 
diff --git a/common/rdr/BufferedInStream.h b/common/rdr/BufferedInStream.h
index 89b25ffb9..b3d6115e0 100644
--- a/common/rdr/BufferedInStream.h
+++ b/common/rdr/BufferedInStream.h
@@ -35,7 +35,7 @@ namespace rdr {
   public:
     virtual ~BufferedInStream();
 
-    virtual size_t pos();
+    size_t pos() override;
 
   protected:
     size_t availSpace() { return start + bufSize - end; }
@@ -45,7 +45,7 @@ namespace rdr {
   private:
     virtual bool fillBuffer() = 0;
 
-    virtual bool overrun(size_t needed);
+    bool overrun(size_t needed) override;
 
   private:
     size_t bufSize;
diff --git a/common/rdr/BufferedOutStream.cxx b/common/rdr/BufferedOutStream.cxx
index 640f60076..0d6a1eb6b 100644
--- a/common/rdr/BufferedOutStream.cxx
+++ b/common/rdr/BufferedOutStream.cxx
@@ -31,12 +31,12 @@ using namespace rdr;
 static const size_t DEFAULT_BUF_SIZE = 16384;
 static const size_t MAX_BUF_SIZE = 32 * 1024 * 1024;
 
-BufferedOutStream::BufferedOutStream(bool emulateCork)
-  : bufSize(DEFAULT_BUF_SIZE), offset(0), emulateCork(emulateCork)
+BufferedOutStream::BufferedOutStream(bool emulateCork_)
+  : bufSize(DEFAULT_BUF_SIZE), offset(0), emulateCork(emulateCork_)
 {
   ptr = start = sentUpTo = new uint8_t[bufSize];
   end = start + bufSize;
-  gettimeofday(&lastSizeCheck, NULL);
+  gettimeofday(&lastSizeCheck, nullptr);
   peakUsage = 0;
 }
 
@@ -75,7 +75,7 @@ void BufferedOutStream::flush()
     ptr = sentUpTo = start;
 
   // Time to shrink an excessive buffer?
-  gettimeofday(&now, NULL);
+  gettimeofday(&now, nullptr);
   if ((sentUpTo == ptr) && (bufSize > DEFAULT_BUF_SIZE) &&
       ((now.tv_sec < lastSizeCheck.tv_sec) ||
        (now.tv_sec > (lastSizeCheck.tv_sec + 5)))) {
@@ -93,7 +93,7 @@ void BufferedOutStream::flush()
       bufSize = newSize;
     }
 
-    gettimeofday(&lastSizeCheck, NULL);
+    gettimeofday(&lastSizeCheck, nullptr);
     peakUsage = 0;
   }
 }
@@ -156,7 +156,7 @@ void BufferedOutStream::overrun(size_t needed)
   sentUpTo = start = newBuffer;
   end = newBuffer + newSize;
 
-  gettimeofday(&lastSizeCheck, NULL);
+  gettimeofday(&lastSizeCheck, nullptr);
   peakUsage = totalNeeded;
 
   return;
diff --git a/common/rdr/BufferedOutStream.h b/common/rdr/BufferedOutStream.h
index 226932575..dd765dc9e 100644
--- a/common/rdr/BufferedOutStream.h
+++ b/common/rdr/BufferedOutStream.h
@@ -35,8 +35,8 @@ namespace rdr {
   public:
     virtual ~BufferedOutStream();
 
-    virtual size_t length();
-    virtual void flush();
+    size_t length() override;
+    void flush() override;
 
     // hasBufferedData() checks if there is any data yet to be flushed
 
@@ -49,7 +49,7 @@ namespace rdr {
 
     virtual bool flushBuffer() = 0;
 
-    virtual void overrun(size_t needed);
+    void overrun(size_t needed) override;
 
   private:
     size_t bufSize;
diff --git a/common/rdr/Exception.cxx b/common/rdr/Exception.cxx
index b1e0a841c..d55462749 100644
--- a/common/rdr/Exception.cxx
+++ b/common/rdr/Exception.cxx
@@ -51,15 +51,15 @@ Exception::Exception(const char *format, ...) {
 	va_end(ap);
 }
 
-GAIException::GAIException(const char* s, int err)
-  : Exception("%s", s)
+GAIException::GAIException(const char* s, int err_)
+  : Exception("%s", s), err(err_)
 {
   strncat(str_, ": ", len-1-strlen(str_));
 #ifdef _WIN32
   wchar_t *currStr = new wchar_t[len-strlen(str_)];
   wcsncpy(currStr, gai_strerrorW(err), len-1-strlen(str_));
   WideCharToMultiByte(CP_UTF8, 0, currStr, -1, str_+strlen(str_),
-                      len-1-strlen(str_), 0, 0);
+                      len-1-strlen(str_), nullptr, nullptr);
   delete [] currStr;
 #else
   strncat(str_, gai_strerror(err), len-1-strlen(str_));
@@ -83,9 +83,9 @@ SystemException::SystemException(const char* s, int err_)
 #ifdef _WIN32
   wchar_t *currStr = new wchar_t[len-strlen(str_)];
   FormatMessageW(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
-                 0, err, 0, currStr, len-1-strlen(str_), 0);
+                 nullptr, err, 0, currStr, len-1-strlen(str_), nullptr);
   WideCharToMultiByte(CP_UTF8, 0, currStr, -1, str_+strlen(str_),
-                      len-1-strlen(str_), 0, 0);
+                      len-1-strlen(str_), nullptr, nullptr);
   delete [] currStr;
 
   int l = strlen(str_);
diff --git a/common/rdr/Exception.h b/common/rdr/Exception.h
index 2c66ffcab..f1a167e5c 100644
--- a/common/rdr/Exception.h
+++ b/common/rdr/Exception.h
@@ -26,7 +26,7 @@ namespace rdr {
   struct Exception {
     enum { len = 256 };
     char str_[len];
-    Exception(const char *format = 0, ...)
+    Exception(const char *format=nullptr, ...)
       __attribute__((__format__ (__printf__, 2, 3)));
     virtual ~Exception() {}
     virtual const char* str() const { return str_; }
diff --git a/common/rdr/FdInStream.cxx b/common/rdr/FdInStream.cxx
index 8e12f3a4b..491dc008a 100644
--- a/common/rdr/FdInStream.cxx
+++ b/common/rdr/FdInStream.cxx
@@ -88,7 +88,7 @@ size_t FdInStream::readFd(uint8_t* buf, size_t len)
 
     FD_ZERO(&fds);
     FD_SET(fd, &fds);
-    n = select(fd+1, &fds, 0, 0, &tv);
+    n = select(fd+1, &fds, nullptr, nullptr, &tv);
   } while (n < 0 && errorNumber == EINTR);
 
   if (n < 0)
diff --git a/common/rdr/FdInStream.h b/common/rdr/FdInStream.h
index 0f8373fe7..0bd5bf194 100644
--- a/common/rdr/FdInStream.h
+++ b/common/rdr/FdInStream.h
@@ -37,7 +37,7 @@ namespace rdr {
     int getFd() { return fd; }
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
     size_t readFd(uint8_t* buf, size_t len);
 
diff --git a/common/rdr/FdOutStream.cxx b/common/rdr/FdOutStream.cxx
index 6827655f0..1f60d45b4 100644
--- a/common/rdr/FdOutStream.cxx
+++ b/common/rdr/FdOutStream.cxx
@@ -59,7 +59,7 @@ FdOutStream::FdOutStream(int fd_)
 #endif
   fd(fd_)
 {
-  gettimeofday(&lastWrite, NULL);
+  gettimeofday(&lastWrite, nullptr);
 }
 
 FdOutStream::~FdOutStream()
@@ -113,7 +113,7 @@ size_t FdOutStream::writeFd(const uint8_t* data, size_t length)
 
     FD_ZERO(&fds);
     FD_SET(fd, &fds);
-    n = select(fd+1, 0, &fds, 0, &tv);
+    n = select(fd+1, nullptr, &fds, nullptr, &tv);
   } while (n < 0 && errorNumber == EINTR);
 
   if (n < 0)
@@ -136,7 +136,7 @@ size_t FdOutStream::writeFd(const uint8_t* data, size_t length)
   if (n < 0)
     throw SystemException("write", errorNumber);
 
-  gettimeofday(&lastWrite, NULL);
+  gettimeofday(&lastWrite, nullptr);
 
   return n;
 }
diff --git a/common/rdr/FdOutStream.h b/common/rdr/FdOutStream.h
index 05fc1fed7..d9f16efb7 100644
--- a/common/rdr/FdOutStream.h
+++ b/common/rdr/FdOutStream.h
@@ -41,10 +41,10 @@ namespace rdr {
 
     unsigned getIdleTime();
 
-    virtual void cork(bool enable);
+    void cork(bool enable) override;
 
   private:
-    virtual bool flushBuffer();
+    bool flushBuffer() override;
     size_t writeFd(const uint8_t* data, size_t length);
     int fd;
     struct timeval lastWrite;
diff --git a/common/rdr/FileInStream.cxx b/common/rdr/FileInStream.cxx
index 6de1a5b29..4239a2386 100644
--- a/common/rdr/FileInStream.cxx
+++ b/common/rdr/FileInStream.cxx
@@ -39,7 +39,7 @@ FileInStream::FileInStream(const char *fileName)
 FileInStream::~FileInStream(void) {
   if (file) {
     fclose(file);
-    file = NULL;
+    file = nullptr;
   }
 }
 
diff --git a/common/rdr/FileInStream.h b/common/rdr/FileInStream.h
index e13596ce8..1b409e466 100644
--- a/common/rdr/FileInStream.h
+++ b/common/rdr/FileInStream.h
@@ -34,7 +34,7 @@ namespace rdr {
     ~FileInStream(void);
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
   private:
     FILE *file;
diff --git a/common/rdr/HexInStream.h b/common/rdr/HexInStream.h
index 76f91c089..c69fcd689 100644
--- a/common/rdr/HexInStream.h
+++ b/common/rdr/HexInStream.h
@@ -30,7 +30,7 @@ namespace rdr {
     virtual ~HexInStream();
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
   private:
     InStream& in_stream;
diff --git a/common/rdr/HexOutStream.h b/common/rdr/HexOutStream.h
index 16596bf39..7c74f9dec 100644
--- a/common/rdr/HexOutStream.h
+++ b/common/rdr/HexOutStream.h
@@ -29,11 +29,11 @@ namespace rdr {
     HexOutStream(OutStream& os);
     virtual ~HexOutStream();
 
-    virtual void flush();
-    virtual void cork(bool enable);
+    void flush() override;
+    void cork(bool enable) override;
 
   private:
-    virtual bool flushBuffer();
+    bool flushBuffer() override;
     void writeBuffer();
 
     OutStream& out_stream;
diff --git a/common/rdr/InStream.h b/common/rdr/InStream.h
index 019ca5a72..939439e1b 100644
--- a/common/rdr/InStream.h
+++ b/common/rdr/InStream.h
@@ -64,7 +64,7 @@ namespace rdr {
 #endif
 
       if (length > (size_t)(end - ptr)) {
-        if (restorePoint != NULL) {
+        if (restorePoint != nullptr) {
           bool ret;
           size_t restoreDiff;
 
@@ -100,21 +100,21 @@ namespace rdr {
 
     inline void setRestorePoint() {
 #ifdef RFB_INSTREAM_CHECK
-      if (restorePoint != NULL)
+      if (restorePoint != nullptr)
         throw Exception("Nested use of input stream restore point");
 #endif
       restorePoint = ptr;
     }
     inline void clearRestorePoint() {
 #ifdef RFB_INSTREAM_CHECK
-      if (restorePoint == NULL)
+      if (restorePoint == nullptr)
         throw Exception("Incorrect clearing of input stream restore point");
 #endif
-      restorePoint = NULL;
+      restorePoint = nullptr;
     }
     inline void gotoRestorePoint() {
 #ifdef RFB_INSTREAM_CHECK
-      if (restorePoint == NULL)
+      if (restorePoint == nullptr)
         throw Exception("Incorrect activation of input stream restore point");
 #endif
       ptr = restorePoint;
@@ -204,7 +204,7 @@ namespace rdr {
 
   protected:
 
-    InStream() : restorePoint(NULL)
+    InStream() : restorePoint(nullptr)
 #ifdef RFB_INSTREAM_CHECK
       ,checkedBytes(0)
 #endif
diff --git a/common/rdr/MemInStream.h b/common/rdr/MemInStream.h
index 61d084822..e10273b16 100644
--- a/common/rdr/MemInStream.h
+++ b/common/rdr/MemInStream.h
@@ -54,12 +54,12 @@ namespace rdr {
         delete [] start;
     }
 
-    size_t pos() { return ptr - start; }
+    size_t pos() override { return ptr - start; }
     void reposition(size_t pos) { ptr = start + pos; }
 
   private:
 
-    bool overrun(size_t /*needed*/) { throw EndOfStream(); }
+    bool overrun(size_t /*needed*/) override { throw EndOfStream(); }
     const uint8_t* start;
     bool deleteWhenDone;
   };
diff --git a/common/rdr/MemOutStream.h b/common/rdr/MemOutStream.h
index 5ed1ccf78..9bf2b810f 100644
--- a/common/rdr/MemOutStream.h
+++ b/common/rdr/MemOutStream.h
@@ -41,7 +41,7 @@ namespace rdr {
       delete [] start;
     }
 
-    size_t length() { return ptr - start; }
+    size_t length() override { return ptr - start; }
     void clear() { ptr = start; };
     void clearAndZero() { memset(start, 0, ptr-start); clear(); }
     void reposition(size_t pos) { ptr = start + pos; }
@@ -55,7 +55,7 @@ namespace rdr {
     // overrun() either doubles the buffer or adds enough space for
     // needed bytes.
 
-    virtual void overrun(size_t needed) {
+    void overrun(size_t needed) override {
       size_t len = ptr - start + needed;
       if (len < (size_t)(end - start) * 2)
         len = (end - start) * 2;
diff --git a/common/rdr/OutStream.h b/common/rdr/OutStream.h
index 8450efd09..2921b2326 100644
--- a/common/rdr/OutStream.h
+++ b/common/rdr/OutStream.h
@@ -36,7 +36,7 @@ namespace rdr {
 
   protected:
 
-    OutStream() : ptr(NULL), end(NULL), corked(false) {}
+    OutStream() : ptr(nullptr), end(nullptr), corked(false) {}
 
   public:
 
diff --git a/common/rdr/RandomStream.cxx b/common/rdr/RandomStream.cxx
index 79a1a0f77..9813abdd1 100644
--- a/common/rdr/RandomStream.cxx
+++ b/common/rdr/RandomStream.cxx
@@ -45,9 +45,11 @@ RandomStream::RandomStream()
 {
 #ifdef RFB_HAVE_WINCRYPT
   provider = 0;
-  if (!CryptAcquireContext(&provider, 0, 0, PROV_RSA_FULL, 0)) {
+  if (!CryptAcquireContext(&provider, nullptr, nullptr,
+                           PROV_RSA_FULL, 0)) {
     if (GetLastError() == (DWORD)NTE_BAD_KEYSET) {
-      if (!CryptAcquireContext(&provider, 0, 0, PROV_RSA_FULL, CRYPT_NEWKEYSET)) {
+      if (!CryptAcquireContext(&provider, nullptr, nullptr,
+                               PROV_RSA_FULL, CRYPT_NEWKEYSET)) {
         vlog.error("unable to create keyset");
         provider = 0;
       }
@@ -68,7 +70,7 @@ RandomStream::RandomStream()
 #endif
 #endif
     vlog.error("no OS supplied random source - using rand()");
-    seed += (unsigned int) time(0) + getpid() + getpid() * 987654 + rand();
+    seed += (unsigned int) time(nullptr) + getpid() + getpid() * 987654 + rand();
     srand(seed);
   }
 }
diff --git a/common/rdr/RandomStream.h b/common/rdr/RandomStream.h
index 521012e07..48f373c17 100644
--- a/common/rdr/RandomStream.h
+++ b/common/rdr/RandomStream.h
@@ -40,7 +40,7 @@ namespace rdr {
     virtual ~RandomStream();
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
   private:
     static unsigned int seed;
diff --git a/common/rdr/TLSInStream.cxx b/common/rdr/TLSInStream.cxx
index 7ba98155f..d13cee1fb 100644
--- a/common/rdr/TLSInStream.cxx
+++ b/common/rdr/TLSInStream.cxx
@@ -41,7 +41,7 @@ ssize_t TLSInStream::pull(gnutls_transport_ptr_t str, void* data, size_t size)
 
   self->streamEmpty = false;
   delete self->saved_exception;
-  self->saved_exception = NULL;
+  self->saved_exception = nullptr;
 
   try {
     if (!in->hasData(1)) {
@@ -72,7 +72,7 @@ ssize_t TLSInStream::pull(gnutls_transport_ptr_t str, void* data, size_t size)
 }
 
 TLSInStream::TLSInStream(InStream* _in, gnutls_session_t _session)
-  : session(_session), in(_in), saved_exception(NULL)
+  : session(_session), in(_in), saved_exception(nullptr)
 {
   gnutls_transport_ptr_t recv, send;
 
@@ -83,7 +83,7 @@ TLSInStream::TLSInStream(InStream* _in, gnutls_session_t _session)
 
 TLSInStream::~TLSInStream()
 {
-  gnutls_transport_set_pull_function(session, NULL);
+  gnutls_transport_set_pull_function(session, nullptr);
 
   delete saved_exception;
 }
diff --git a/common/rdr/TLSInStream.h b/common/rdr/TLSInStream.h
index 5b1b716f9..ca69dddea 100644
--- a/common/rdr/TLSInStream.h
+++ b/common/rdr/TLSInStream.h
@@ -33,7 +33,7 @@ namespace rdr {
     virtual ~TLSInStream();
 
   private:
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
     size_t readTLS(uint8_t* buf, size_t len);
     static ssize_t pull(gnutls_transport_ptr_t str, void* data, size_t size);
 
diff --git a/common/rdr/TLSOutStream.cxx b/common/rdr/TLSOutStream.cxx
index a06dd285f..c2f693102 100644
--- a/common/rdr/TLSOutStream.cxx
+++ b/common/rdr/TLSOutStream.cxx
@@ -41,7 +41,7 @@ ssize_t TLSOutStream::push(gnutls_transport_ptr_t str, const void* data,
   OutStream *out = self->out;
 
   delete self->saved_exception;
-  self->saved_exception = NULL;
+  self->saved_exception = nullptr;
 
   try {
     out->writeBytes((const uint8_t*)data, size);
@@ -62,7 +62,7 @@ ssize_t TLSOutStream::push(gnutls_transport_ptr_t str, const void* data,
 }
 
 TLSOutStream::TLSOutStream(OutStream* _out, gnutls_session_t _session)
-  : session(_session), out(_out), saved_exception(NULL)
+  : session(_session), out(_out), saved_exception(nullptr)
 {
   gnutls_transport_ptr_t recv, send;
 
@@ -79,7 +79,7 @@ TLSOutStream::~TLSOutStream()
   } catch (Exception&) {
   }
 #endif
-  gnutls_transport_set_push_function(session, NULL);
+  gnutls_transport_set_push_function(session, nullptr);
 
   delete saved_exception;
 }
diff --git a/common/rdr/TLSOutStream.h b/common/rdr/TLSOutStream.h
index 2d365f36d..357142382 100644
--- a/common/rdr/TLSOutStream.h
+++ b/common/rdr/TLSOutStream.h
@@ -31,11 +31,11 @@ namespace rdr {
     TLSOutStream(OutStream* out, gnutls_session_t session);
     virtual ~TLSOutStream();
 
-    virtual void flush();
-    virtual void cork(bool enable);
+    void flush() override;
+    void cork(bool enable) override;
 
   private:
-    virtual bool flushBuffer();
+    bool flushBuffer() override;
     size_t writeTLS(const uint8_t* data, size_t length);
     static ssize_t push(gnutls_transport_ptr_t str, const void* data, size_t size);
 
diff --git a/common/rdr/ZlibInStream.cxx b/common/rdr/ZlibInStream.cxx
index 6441f0a1d..a90d50f75 100644
--- a/common/rdr/ZlibInStream.cxx
+++ b/common/rdr/ZlibInStream.cxx
@@ -29,7 +29,7 @@
 using namespace rdr;
 
 ZlibInStream::ZlibInStream()
-  : underlying(0), zs(NULL), bytesIn(0)
+  : underlying(nullptr), zs(nullptr), bytesIn(0)
 {
   init();
 }
@@ -54,7 +54,7 @@ void ZlibInStream::flushUnderlying()
     skip(avail());
   }
 
-  setUnderlying(NULL, 0);
+  setUnderlying(nullptr, 0);
 }
 
 void ZlibInStream::reset()
@@ -65,28 +65,28 @@ void ZlibInStream::reset()
 
 void ZlibInStream::init()
 {
-  assert(zs == NULL);
+  assert(zs == nullptr);
 
   zs = new z_stream;
-  zs->zalloc    = Z_NULL;
-  zs->zfree     = Z_NULL;
-  zs->opaque    = Z_NULL;
-  zs->next_in   = Z_NULL;
+  zs->zalloc    = nullptr;
+  zs->zfree     = nullptr;
+  zs->opaque    = nullptr;
+  zs->next_in   = nullptr;
   zs->avail_in  = 0;
   if (inflateInit(zs) != Z_OK) {
     delete zs;
-    zs = NULL;
+    zs = nullptr;
     throw Exception("ZlibInStream: inflateInit failed");
   }
 }
 
 void ZlibInStream::deinit()
 {
-  assert(zs != NULL);
-  setUnderlying(NULL, 0);
+  assert(zs != nullptr);
+  setUnderlying(nullptr, 0);
   inflateEnd(zs);
   delete zs;
-  zs = NULL;
+  zs = nullptr;
 }
 
 bool ZlibInStream::fillBuffer()
diff --git a/common/rdr/ZlibInStream.h b/common/rdr/ZlibInStream.h
index cce6a6e0e..a0c311611 100644
--- a/common/rdr/ZlibInStream.h
+++ b/common/rdr/ZlibInStream.h
@@ -44,7 +44,7 @@ namespace rdr {
     void init();
     void deinit();
 
-    virtual bool fillBuffer();
+    bool fillBuffer() override;
 
   private:
     InStream* underlying;
diff --git a/common/rdr/ZlibOutStream.cxx b/common/rdr/ZlibOutStream.cxx
index 63820b8ec..0b167711e 100644
--- a/common/rdr/ZlibOutStream.cxx
+++ b/common/rdr/ZlibOutStream.cxx
@@ -39,10 +39,10 @@ ZlibOutStream::ZlibOutStream(OutStream* os, int compressLevel)
   : underlying(os), compressionLevel(compressLevel), newLevel(compressLevel)
 {
   zs = new z_stream;
-  zs->zalloc    = Z_NULL;
-  zs->zfree     = Z_NULL;
-  zs->opaque    = Z_NULL;
-  zs->next_in   = Z_NULL;
+  zs->zalloc    = nullptr;
+  zs->zfree     = nullptr;
+  zs->opaque    = nullptr;
+  zs->next_in   = nullptr;
   zs->avail_in  = 0;
   if (deflateInit(zs, compressLevel) != Z_OK) {
     delete zs;
@@ -78,14 +78,14 @@ void ZlibOutStream::setCompressionLevel(int level)
 void ZlibOutStream::flush()
 {
   BufferedOutStream::flush();
-  if (underlying != NULL)
+  if (underlying != nullptr)
     underlying->flush();
 }
 
 void ZlibOutStream::cork(bool enable)
 {
   BufferedOutStream::cork(enable);
-  if (underlying != NULL)
+  if (underlying != nullptr)
     underlying->cork(enable);
 }
 
diff --git a/common/rdr/ZlibOutStream.h b/common/rdr/ZlibOutStream.h
index 8061a58c6..14df2a845 100644
--- a/common/rdr/ZlibOutStream.h
+++ b/common/rdr/ZlibOutStream.h
@@ -35,16 +35,16 @@ namespace rdr {
 
   public:
 
-    ZlibOutStream(OutStream* os=0, int compressionLevel=-1);
+    ZlibOutStream(OutStream* os=nullptr, int compressionLevel=-1);
     virtual ~ZlibOutStream();
 
     void setUnderlying(OutStream* os);
     void setCompressionLevel(int level=-1);
-    virtual void flush();
-    virtual void cork(bool enable);
+    void flush() override;
+    void cork(bool enable) override;
 
   private:
-    virtual bool flushBuffer();
+    bool flushBuffer() override;
     void deflate(int flush);
     void checkCompressionLevel();
 
diff --git a/common/rfb/Blacklist.cxx b/common/rfb/Blacklist.cxx
index 12a54c451..68420ae2f 100644
--- a/common/rfb/Blacklist.cxx
+++ b/common/rfb/Blacklist.cxx
@@ -67,7 +67,7 @@ bool Blacklist::isBlackmarked(const char* name) {
   // Entry exists - has it reached the threshold yet?
   if ((*i).second.marks >= threshold) {
     // Yes - entry is blocked - has the timeout expired?        
-    time_t now = time(0);
+    time_t now = time(nullptr);
     if (now >= (*i).second.blockUntil) {
       // Timeout has expired.  Reset timeout and allow
       // a re-try.
diff --git a/common/rfb/CConnection.cxx b/common/rfb/CConnection.cxx
index 0f4fc4f88..0db5f4c8a 100644
--- a/common/rfb/CConnection.cxx
+++ b/common/rfb/CConnection.cxx
@@ -25,6 +25,8 @@
 #include <stdio.h>
 #include <string.h>
 
+#include <algorithm>
+
 #include <rfb/Exception.h>
 #include <rfb/clipboardTypes.h>
 #include <rfb/fenceTypes.h>
@@ -48,10 +50,10 @@ using namespace rfb;
 static LogWriter vlog("CConnection");
 
 CConnection::CConnection()
-  : csecurity(0),
+  : csecurity(nullptr),
     supportsLocalCursor(false), supportsCursorPosition(false),
     supportsDesktopResize(false), supportsLEDState(false),
-    is(0), os(0), reader_(0), writer_(0),
+    is(nullptr), os(nullptr), reader_(nullptr), writer_(nullptr),
     shared(false),
     state_(RFBSTATE_UNINITIALISED),
     pendingPFChange(false), preferredEncoding(encodingTight),
@@ -59,7 +61,7 @@ CConnection::CConnection()
     formatChange(false), encodingChange(false),
     firstUpdate(true), pendingUpdate(false), continuousUpdates(false),
     forceNonincremental(true),
-    framebuffer(NULL), decoder(this),
+    framebuffer(nullptr), decoder(this),
     hasRemoteClipboard(false), hasLocalClipboard(false)
 {
 }
@@ -71,7 +73,7 @@ CConnection::~CConnection()
 
 void CConnection::setServerName(const char* name_)
 {
-  if (name_ == NULL)
+  if (name_ == nullptr)
     name_ = "";
   serverName = name_;
 }
@@ -91,7 +93,7 @@ void CConnection::setFramebuffer(ModifiablePixelBuffer* fb)
     assert(fb->height() == server.height());
   }
 
-  if ((framebuffer != NULL) && (fb != NULL)) {
+  if ((framebuffer != nullptr) && (fb != nullptr)) {
     Rect rect;
 
     const uint8_t* data;
@@ -226,14 +228,8 @@ bool CConnection::processSecurityTypesMsg()
       state_ = RFBSTATE_SECURITY_REASON;
       return true;
     } else if (secType == secTypeNone || secType == secTypeVncAuth) {
-      std::list<uint8_t>::iterator i;
-      for (i = secTypes.begin(); i != secTypes.end(); i++)
-        if (*i == secType) {
-          secType = *i;
-          break;
-        }
-
-      if (i == secTypes.end())
+      if (std::find(secTypes.begin(), secTypes.end(),
+                    secType) == secTypes.end())
         secType = secTypeInvalid;
     } else {
       vlog.error("Unknown 3.3 security type %d", secType);
@@ -260,8 +256,6 @@ bool CConnection::processSecurityTypesMsg()
       return true;
     }
 
-    std::list<uint8_t>::iterator j;
-
     for (int i = 0; i < nServerSecTypes; i++) {
       uint8_t serverSecType = is->readU8();
       vlog.debug("Server offers security type %s(%d)",
@@ -272,12 +266,10 @@ bool CConnection::processSecurityTypesMsg()
        * It means server's order specifies priority.
        */
       if (secType == secTypeInvalid) {
-        for (j = secTypes.begin(); j != secTypes.end(); j++)
-          if (*j == serverSecType) {
-            secType = *j;
-            break;
-          }
-       }
+        if (std::find(secTypes.begin(), secTypes.end(),
+                      serverSecType) != secTypes.end())
+          secType = serverSecType;
+      }
     }
 
     // Inform the server of our decision
@@ -399,13 +391,13 @@ void CConnection::close()
     vlog.error("%s", e.str());
   }
 
-  setFramebuffer(NULL);
+  setFramebuffer(nullptr);
   delete csecurity;
-  csecurity = NULL;
+  csecurity = nullptr;
   delete reader_;
-  reader_ = NULL;
+  reader_ = nullptr;
   delete writer_;
-  writer_ = NULL;
+  writer_ = nullptr;
 }
 
 void CConnection::setDesktopSize(int w, int h)
@@ -420,7 +412,7 @@ void CConnection::setDesktopSize(int w, int h)
                                            server.height());
 
   resizeFramebuffer();
-  assert(framebuffer != NULL);
+  assert(framebuffer != nullptr);
   assert(framebuffer->width() == server.width());
   assert(framebuffer->height() == server.height());
 }
@@ -440,7 +432,7 @@ void CConnection::setExtendedDesktopSize(unsigned reason,
                                            server.height());
 
   resizeFramebuffer();
-  assert(framebuffer != NULL);
+  assert(framebuffer != nullptr);
   assert(framebuffer->width() == server.width());
   assert(framebuffer->height() == server.height());
 }
@@ -471,7 +463,7 @@ void CConnection::serverInit(int width, int height,
   vlog.debug("initialisation done");
 
   initDone();
-  assert(framebuffer != NULL);
+  assert(framebuffer != nullptr);
   assert(framebuffer->width() == server.width());
   assert(framebuffer->height() == server.height());
 
@@ -501,7 +493,7 @@ void CConnection::framebufferUpdateStart()
 {
   CMsgHandler::framebufferUpdateStart();
 
-  assert(framebuffer != NULL);
+  assert(framebuffer != nullptr);
 
   // Note: This might not be true if continuous updates are supported
   pendingUpdate = false;
@@ -683,7 +675,7 @@ void CConnection::sendClipboardData(const char* data)
     // FIXME: This conversion magic should be in CMsgWriter
     std::string filtered(convertCRLF(data));
     size_t sizes[1] = { filtered.size() + 1 };
-    const uint8_t* data[1] = { (const uint8_t*)filtered.c_str() };
+    const uint8_t* datas[1] = { (const uint8_t*)filtered.c_str() };
 
     if (unsolicitedClipboardAttempt) {
       unsolicitedClipboardAttempt = false;
@@ -695,7 +687,7 @@ void CConnection::sendClipboardData(const char* data)
       }
     }
 
-    writer()->writeClipboardProvide(rfb::clipboardUTF8, sizes, data);
+    writer()->writeClipboardProvide(rfb::clipboardUTF8, sizes, datas);
   } else {
     writer()->writeClientCutText(data);
   }
diff --git a/common/rfb/CConnection.h b/common/rfb/CConnection.h
index df0fbb14a..dca98a92e 100644
--- a/common/rfb/CConnection.h
+++ b/common/rfb/CConnection.h
@@ -97,34 +97,32 @@ namespace rfb {
 
     // Note: These must be called by any deriving classes
 
-    virtual void setDesktopSize(int w, int h);
-    virtual void setExtendedDesktopSize(unsigned reason, unsigned result,
-                                        int w, int h,
-                                        const ScreenSet& layout);
+    void setDesktopSize(int w, int h) override;
+    void setExtendedDesktopSize(unsigned reason, unsigned result,
+                                int w, int h,
+                                const ScreenSet& layout) override;
 
-    virtual void endOfContinuousUpdates();
+    void endOfContinuousUpdates() override;
 
-    virtual void serverInit(int width, int height,
-                            const PixelFormat& pf,
-                            const char* name);
+    void serverInit(int width, int height, const PixelFormat& pf,
+                    const char* name) override;
 
-    virtual bool readAndDecodeRect(const Rect& r, int encoding,
-                                   ModifiablePixelBuffer* pb);
+    bool readAndDecodeRect(const Rect& r, int encoding,
+                           ModifiablePixelBuffer* pb) override;
 
-    virtual void framebufferUpdateStart();
-    virtual void framebufferUpdateEnd();
-    virtual bool dataRect(const Rect& r, int encoding);
+    void framebufferUpdateStart() override;
+    void framebufferUpdateEnd() override;
+    bool dataRect(const Rect& r, int encoding) override;
 
-    virtual void serverCutText(const char* str);
+    void serverCutText(const char* str) override;
 
-    virtual void handleClipboardCaps(uint32_t flags,
-                                     const uint32_t* lengths);
-    virtual void handleClipboardRequest(uint32_t flags);
-    virtual void handleClipboardPeek();
-    virtual void handleClipboardNotify(uint32_t flags);
-    virtual void handleClipboardProvide(uint32_t flags,
-                                        const size_t* lengths,
-                                        const uint8_t* const* data);
+    void handleClipboardCaps(uint32_t flags,
+                                     const uint32_t* lengths) override;
+    void handleClipboardRequest(uint32_t flags) override;
+    void handleClipboardPeek() override;
+    void handleClipboardNotify(uint32_t flags) override;
+    void handleClipboardProvide(uint32_t flags, const size_t* lengths,
+                                const uint8_t* const* data) override;
 
 
     // Methods to be overridden in a derived class
@@ -249,7 +247,7 @@ namespace rfb {
     // responds to requests, stating no support for synchronisation.
     // When overriding, call CMsgHandler::fence() directly in order to
     // state correct support for fence flags.
-    virtual void fence(uint32_t flags, unsigned len, const uint8_t data[]);
+    void fence(uint32_t flags, unsigned len, const uint8_t data[]) override;
 
   private:
     bool processVersionMsg();
diff --git a/common/rfb/CMsgReader.cxx b/common/rfb/CMsgReader.cxx
index 006645df4..8bcdbfd04 100644
--- a/common/rfb/CMsgReader.cxx
+++ b/common/rfb/CMsgReader.cxx
@@ -385,7 +385,7 @@ bool CMsgReader::readExtendedClipboard(int32_t len)
     }
 
     zis.flushUnderlying();
-    zis.setUnderlying(NULL, 0);
+    zis.setUnderlying(nullptr, 0);
 
     handler->handleClipboardProvide(flags, lengths, buffers);
 
@@ -827,31 +827,31 @@ bool CMsgReader::readExtendedDesktopSize(int x, int y, int w, int h)
 
 bool CMsgReader::readLEDState()
 {
-  uint8_t state;
+  uint8_t ledState;
 
   if (!is->hasData(1))
     return false;
 
-  state = is->readU8();
+  ledState = is->readU8();
 
-  handler->setLEDState(state);
+  handler->setLEDState(ledState);
 
   return true;
 }
 
 bool CMsgReader::readVMwareLEDState()
 {
-  uint32_t state;
+  uint32_t ledState;
 
   if (!is->hasData(4))
     return false;
 
-  state = is->readU32();
+  ledState = is->readU32();
 
   // As luck has it, this extension uses the same bit definitions,
   // so no conversion required
 
-  handler->setLEDState(state);
+  handler->setLEDState(ledState);
 
   return true;
 }
diff --git a/common/rfb/CMsgWriter.cxx b/common/rfb/CMsgWriter.cxx
index e941aaa7e..7d7579680 100644
--- a/common/rfb/CMsgWriter.cxx
+++ b/common/rfb/CMsgWriter.cxx
@@ -65,12 +65,11 @@ void CMsgWriter::writeSetPixelFormat(const PixelFormat& pf)
 
 void CMsgWriter::writeSetEncodings(const std::list<uint32_t> encodings)
 {
-  std::list<uint32_t>::const_iterator iter;
   startMsg(msgTypeSetEncodings);
   os->pad(1);
   os->writeU16(encodings.size());
-  for (iter = encodings.begin(); iter != encodings.end(); ++iter)
-    os->writeU32(*iter);
+  for (uint32_t encoding : encodings)
+    os->writeU32(encoding);
   endMsg();
 }
 
@@ -192,7 +191,7 @@ void CMsgWriter::writePointerEvent(const Point& pos, int buttonMask)
 
 void CMsgWriter::writeClientCutText(const char* str)
 {
-  if (strchr(str, '\r') != NULL)
+  if (strchr(str, '\r') != nullptr)
     throw Exception("Invalid carriage return in clipboard data");
 
   std::string latin1(utf8ToLatin1(str));
diff --git a/common/rfb/CSecurityDH.cxx b/common/rfb/CSecurityDH.cxx
index f6e5ded43..6d9650bd2 100644
--- a/common/rfb/CSecurityDH.cxx
+++ b/common/rfb/CSecurityDH.cxx
@@ -47,8 +47,8 @@ using namespace rfb;
 const int MinKeyLength = 128;
 const int MaxKeyLength = 1024;
 
-CSecurityDH::CSecurityDH(CConnection* cc)
-  : CSecurity(cc), keyLength(0)
+CSecurityDH::CSecurityDH(CConnection* cc_)
+  : CSecurity(cc_), keyLength(0)
 {
   mpz_init(g);
   mpz_init(p);
diff --git a/common/rfb/CSecurityDH.h b/common/rfb/CSecurityDH.h
index d0e5e8946..df33d29b6 100644
--- a/common/rfb/CSecurityDH.h
+++ b/common/rfb/CSecurityDH.h
@@ -33,9 +33,9 @@ namespace rfb {
   public:
     CSecurityDH(CConnection* cc);
     virtual ~CSecurityDH();
-    virtual bool processMsg();
-    virtual int getType() const { return secTypeDH; }
-    virtual bool isSecure() const { return false; }
+    bool processMsg() override;
+    int getType() const override { return secTypeDH; }
+    bool isSecure() const override { return false; }
 
   private:
     bool readKey();
diff --git a/common/rfb/CSecurityMSLogonII.cxx b/common/rfb/CSecurityMSLogonII.cxx
index d7e237151..e721cdfcf 100644
--- a/common/rfb/CSecurityMSLogonII.cxx
+++ b/common/rfb/CSecurityMSLogonII.cxx
@@ -44,8 +44,8 @@
 
 using namespace rfb;
 
-CSecurityMSLogonII::CSecurityMSLogonII(CConnection* cc)
-  : CSecurity(cc)
+CSecurityMSLogonII::CSecurityMSLogonII(CConnection* cc_)
+  : CSecurity(cc_)
 {
   mpz_init(g);
   mpz_init(p);
diff --git a/common/rfb/CSecurityMSLogonII.h b/common/rfb/CSecurityMSLogonII.h
index f7c83a3e1..71600c853 100644
--- a/common/rfb/CSecurityMSLogonII.h
+++ b/common/rfb/CSecurityMSLogonII.h
@@ -33,9 +33,9 @@ namespace rfb {
   public:
     CSecurityMSLogonII(CConnection* cc);
     virtual ~CSecurityMSLogonII();
-    virtual bool processMsg();
-    virtual int getType() const { return secTypeMSLogonII; }
-    virtual bool isSecure() const { return false; }
+    bool processMsg() override;
+    int getType() const override { return secTypeMSLogonII; }
+    bool isSecure() const override { return false; }
 
   private:
     bool readKey();
diff --git a/common/rfb/CSecurityNone.h b/common/rfb/CSecurityNone.h
index cb887914f..df685d0d1 100644
--- a/common/rfb/CSecurityNone.h
+++ b/common/rfb/CSecurityNone.h
@@ -29,9 +29,9 @@ namespace rfb {
 
   class CSecurityNone : public CSecurity {
   public:
-    CSecurityNone(CConnection* cc) : CSecurity(cc) {}
-    virtual bool processMsg() { return true; }
-    virtual int getType() const {return secTypeNone;}
+    CSecurityNone(CConnection* cc_) : CSecurity(cc_) {}
+    bool processMsg() override { return true; }
+    int getType() const override {return secTypeNone;}
   };
 }
 #endif
diff --git a/common/rfb/CSecurityPlain.h b/common/rfb/CSecurityPlain.h
index add7e776e..0dbf4064a 100644
--- a/common/rfb/CSecurityPlain.h
+++ b/common/rfb/CSecurityPlain.h
@@ -26,9 +26,9 @@ namespace rfb {
 
   class CSecurityPlain : public CSecurity {
   public:
-    CSecurityPlain(CConnection* cc) : CSecurity(cc) {}
-    virtual bool processMsg();
-    virtual int getType() const { return secTypePlain; }
+    CSecurityPlain(CConnection* cc_) : CSecurity(cc_) {}
+    bool processMsg() override;
+    int getType() const override { return secTypePlain; }
   };
 }
 #endif
diff --git a/common/rfb/CSecurityRSAAES.cxx b/common/rfb/CSecurityRSAAES.cxx
index 5a4bc9c9b..96d96b01a 100644
--- a/common/rfb/CSecurityRSAAES.cxx
+++ b/common/rfb/CSecurityRSAAES.cxx
@@ -56,14 +56,14 @@ const int MaxKeyLength = 8192;
 
 using namespace rfb;
 
-CSecurityRSAAES::CSecurityRSAAES(CConnection* cc, uint32_t _secType,
+CSecurityRSAAES::CSecurityRSAAES(CConnection* cc_, uint32_t _secType,
                                  int _keySize, bool _isAllEncrypted)
-  : CSecurity(cc), state(ReadPublicKey),
+  : CSecurity(cc_), state(ReadPublicKey),
     keySize(_keySize), isAllEncrypted(_isAllEncrypted), secType(_secType),
     clientKey(), clientPublicKey(), serverKey(),
-    serverKeyN(NULL), serverKeyE(NULL),
-    clientKeyN(NULL), clientKeyE(NULL),
-    rais(NULL), raos(NULL), rawis(NULL), rawos(NULL)
+    serverKeyN(nullptr), serverKeyE(nullptr),
+    clientKeyN(nullptr), clientKeyE(nullptr),
+    rais(nullptr), raos(nullptr), rawis(nullptr), rawos(nullptr)
 {
   assert(keySize == 128 || keySize == 256);
 }
@@ -154,7 +154,8 @@ void CSecurityRSAAES::writePublicKey()
   // set e = 65537
   mpz_set_ui(clientPublicKey.e, 65537);
   if (!rsa_generate_keypair(&clientPublicKey, &clientKey,
-                            &rs, random_func, NULL, NULL, clientKeyLength, 0))
+                            &rs, random_func, nullptr, nullptr,
+                            clientKeyLength, 0))
     throw AuthFailureException("failed to generate key");
   clientKeyN = new uint8_t[rsaKeySize];
   clientKeyE = new uint8_t[rsaKeySize];
@@ -413,10 +414,10 @@ void CSecurityRSAAES::clearSecrets()
   delete[] serverKeyE;
   delete[] clientKeyN;
   delete[] clientKeyE;
-  serverKeyN = NULL;
-  serverKeyE = NULL;
-  clientKeyN = NULL;
-  clientKeyE = NULL;
+  serverKeyN = nullptr;
+  serverKeyE = nullptr;
+  clientKeyN = nullptr;
+  clientKeyE = nullptr;
   memset(serverRandom, 0, sizeof(serverRandom));
   memset(clientRandom, 0, sizeof(clientRandom));
 }
@@ -439,7 +440,7 @@ void CSecurityRSAAES::writeCredentials()
   if (subtype == secTypeRA2UserPass)
     (CSecurity::upg)->getUserPasswd(isSecure(), &username, &password);
   else
-    (CSecurity::upg)->getUserPasswd(isSecure(), NULL, &password);
+    (CSecurity::upg)->getUserPasswd(isSecure(), nullptr, &password);
 
   if (subtype == secTypeRA2UserPass) {
     if (username.size() > 255)
diff --git a/common/rfb/CSecurityRSAAES.h b/common/rfb/CSecurityRSAAES.h
index 543b01522..29bfd5750 100644
--- a/common/rfb/CSecurityRSAAES.h
+++ b/common/rfb/CSecurityRSAAES.h
@@ -39,9 +39,9 @@ namespace rfb {
     CSecurityRSAAES(CConnection* cc, uint32_t secType,
                     int keySize, bool isAllEncrypted);
     virtual ~CSecurityRSAAES();
-    virtual bool processMsg();
-    virtual int getType() const { return secType; }
-    virtual bool isSecure() const { return secType == secTypeRA256; }
+    bool processMsg() override;
+    int getType() const override { return secType; }
+    bool isSecure() const override { return secType == secTypeRA256; }
 
     static IntParameter RSAKeyLength;
 
diff --git a/common/rfb/CSecurityStack.cxx b/common/rfb/CSecurityStack.cxx
index 6b8da8ddd..838d68ac6 100644
--- a/common/rfb/CSecurityStack.cxx
+++ b/common/rfb/CSecurityStack.cxx
@@ -25,9 +25,9 @@
 
 using namespace rfb;
 
-CSecurityStack::CSecurityStack(CConnection* cc, int Type,
+CSecurityStack::CSecurityStack(CConnection* cc_, int Type,
                                CSecurity* s0, CSecurity* s1)
-  : CSecurity(cc), type(Type)
+  : CSecurity(cc_), type(Type)
 {
   state = 0;
   state0 = s0;
diff --git a/common/rfb/CSecurityStack.h b/common/rfb/CSecurityStack.h
index 56ac3fea6..521597ec8 100644
--- a/common/rfb/CSecurityStack.h
+++ b/common/rfb/CSecurityStack.h
@@ -28,11 +28,11 @@ namespace rfb {
   class CSecurityStack : public CSecurity {
   public:
     CSecurityStack(CConnection* cc, int Type,
-                   CSecurity* s0 = NULL, CSecurity* s1 = NULL);
+                   CSecurity* s0 = nullptr, CSecurity* s1 = nullptr);
     ~CSecurityStack();
-    virtual bool processMsg();
-    virtual int getType() const {return type;};
-    virtual bool isSecure() const;
+    bool processMsg() override;
+    int getType() const override {return type;};
+    bool isSecure() const override;
   protected:
     int state;
     CSecurity* state0;
diff --git a/common/rfb/CSecurityTLS.cxx b/common/rfb/CSecurityTLS.cxx
index 11e6dfe3b..8d8b58fda 100644
--- a/common/rfb/CSecurityTLS.cxx
+++ b/common/rfb/CSecurityTLS.cxx
@@ -75,16 +75,18 @@ static const char* configdirfn(const char* fn)
   const char* configdir;
 
   configdir = os::getvncconfigdir();
-  if (configdir == NULL)
+  if (configdir == nullptr)
     return "";
 
   snprintf(full_path, sizeof(full_path), "%s/%s", configdir, fn);
   return full_path;
 }
 
-CSecurityTLS::CSecurityTLS(CConnection* cc, bool _anon)
-  : CSecurity(cc), session(NULL), anon_cred(NULL), cert_cred(NULL),
-    anon(_anon), tlsis(NULL), tlsos(NULL), rawis(NULL), rawos(NULL)
+CSecurityTLS::CSecurityTLS(CConnection* cc_, bool _anon)
+  : CSecurity(cc_), session(nullptr),
+    anon_cred(nullptr), cert_cred(nullptr),
+    anon(_anon), tlsis(nullptr), tlsos(nullptr),
+    rawis(nullptr), rawos(nullptr)
 {
   if (gnutls_global_init() != GNUTLS_E_SUCCESS)
     throw AuthFailureException("gnutls_global_init failed");
@@ -103,32 +105,32 @@ void CSecurityTLS::shutdown()
 
   if (anon_cred) {
     gnutls_anon_free_client_credentials(anon_cred);
-    anon_cred = 0;
+    anon_cred = nullptr;
   }
 
   if (cert_cred) {
     gnutls_certificate_free_credentials(cert_cred);
-    cert_cred = 0;
+    cert_cred = nullptr;
   }
 
   if (rawis && rawos) {
     cc->setStreams(rawis, rawos);
-    rawis = NULL;
-    rawos = NULL;
+    rawis = nullptr;
+    rawos = nullptr;
   }
 
   if (tlsis) {
     delete tlsis;
-    tlsis = NULL;
+    tlsis = nullptr;
   }
   if (tlsos) {
     delete tlsos;
-    tlsos = NULL;
+    tlsos = nullptr;
   }
 
   if (session) {
     gnutls_deinit(session);
-    session = 0;
+    session = nullptr;
   }
 }
 
@@ -206,7 +208,7 @@ void CSecurityTLS::setParam()
 
     prio = (char*)malloc(strlen(Security::GnuTLSPriority) +
                          strlen(kx_anon_priority) + 1);
-    if (prio == NULL)
+    if (prio == nullptr)
       throw AuthFailureException("Not enough memory for GnuTLS priority string");
 
     strcpy(prio, Security::GnuTLSPriority);
@@ -242,7 +244,7 @@ void CSecurityTLS::setParam()
 
     prio = (char*)malloc(strlen(gnutls_default_priority) +
                          strlen(kx_anon_priority) + 1);
-    if (prio == NULL)
+    if (prio == nullptr)
       throw AuthFailureException("Not enough memory for GnuTLS priority string");
 
     strcpy(prio, gnutls_default_priority);
@@ -385,7 +387,7 @@ void CSecurityTLS::checkSession()
   /* Certificate has some user overridable problems, so TOFU time */
 
   hostsDir = os::getvncstatedir();
-  if (hostsDir == NULL) {
+  if (hostsDir == nullptr) {
     throw AuthFailureException("Could not obtain VNC state directory "
                                "path for known hosts storage");
   }
@@ -393,8 +395,8 @@ void CSecurityTLS::checkSession()
   std::string dbPath;
   dbPath = (std::string)hostsDir + "/x509_known_hosts";
 
-  err = gnutls_verify_stored_pubkey(dbPath.c_str(), NULL,
-                                    client->getServerName(), NULL,
+  err = gnutls_verify_stored_pubkey(dbPath.c_str(), nullptr,
+                                    client->getServerName(), nullptr,
                                     GNUTLS_CRT_X509, &cert_list[0], 0);
 
   /* Previously known? */
@@ -648,8 +650,9 @@ void CSecurityTLS::checkSession()
     }
   }
 
-  if (gnutls_store_pubkey(dbPath.c_str(), NULL, client->getServerName(),
-                          NULL, GNUTLS_CRT_X509, &cert_list[0], 0, 0))
+  if (gnutls_store_pubkey(dbPath.c_str(), nullptr,
+                          client->getServerName(), nullptr,
+                          GNUTLS_CRT_X509, &cert_list[0], 0, 0))
     vlog.error("Failed to store server certificate to known hosts database");
 
   vlog.info("Exception added for server host");
diff --git a/common/rfb/CSecurityTLS.h b/common/rfb/CSecurityTLS.h
index b9c345cfb..8688b742c 100644
--- a/common/rfb/CSecurityTLS.h
+++ b/common/rfb/CSecurityTLS.h
@@ -38,9 +38,9 @@ namespace rfb {
   public:
     CSecurityTLS(CConnection* cc, bool _anon);
     virtual ~CSecurityTLS();
-    virtual bool processMsg();
-    virtual int getType() const { return anon ? secTypeTLSNone : secTypeX509None; }
-    virtual bool isSecure() const { return !anon; }
+    bool processMsg() override;
+    int getType() const override { return anon ? secTypeTLSNone : secTypeX509None; }
+    bool isSecure() const override { return !anon; }
 
     static StringParameter X509CA;
     static StringParameter X509CRL;
diff --git a/common/rfb/CSecurityVeNCrypt.cxx b/common/rfb/CSecurityVeNCrypt.cxx
index 3c8e91ba4..19dcabc33 100644
--- a/common/rfb/CSecurityVeNCrypt.cxx
+++ b/common/rfb/CSecurityVeNCrypt.cxx
@@ -26,13 +26,15 @@
 #include <config.h>
 #endif
 
+#include <algorithm>
+#include <list>
+
 #include <rfb/Exception.h>
 #include <rdr/InStream.h>
 #include <rdr/OutStream.h>
 #include <rfb/CConnection.h>
 #include <rfb/CSecurityVeNCrypt.h>
 #include <rfb/LogWriter.h>
-#include <list>
 
 using namespace rfb;
 using namespace rdr;
@@ -40,8 +42,9 @@ using namespace std;
 
 static LogWriter vlog("CVeNCrypt");
 
-CSecurityVeNCrypt::CSecurityVeNCrypt(CConnection* cc, SecurityClient* sec)
-  : CSecurity(cc), csecurity(NULL), security(sec)
+CSecurityVeNCrypt::CSecurityVeNCrypt(CConnection* cc_,
+                                     SecurityClient* sec)
+  : CSecurity(cc_), csecurity(nullptr), security(sec)
 {
   haveRecvdMajorVersion = false;
   haveRecvdMinorVersion = false;
@@ -54,7 +57,7 @@ CSecurityVeNCrypt::CSecurityVeNCrypt(CConnection* cc, SecurityClient* sec)
   minorVersion = 0;
   chosenType = secTypeVeNCrypt;
   nAvailableTypes = 0;
-  availableTypes = NULL;
+  availableTypes = nullptr;
 }
 
 CSecurityVeNCrypt::~CSecurityVeNCrypt()
@@ -156,22 +159,17 @@ bool CSecurityVeNCrypt::processMsg()
     if (!haveChosenType) {
       chosenType = secTypeInvalid;
       uint8_t i;
-      list<uint32_t>::iterator j;
       list<uint32_t> secTypes;
 
       secTypes = security->GetEnabledExtSecTypes();
 
       /* Honor server's security type order */
       for (i = 0; i < nAvailableTypes; i++) {
-        for (j = secTypes.begin(); j != secTypes.end(); j++) {
-	  if (*j == availableTypes[i]) {
-	    chosenType = *j;
-	    break;
-	  }
-	}
-
-	if (chosenType != secTypeInvalid)
-	  break;
+        if (std::find(secTypes.begin(), secTypes.end(),
+                      availableTypes[i]) != secTypes.end()) {
+          chosenType = availableTypes[i];
+          break;
+        }
       }
 
       /* Set up the stack according to the chosen type: */
diff --git a/common/rfb/CSecurityVeNCrypt.h b/common/rfb/CSecurityVeNCrypt.h
index 476bf813a..f73e7927c 100644
--- a/common/rfb/CSecurityVeNCrypt.h
+++ b/common/rfb/CSecurityVeNCrypt.h
@@ -37,9 +37,9 @@ namespace rfb {
 
     CSecurityVeNCrypt(CConnection* cc, SecurityClient* sec);
     ~CSecurityVeNCrypt();
-    virtual bool processMsg();
-    int getType() const {return chosenType;}
-    virtual bool isSecure() const;
+    bool processMsg() override;
+    int getType() const override {return chosenType;}
+    bool isSecure() const override;
 
   protected:
     CSecurity *csecurity;
diff --git a/common/rfb/CSecurityVncAuth.cxx b/common/rfb/CSecurityVncAuth.cxx
index f6a5e07a6..e5f842baa 100644
--- a/common/rfb/CSecurityVncAuth.cxx
+++ b/common/rfb/CSecurityVncAuth.cxx
@@ -54,7 +54,7 @@ bool CSecurityVncAuth::processMsg()
   uint8_t challenge[vncAuthChallengeSize];
   is->readBytes(challenge, vncAuthChallengeSize);
   std::string passwd;
-  (CSecurity::upg)->getUserPasswd(cc->isSecure(), 0, &passwd);
+  (CSecurity::upg)->getUserPasswd(cc->isSecure(), nullptr, &passwd);
 
   // Calculate the correct response
   uint8_t key[8];
diff --git a/common/rfb/CSecurityVncAuth.h b/common/rfb/CSecurityVncAuth.h
index 3f1f315b1..9a9cf6e01 100644
--- a/common/rfb/CSecurityVncAuth.h
+++ b/common/rfb/CSecurityVncAuth.h
@@ -25,10 +25,10 @@ namespace rfb {
 
   class CSecurityVncAuth : public CSecurity {
   public:
-    CSecurityVncAuth(CConnection* cc) : CSecurity(cc) {}
+    CSecurityVncAuth(CConnection* cc_) : CSecurity(cc_) {}
     virtual ~CSecurityVncAuth() {}
-    virtual bool processMsg();
-    virtual int getType() const {return secTypeVncAuth;};
+    bool processMsg() override;
+    int getType() const override {return secTypeVncAuth;};
   };
 }
 #endif
diff --git a/common/rfb/ClientParams.cxx b/common/rfb/ClientParams.cxx
index ade990181..bc20c3d72 100644
--- a/common/rfb/ClientParams.cxx
+++ b/common/rfb/ClientParams.cxx
@@ -39,7 +39,7 @@ ClientParams::ClientParams()
 {
   setName("");
 
-  cursor_ = new Cursor(0, 0, Point(), NULL);
+  cursor_ = new Cursor(0, 0, Point(), nullptr);
 
   clipFlags = clipboardUTF8 | clipboardRTF | clipboardHTML |
               clipboardRequest | clipboardNotify | clipboardProvide;
diff --git a/common/rfb/Configuration.cxx b/common/rfb/Configuration.cxx
index 1c215c7f1..f58a9c2f9 100644
--- a/common/rfb/Configuration.cxx
+++ b/common/rfb/Configuration.cxx
@@ -48,9 +48,9 @@ static LogWriter vlog("Config");
 
 
 // -=- The Global/server/viewer Configuration objects
-Configuration* Configuration::global_ = 0;
-Configuration* Configuration::server_ = 0;
-Configuration* Configuration::viewer_ = 0;
+Configuration* Configuration::global_ = nullptr;
+Configuration* Configuration::server_ = nullptr;
+Configuration* Configuration::viewer_ = nullptr;
 
 Configuration* Configuration::global() {
   if (!global_)
@@ -76,13 +76,13 @@ bool Configuration::set(const char* n, const char* v, bool immutable) {
   return set(n, strlen(n), v, immutable);
 }
 
-bool Configuration::set(const char* name, int len,
+bool Configuration::set(const char* paramName, int len,
                              const char* val, bool immutable)
 {
   VoidParameter* current = head;
   while (current) {
     if ((int)strlen(current->getName()) == len &&
-        strncasecmp(current->getName(), name, len) == 0)
+        strncasecmp(current->getName(), paramName, len) == 0)
     {
       bool b = current->setParam(val);
       if (b && immutable) 
@@ -91,7 +91,7 @@ bool Configuration::set(const char* name, int len,
     }
     current = current->_next;
   }
-  return _next ? _next->set(name, len, val, immutable) : false;
+  return _next ? _next->set(paramName, len, val, immutable) : false;
 }
 
 bool Configuration::set(const char* config, bool immutable) {
@@ -127,7 +127,7 @@ VoidParameter* Configuration::get(const char* param)
       return current;
     current = current->_next;
   }
-  return _next ? _next->get(param) : 0;
+  return _next ? _next->get(param) : nullptr;
 }
 
 void Configuration::list(int width, int nameWidth) {
@@ -195,7 +195,7 @@ VoidParameter::VoidParameter(const char* name_, const char* desc_,
 			     ConfigurationObject co)
   : immutable(false), name(name_), description(desc_)
 {
-  Configuration *conf = NULL;
+  Configuration *conf = nullptr;
 
   switch (co) {
   case ConfGlobal: conf = Configuration::global();
@@ -339,7 +339,7 @@ IntParameter::IntParameter(const char* name_, const char* desc_, int v,
 bool
 IntParameter::setParam(const char* v) {
   if (immutable) return true;
-  return setParam(strtol(v, NULL, 0));
+  return setParam(strtol(v, nullptr, 0));
 }
 
 bool
@@ -410,7 +410,8 @@ StringParameter::operator const char *() const {
 
 BinaryParameter::BinaryParameter(const char* name_, const char* desc_,
 				 const uint8_t* v, size_t l, ConfigurationObject co)
-: VoidParameter(name_, desc_, co), value(0), length(0), def_value(0), def_length(0) {
+: VoidParameter(name_, desc_, co),
+  value(nullptr), length(0), def_value(nullptr), def_length(0) {
   if (l) {
     assert(v);
     value = new uint8_t[l];
@@ -440,7 +441,7 @@ void BinaryParameter::setParam(const uint8_t* v, size_t len) {
   if (immutable) return; 
   vlog.debug("set %s(Binary)", getName());
   delete [] value;
-  value = NULL;
+  value = nullptr;
   length = 0;
   if (len) {
     assert(v);
diff --git a/common/rfb/Configuration.h b/common/rfb/Configuration.h
index d73d80052..ec8d789aa 100644
--- a/common/rfb/Configuration.h
+++ b/common/rfb/Configuration.h
@@ -64,7 +64,8 @@ namespace rfb {
   class Configuration {
   public:
     // - Create a new Configuration object
-    Configuration(const char* name_) : name(name_), head(0), _next(0) {}
+    Configuration(const char* name_)
+      : name(name_), head(nullptr), _next(nullptr) {}
 
     // - Return the buffer containing the Configuration's name
     const char* getName() const { return name.c_str(); }
@@ -195,12 +196,12 @@ namespace rfb {
   public:
     AliasParameter(const char* name_, const char* desc_,VoidParameter* param_,
 		   ConfigurationObject co=ConfGlobal);
-    virtual bool setParam(const char* value);
-    virtual bool setParam();
-    virtual std::string getDefaultStr() const;
-    virtual std::string getValueStr() const;
-    virtual bool isBool() const;
-    virtual void setImmutable();
+    bool setParam(const char* value) override;
+    bool setParam() override;
+    std::string getDefaultStr() const override;
+    std::string getValueStr() const override;
+    bool isBool() const override;
+    void setImmutable() override;
   private:
     VoidParameter* param;
   };
@@ -209,12 +210,12 @@ namespace rfb {
   public:
     BoolParameter(const char* name_, const char* desc_, bool v,
 		  ConfigurationObject co=ConfGlobal);
-    virtual bool setParam(const char* value);
-    virtual bool setParam();
+    bool setParam(const char* value) override;
+    bool setParam() override;
     virtual void setParam(bool b);
-    virtual std::string getDefaultStr() const;
-    virtual std::string getValueStr() const;
-    virtual bool isBool() const;
+    std::string getDefaultStr() const override;
+    std::string getValueStr() const override;
+    bool isBool() const override;
     operator bool() const;
   protected:
     bool value;
@@ -227,10 +228,10 @@ namespace rfb {
                  int minValue=INT_MIN, int maxValue=INT_MAX,
 		 ConfigurationObject co=ConfGlobal);
     using VoidParameter::setParam;
-    virtual bool setParam(const char* value);
+    bool setParam(const char* value) override;
     virtual bool setParam(int v);
-    virtual std::string getDefaultStr() const;
-    virtual std::string getValueStr() const;
+    std::string getDefaultStr() const override;
+    std::string getValueStr() const override;
     operator int() const;
   protected:
     int value;
@@ -244,10 +245,10 @@ namespace rfb {
     // be Null, and so neither can the default value!
     StringParameter(const char* name_, const char* desc_, const char* v,
 		    ConfigurationObject co=ConfGlobal);
-    virtual ~StringParameter();
-    virtual bool setParam(const char* value);
-    virtual std::string getDefaultStr() const;
-    virtual std::string getValueStr() const;
+    ~StringParameter() override;
+    bool setParam(const char* value) override;
+    std::string getDefaultStr() const override;
+    std::string getValueStr() const override;
     operator const char*() const;
   protected:
     std::string value;
@@ -260,11 +261,11 @@ namespace rfb {
                     const uint8_t* v, size_t l,
                     ConfigurationObject co=ConfGlobal);
     using VoidParameter::setParam;
-    virtual ~BinaryParameter();
-    virtual bool setParam(const char* value);
+    ~BinaryParameter() override;
+    bool setParam(const char* value) override;
     virtual void setParam(const uint8_t* v, size_t l);
-    virtual std::string getDefaultStr() const;
-    virtual std::string getValueStr() const;
+    std::string getDefaultStr() const override;
+    std::string getValueStr() const override;
 
     std::vector<uint8_t> getData() const;
 
diff --git a/common/rfb/Congestion.cxx b/common/rfb/Congestion.cxx
index 1e252165e..94f07055d 100644
--- a/common/rfb/Congestion.cxx
+++ b/common/rfb/Congestion.cxx
@@ -85,11 +85,11 @@ Congestion::Congestion() :
     baseRTT(-1), congWindow(INITIAL_WINDOW), inSlowStart(true),
     safeBaseRTT(-1), measurements(0), minRTT(-1), minCongestedRTT(-1)
 {
-  gettimeofday(&lastUpdate, NULL);
-  gettimeofday(&lastSent, NULL);
+  gettimeofday(&lastUpdate, nullptr);
+  gettimeofday(&lastSent, nullptr);
   memset(&lastPong, 0, sizeof(lastPong));
-  gettimeofday(&lastPongArrival, NULL);
-  gettimeofday(&lastAdjustment, NULL);
+  gettimeofday(&lastPongArrival, nullptr);
+  gettimeofday(&lastAdjustment, nullptr);
 }
 
 Congestion::~Congestion()
@@ -101,7 +101,7 @@ void Congestion::updatePosition(unsigned pos)
   struct timeval now;
   unsigned delta, consumed;
 
-  gettimeofday(&now, NULL);
+  gettimeofday(&now, nullptr);
 
   delta = pos - lastPosition;
   if ((delta > 0) || (extraBuffer > 0))
@@ -121,7 +121,7 @@ void Congestion::updatePosition(unsigned pos)
     congWindow = __rfbmin(INITIAL_WINDOW, congWindow);
     baseRTT = -1;
     measurements = 0;
-    gettimeofday(&lastAdjustment, NULL);
+    gettimeofday(&lastAdjustment, nullptr);
     minRTT = minCongestedRTT = -1;
     inSlowStart = true;
   }
@@ -149,7 +149,7 @@ void Congestion::sentPing()
 
   memset(&rttInfo, 0, sizeof(struct RTTInfo));
 
-  gettimeofday(&rttInfo.tv, NULL);
+  gettimeofday(&rttInfo.tv, nullptr);
   rttInfo.pos = lastPosition;
   rttInfo.extra = getExtraBuffer();
   rttInfo.congested = isCongested();
@@ -166,7 +166,7 @@ void Congestion::gotPong()
   if (pings.empty())
     return;
 
-  gettimeofday(&now, NULL);
+  gettimeofday(&now, nullptr);
 
   rttInfo = pings.front();
   pings.pop_front();
@@ -320,7 +320,7 @@ void Congestion::debugTrace(const char* filename, int fd)
 #ifdef __linux__
   FILE *f;
   f = fopen(filename, "ab");
-  if (f != NULL) {
+  if (f != nullptr) {
     struct tcp_info info;
     int buffered;
     socklen_t len;
@@ -329,7 +329,7 @@ void Congestion::debugTrace(const char* filename, int fd)
                     TCP_INFO, &info, &len) == 0) &&
         (ioctl(fd, SIOCOUTQ, &buffered) == 0)) {
       struct timeval now;
-      gettimeofday(&now, NULL);
+      gettimeofday(&now, nullptr);
       fprintf(f, "%u.%06u,%u,%u,%u,%u\n",
               (unsigned)now.tv_sec, (unsigned)now.tv_usec,
               congWindow, info.tcpi_snd_cwnd * info.tcpi_snd_mss,
@@ -494,7 +494,7 @@ void Congestion::updateCongestion()
 #endif
 
   measurements = 0;
-  gettimeofday(&lastAdjustment, NULL);
+  gettimeofday(&lastAdjustment, nullptr);
   minRTT = minCongestedRTT = -1;
 }
 
diff --git a/common/rfb/CopyRectDecoder.h b/common/rfb/CopyRectDecoder.h
index c9f9c8907..516511962 100644
--- a/common/rfb/CopyRectDecoder.h
+++ b/common/rfb/CopyRectDecoder.h
@@ -26,14 +26,15 @@ namespace rfb {
   public:
     CopyRectDecoder();
     virtual ~CopyRectDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void getAffectedRegion(const Rect& rect, const uint8_t* buffer,
-                                   size_t buflen, const ServerParams& server,
-                                   Region* region);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void getAffectedRegion(const Rect& rect, const uint8_t* buffer,
+                           size_t buflen, const ServerParams& server,
+                           Region* region) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
   };
 }
 #endif
diff --git a/common/rfb/Cursor.cxx b/common/rfb/Cursor.cxx
index f0c72eed8..fa596bc5b 100644
--- a/common/rfb/Cursor.cxx
+++ b/common/rfb/Cursor.cxx
@@ -33,11 +33,11 @@ using namespace rfb;
 static LogWriter vlog("Cursor");
 
 Cursor::Cursor(int width, int height, const Point& hotspot,
-               const uint8_t* data) :
+               const uint8_t* data_) :
   width_(width), height_(height), hotspot_(hotspot)
 {
-  this->data = new uint8_t[width_*height_*4];
-  memcpy(this->data, data, width_*height_*4);
+  data = new uint8_t[width_*height_*4];
+  memcpy(data, data_, width_*height_*4);
 }
 
 Cursor::Cursor(const Cursor& other) :
diff --git a/common/rfb/Cursor.h b/common/rfb/Cursor.h
index 31d6fda95..c71f5a77a 100644
--- a/common/rfb/Cursor.h
+++ b/common/rfb/Cursor.h
@@ -62,7 +62,7 @@ namespace rfb {
 
     Rect getEffectiveRect() const { return buffer.getRect(offset); }
 
-    virtual const uint8_t* getBuffer(const Rect& r, int* stride) const;
+    const uint8_t* getBuffer(const Rect& r, int* stride) const override;
 
     void update(PixelBuffer* framebuffer, Cursor* cursor, const Point& pos);
 
diff --git a/common/rfb/DecodeManager.cxx b/common/rfb/DecodeManager.cxx
index e39a39433..ef4158861 100644
--- a/common/rfb/DecodeManager.cxx
+++ b/common/rfb/DecodeManager.cxx
@@ -40,8 +40,8 @@ using namespace rfb;
 
 static LogWriter vlog("DecodeManager");
 
-DecodeManager::DecodeManager(CConnection *conn) :
-  conn(conn), threadException(NULL)
+DecodeManager::DecodeManager(CConnection *conn_) :
+  conn(conn_), threadException(nullptr)
 {
   size_t cpuCount;
 
@@ -97,8 +97,8 @@ DecodeManager::~DecodeManager()
   delete producerCond;
   delete queueMutex;
 
-  for (size_t i = 0; i < sizeof(decoders)/sizeof(decoders[0]); i++)
-    delete decoders[i];
+  for (Decoder* decoder : decoders)
+    delete decoder;
 }
 
 bool DecodeManager::decodeRect(const Rect& r, int encoding,
@@ -110,7 +110,7 @@ bool DecodeManager::decodeRect(const Rect& r, int encoding,
 
   QueueEntry *entry;
 
-  assert(pb != NULL);
+  assert(pb != nullptr);
 
   if (!Decoder::supported(encoding)) {
     vlog.error("Unknown encoding %d", encoding);
@@ -247,7 +247,7 @@ void DecodeManager::setThreadException(const rdr::Exception& e)
 {
   os::AutoMutex a(queueMutex);
 
-  if (threadException != NULL)
+  if (threadException != nullptr)
     return;
 
   threadException = new rdr::Exception("Exception on worker thread: %s", e.str());
@@ -257,23 +257,20 @@ void DecodeManager::throwThreadException()
 {
   os::AutoMutex a(queueMutex);
 
-  if (threadException == NULL)
+  if (threadException == nullptr)
     return;
 
   rdr::Exception e(*threadException);
 
   delete threadException;
-  threadException = NULL;
+  threadException = nullptr;
 
   throw e;
 }
 
-DecodeManager::DecodeThread::DecodeThread(DecodeManager* manager)
+DecodeManager::DecodeThread::DecodeThread(DecodeManager* manager_)
+  : manager(manager_), stopRequested(false)
 {
-  this->manager = manager;
-
-  stopRequested = false;
-
   start();
 }
 
@@ -305,7 +302,7 @@ void DecodeManager::DecodeThread::worker()
 
     // Look for an available entry in the work queue
     entry = findEntry();
-    if (entry == NULL) {
+    if (entry == nullptr) {
       // Wait and try again
       manager->consumerCond->wait();
       continue;
@@ -347,24 +344,15 @@ void DecodeManager::DecodeThread::worker()
 
 DecodeManager::QueueEntry* DecodeManager::DecodeThread::findEntry()
 {
-  std::list<DecodeManager::QueueEntry*>::iterator iter;
   Region lockedRegion;
 
   if (manager->workQueue.empty())
-    return NULL;
+    return nullptr;
 
   if (!manager->workQueue.front()->active)
     return manager->workQueue.front();
 
-  for (iter = manager->workQueue.begin();
-       iter != manager->workQueue.end();
-       ++iter) {
-    DecodeManager::QueueEntry* entry;
-
-    std::list<DecodeManager::QueueEntry*>::iterator iter2;
-
-    entry = *iter;
-
+  for (DecodeManager::QueueEntry* entry : manager->workQueue) {
     // Another thread working on this?
     if (entry->active)
       goto next;
@@ -372,8 +360,10 @@ DecodeManager::QueueEntry* DecodeManager::DecodeThread::findEntry()
     // If this is an ordered decoder then make sure this is the first
     // rectangle in the queue for that decoder
     if (entry->decoder->flags & DecoderOrdered) {
-      for (iter2 = manager->workQueue.begin(); iter2 != iter; ++iter2) {
-        if (entry->encoding == (*iter2)->encoding)
+      for (DecodeManager::QueueEntry* entry2 : manager->workQueue) {
+        if (entry2 == entry)
+          break;
+        if (entry->encoding == entry2->encoding)
           goto next;
       }
     }
@@ -381,15 +371,17 @@ DecodeManager::QueueEntry* DecodeManager::DecodeThread::findEntry()
     // For a partially ordered decoder we must ask the decoder for each
     // pair of rectangles.
     if (entry->decoder->flags & DecoderPartiallyOrdered) {
-      for (iter2 = manager->workQueue.begin(); iter2 != iter; ++iter2) {
-        if (entry->encoding != (*iter2)->encoding)
+      for (DecodeManager::QueueEntry* entry2 : manager->workQueue) {
+        if (entry2 == entry)
+          break;
+        if (entry->encoding != entry2->encoding)
           continue;
         if (entry->decoder->doRectsConflict(entry->rect,
                                             entry->bufferStream->data(),
                                             entry->bufferStream->length(),
-                                            (*iter2)->rect,
-                                            (*iter2)->bufferStream->data(),
-                                            (*iter2)->bufferStream->length(),
+                                            entry2->rect,
+                                            entry2->bufferStream->data(),
+                                            entry2->bufferStream->length(),
                                             *entry->server))
           goto next;
       }
@@ -405,5 +397,5 @@ DecodeManager::QueueEntry* DecodeManager::DecodeThread::findEntry()
     lockedRegion.assign_union(entry->affectedRegion);
   }
 
-  return NULL;
+  return nullptr;
 }
diff --git a/common/rfb/DecodeManager.h b/common/rfb/DecodeManager.h
index a8e0cac9f..5435bfc17 100644
--- a/common/rfb/DecodeManager.h
+++ b/common/rfb/DecodeManager.h
@@ -98,7 +98,7 @@ namespace rfb {
       void stop();
 
     protected:
-      void worker();
+      void worker() override;
       DecodeManager::QueueEntry* findEntry();
 
     private:
diff --git a/common/rfb/Decoder.cxx b/common/rfb/Decoder.cxx
index 78c54ec3c..e9bc9a4ff 100644
--- a/common/rfb/Decoder.cxx
+++ b/common/rfb/Decoder.cxx
@@ -37,7 +37,7 @@
 
 using namespace rfb;
 
-Decoder::Decoder(enum DecoderFlags flags) : flags(flags)
+Decoder::Decoder(enum DecoderFlags flags_) : flags(flags_)
 {
 }
 
@@ -103,6 +103,6 @@ Decoder* Decoder::createDecoder(int encoding)
     return new H264Decoder();
 #endif
   default:
-    return NULL;
+    return nullptr;
   }
 }
diff --git a/common/rfb/EncodeManager.cxx b/common/rfb/EncodeManager.cxx
index c2658a70a..5c1429d2a 100644
--- a/common/rfb/EncodeManager.cxx
+++ b/common/rfb/EncodeManager.cxx
@@ -138,7 +138,7 @@ EncodeManager::EncodeManager(SConnection* conn_)
 {
   StatsVector::iterator iter;
 
-  encoders.resize(encoderClassMax, NULL);
+  encoders.resize(encoderClassMax, nullptr);
   activeEncoders.resize(encoderTypeMax, encoderRaw);
 
   encoders[encoderRaw] = new RawEncoder(conn);
@@ -161,12 +161,10 @@ EncodeManager::EncodeManager(SConnection* conn_)
 
 EncodeManager::~EncodeManager()
 {
-  std::vector<Encoder*>::iterator iter;
-
   logStats();
 
-  for (iter = encoders.begin();iter != encoders.end();iter++)
-    delete *iter;
+  for (Encoder* encoder : encoders)
+    delete encoder;
 }
 
 void EncodeManager::logStats()
@@ -332,7 +330,7 @@ void EncodeManager::doUpdate(bool allowLossy, const Region& changed_,
      * We need to render the cursor seperately as it has its own
      * magical pixel buffer, so split it out from the changed region.
      */
-    if (renderedCursor != NULL) {
+    if (renderedCursor != nullptr) {
       cursorRegion = changed.intersect(renderedCursor->getEffectiveRect());
       changed.assign_subtract(renderedCursor->getEffectiveRect());
     }
diff --git a/common/rfb/EncodeManager.h b/common/rfb/EncodeManager.h
index 33484db8a..a01a1614d 100644
--- a/common/rfb/EncodeManager.h
+++ b/common/rfb/EncodeManager.h
@@ -61,7 +61,7 @@ namespace rfb {
                               size_t maxUpdateSize);
 
   protected:
-    virtual void handleTimeout(Timer* t);
+    void handleTimeout(Timer* t) override;
 
     void doUpdate(bool allowLossy, const Region& changed,
                   const Region& copied, const Point& copy_delta,
@@ -142,7 +142,7 @@ namespace rfb {
                   const uint8_t* data_, int stride);
 
     private:
-      virtual uint8_t* getBufferRW(const Rect& r, int* stride);
+      uint8_t* getBufferRW(const Rect& r, int* stride) override;
     };
 
     OffsetPixelBuffer offsetPixelBuffer;
diff --git a/common/rfb/H264Decoder.cxx b/common/rfb/H264Decoder.cxx
index f18554ef3..53b223db9 100644
--- a/common/rfb/H264Decoder.cxx
+++ b/common/rfb/H264Decoder.cxx
@@ -51,18 +51,18 @@ H264Decoder::~H264Decoder()
 void H264Decoder::resetContexts()
 {
   os::AutoMutex lock(&mutex);
-  for (std::deque<H264DecoderContext*>::iterator it = contexts.begin(); it != contexts.end(); it++)
-    delete *it;
+  for (H264DecoderContext* context : contexts)
+    delete context;
   contexts.clear();
 }
 
 H264DecoderContext* H264Decoder::findContext(const Rect& r)
 {
   os::AutoMutex m(&mutex);
-  for (std::deque<H264DecoderContext*>::iterator it = contexts.begin(); it != contexts.end(); it++)
-    if ((*it)->isEqualRect(r))
-      return *it;
-  return NULL;
+  for (H264DecoderContext* context : contexts)
+    if (context->isEqualRect(r))
+      return context;
+  return nullptr;
 }
 
 bool H264Decoder::readRect(const Rect& /*r*/,
@@ -79,9 +79,9 @@ bool H264Decoder::readRect(const Rect& /*r*/,
 
   len = is->readU32();
   os->writeU32(len);
-  uint32_t flags = is->readU32();
+  uint32_t reset = is->readU32();
 
-  os->writeU32(flags);
+  os->writeU32(reset);
 
   if (!is->hasDataOrRestore(len))
     return false;
@@ -100,15 +100,15 @@ void H264Decoder::decodeRect(const Rect& r, const uint8_t* buffer,
 {
   rdr::MemInStream is(buffer, buflen);
   uint32_t len = is.readU32();
-  uint32_t flags = is.readU32();
+  uint32_t reset = is.readU32();
 
-  H264DecoderContext* ctx = NULL;
-  if (flags & resetAllContexts)
+  H264DecoderContext* ctx = nullptr;
+  if (reset & resetAllContexts)
   {
     resetContexts();
     if (!len)
       return;
-    flags &= ~(resetContext | resetAllContexts);
+    reset &= ~(resetContext | resetAllContexts);
   } else {
     ctx = findContext(r);
   }
diff --git a/common/rfb/H264Decoder.h b/common/rfb/H264Decoder.h
index b4f5553e0..8ba477995 100644
--- a/common/rfb/H264Decoder.h
+++ b/common/rfb/H264Decoder.h
@@ -33,11 +33,12 @@ namespace rfb {
   public:
     H264Decoder();
     virtual ~H264Decoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
 
   private:
     void resetContexts();
diff --git a/common/rfb/H264LibavDecoderContext.cxx b/common/rfb/H264LibavDecoderContext.cxx
index 8697a5a57..5bd1dbbf4 100644
--- a/common/rfb/H264LibavDecoderContext.cxx
+++ b/common/rfb/H264LibavDecoderContext.cxx
@@ -42,9 +42,9 @@ static LogWriter vlog("H264LibavDecoderContext");
 bool H264LibavDecoderContext::initCodec() {
   os::AutoMutex lock(&mutex);
 
-  sws = NULL;
-  swsBuffer = NULL;
-  h264WorkBuffer = NULL;
+  sws = nullptr;
+  swsBuffer = nullptr;
+  h264WorkBuffer = nullptr;
   h264WorkBufferLength = 0;
 
   const AVCodec *codec = avcodec_find_decoder(AV_CODEC_ID_H264);
@@ -78,7 +78,7 @@ bool H264LibavDecoderContext::initCodec() {
     return false;
   }
 
-  if (avcodec_open2(avctx, codec, NULL) < 0)
+  if (avcodec_open2(avctx, codec, nullptr) < 0)
   {
     av_parser_close(parser);
     avcodec_free_context(&avctx);
@@ -117,7 +117,7 @@ uint8_t* H264LibavDecoderContext::makeH264WorkBuffer(const uint8_t* buffer, uint
   if (!h264WorkBuffer || reserve_len > h264WorkBufferLength)
   {
     h264WorkBuffer = (uint8_t*)realloc(h264WorkBuffer, reserve_len);
-    if (h264WorkBuffer == NULL) {
+    if (h264WorkBuffer == nullptr) {
       throw Exception("H264LibavDecoderContext: Unable to allocate memory");
     }
     h264WorkBufferLength = reserve_len;
@@ -204,7 +204,7 @@ void H264LibavDecoderContext::decode(const uint8_t* h264_in_buffer,
 
 #ifdef FFMPEG_INIT_PACKET_DEPRECATED
   packet->size = 0;
-  packet->data = NULL;
+  packet->data = nullptr;
   av_packet_free(&packet);
 #else
   delete packet;
@@ -218,7 +218,7 @@ void H264LibavDecoderContext::decode(const uint8_t* h264_in_buffer,
 
   sws = sws_getCachedContext(sws, frame->width, frame->height, avctx->pix_fmt,
                              frame->width, frame->height, AV_PIX_FMT_RGB32,
-                             0, NULL, NULL, NULL);
+                             0, nullptr, nullptr, nullptr);
 
   int stride;
   pb->getBuffer(rect, &stride);
diff --git a/common/rfb/H264LibavDecoderContext.h b/common/rfb/H264LibavDecoderContext.h
index 148ba1adc..f399b3cc6 100644
--- a/common/rfb/H264LibavDecoderContext.h
+++ b/common/rfb/H264LibavDecoderContext.h
@@ -34,12 +34,12 @@ namespace rfb {
       H264LibavDecoderContext(const Rect &r) : H264DecoderContext(r) {}
       ~H264LibavDecoderContext() { freeCodec(); }
 
-      virtual void decode(const uint8_t* h264_buffer, uint32_t len,
-                          ModifiablePixelBuffer* pb);
+      void decode(const uint8_t* h264_buffer, uint32_t len,
+                  ModifiablePixelBuffer* pb) override;
 
     protected:
-      virtual bool initCodec();
-      virtual void freeCodec();
+      bool initCodec() override;
+      void freeCodec() override;
 
     private:
       uint8_t* makeH264WorkBuffer(const uint8_t* buffer, uint32_t len);
diff --git a/common/rfb/H264WinDecoderContext.cxx b/common/rfb/H264WinDecoderContext.cxx
index bb29edb60..8422b5c4b 100644
--- a/common/rfb/H264WinDecoderContext.cxx
+++ b/common/rfb/H264WinDecoderContext.cxx
@@ -21,7 +21,7 @@
 #include <mfapi.h>
 #include <mferror.h>
 #include <wmcodecdsp.h>
-#define SAFE_RELEASE(obj) if (obj) { obj->Release(); obj = NULL; }
+#define SAFE_RELEASE(obj) if (obj) { obj->Release(); obj = nullptr; }
 
 #include <os/Mutex.h>
 #include <rfb/LogWriter.h>
@@ -32,6 +32,11 @@ using namespace rfb;
 
 static LogWriter vlog("H264WinDecoderContext");
 
+// Older MinGW lacks this definition
+#ifndef HAVE_VIDEO_PROCESSOR_MFT
+static GUID CLSID_VideoProcessorMFT = { 0x88753b26, 0x5b24, 0x49bd, { 0xb2, 0xe7, 0xc, 0x44, 0x5c, 0x78, 0xc9, 0x82 } };
+#endif
+
 bool H264WinDecoderContext::initCodec() {
   os::AutoMutex lock(&mutex);
 
@@ -41,17 +46,16 @@ bool H264WinDecoderContext::initCodec() {
     return false;
   }
 
-  if (FAILED(CoCreateInstance(CLSID_CMSH264DecoderMFT, NULL, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&decoder)))
+  if (FAILED(CoCreateInstance(CLSID_CMSH264DecoderMFT, nullptr, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&decoder)))
   {
     vlog.error("MediaFoundation H264 codec not found");
     return false;
   }
 
-  GUID CLSID_VideoProcessorMFT = { 0x88753b26, 0x5b24, 0x49bd, { 0xb2, 0xe7, 0xc, 0x44, 0x5c, 0x78, 0xc9, 0x82 } };
-  if (FAILED(CoCreateInstance(CLSID_VideoProcessorMFT, NULL, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&converter)))
+  if (FAILED(CoCreateInstance(CLSID_VideoProcessorMFT, nullptr, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&converter)))
   {
     vlog.error("Cannot create MediaFoundation Video Processor (available only on Windows 8+). Trying ColorConvert DMO.");
-    if (FAILED(CoCreateInstance(CLSID_CColorConvertDMO, NULL, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&converter)))
+    if (FAILED(CoCreateInstance(CLSID_CColorConvertDMO, nullptr, CLSCTX_INPROC_SERVER, IID_IMFTransform, (LPVOID*)&converter)))
     {
       decoder->Release();
       vlog.error("ColorConvert DMO not found");
@@ -87,7 +91,7 @@ bool H264WinDecoderContext::initCodec() {
 
   // set decoder output type (NV12)
   DWORD output_index = 0;
-  IMFMediaType* output_type = NULL;
+  IMFMediaType* output_type = nullptr;
   while (SUCCEEDED(decoder->GetOutputAvailableType(0, output_index++, &output_type)))
   {
     GUID subtype;
@@ -175,7 +179,7 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
   }
 
   BYTE* locked;
-  input_buffer->Lock(&locked, NULL, NULL);
+  input_buffer->Lock(&locked, nullptr, nullptr);
   memcpy(locked, h264_buffer, len);
   input_buffer->Unlock();
 
@@ -203,7 +207,7 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
     decoded_data.dwStreamID = 0;
     decoded_data.pSample = decoded_sample;
     decoded_data.dwStatus = 0;
-    decoded_data.pEvents = NULL;
+    decoded_data.pEvents = nullptr;
 
     DWORD status;
     HRESULT hr = decoder->ProcessOutput(0, 1, &decoded_data, &status);
@@ -232,7 +236,7 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
       // need to setup output type and try decoding again
 
       DWORD output_index = 0;
-      IMFMediaType* output_type = NULL;
+      IMFMediaType* output_type = nullptr;
       while (SUCCEEDED(decoder->GetOutputAvailableType(0, output_index++, &output_type)))
       {
         GUID subtype;
@@ -242,7 +246,7 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
           break;
         }
         output_type->Release();
-        output_type = NULL;
+        output_type = nullptr;
       }
 
       // reinitialize output type (NV12) that now has correct properties (width/height/framerate)
@@ -327,7 +331,7 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
     converted_data.dwStreamID = 0;
     converted_data.pSample = converted_sample;
     converted_data.dwStatus = 0;
-    converted_data.pEvents = NULL;
+    converted_data.pEvents = nullptr;
 
     DWORD status;
     HRESULT hr = converter->ProcessOutput(0, 1, &converted_data, &status);
@@ -342,8 +346,8 @@ void H264WinDecoderContext::decode(const uint8_t* h264_buffer,
       vlog.debug("Frame converted to RGB");
 
       BYTE* out;
-      DWORD len;
-      converted_buffer->Lock(&out, NULL, &len);
+      DWORD buflen;
+      converted_buffer->Lock(&out, nullptr, &buflen);
       pb->imageRect(rect, out + offset_y * stride + offset_x * 4, (int)stride / 4);
       converted_buffer->Unlock();
     }
@@ -359,20 +363,20 @@ void H264WinDecoderContext::ParseSPS(const uint8_t* buffer, int length)
     if (available == 0)              \
     {                                \
         if (length == 0) return;     \
-        byte = *buffer++;            \
+        byte_ = *buffer++;            \
         length--;                    \
         available = 8;               \
     }                                \
-    bit = (byte >> --available) & 1; \
+    bit = (byte_ >> --available) & 1; \
 } while (0)
 
 #define GET_BITS(n, var) do {      \
     var = 0;                       \
-    for (int i = n-1; i >= 0; i--) \
+    for (int b = n-1; b >= 0; b--) \
     {                              \
         unsigned bit;              \
         GET_BIT(bit);              \
-        var |= bit << i;           \
+        var |= bit << b;           \
     }                              \
 } while (0)
 
@@ -411,7 +415,7 @@ void H264WinDecoderContext::ParseSPS(const uint8_t* buffer, int length)
     length--;
 
     int available = 0;
-    uint8_t byte = 0;
+    uint8_t byte_ = 0;
 
     unsigned profile_idc;
     unsigned seq_parameter_set_id;
diff --git a/common/rfb/H264WinDecoderContext.h b/common/rfb/H264WinDecoderContext.h
index de51576ce..92041781b 100644
--- a/common/rfb/H264WinDecoderContext.h
+++ b/common/rfb/H264WinDecoderContext.h
@@ -33,12 +33,12 @@ namespace rfb {
       H264WinDecoderContext(const Rect &r) : H264DecoderContext(r) {};
       ~H264WinDecoderContext() { freeCodec(); }
 
-      virtual void decode(const uint8_t* h264_buffer, uint32_t len,
-                          ModifiablePixelBuffer* pb);
+      void decode(const uint8_t* h264_buffer, uint32_t len,
+                  ModifiablePixelBuffer* pb) override;
 
     protected:
-      virtual bool initCodec();
-      virtual void freeCodec();
+      bool initCodec() override;
+      void freeCodec() override;
 
     private:
       LONG stride;
@@ -48,14 +48,14 @@ namespace rfb {
       uint32_t crop_height = 0;
       uint32_t offset_x = 0;
       uint32_t offset_y = 0;
-      IMFTransform *decoder = NULL;
-      IMFTransform *converter = NULL;
-      IMFSample *input_sample = NULL;
-      IMFSample *decoded_sample = NULL;
-      IMFSample *converted_sample = NULL;
-      IMFMediaBuffer *input_buffer = NULL;
-      IMFMediaBuffer *decoded_buffer = NULL;
-      IMFMediaBuffer *converted_buffer = NULL;
+      IMFTransform *decoder = nullptr;
+      IMFTransform *converter = nullptr;
+      IMFSample *input_sample = nullptr;
+      IMFSample *decoded_sample = nullptr;
+      IMFSample *converted_sample = nullptr;
+      IMFMediaBuffer *input_buffer = nullptr;
+      IMFMediaBuffer *decoded_buffer = nullptr;
+      IMFMediaBuffer *converted_buffer = nullptr;
 
       void ParseSPS(const uint8_t* buffer, int length);
   };
diff --git a/common/rfb/HextileDecoder.cxx b/common/rfb/HextileDecoder.cxx
index 2243d67fd..dc9b9be72 100644
--- a/common/rfb/HextileDecoder.cxx
+++ b/common/rfb/HextileDecoder.cxx
@@ -191,10 +191,10 @@ void HextileDecoder::hextileDecode(const Rect& r, rdr::InStream* is,
           if (x + w > 16 || y + h > 16) {
             throw rfb::Exception("HEXTILE_DECODE: Hextile out of bounds");
           }
-          T* ptr = buf + y * t.width() + x;
+          ptr = buf + y * t.width() + x;
           int rowAdd = t.width() - w;
           while (h-- > 0) {
-            int len = w;
+            len = w;
             while (len-- > 0) *ptr++ = fg;
             ptr += rowAdd;
           }
diff --git a/common/rfb/HextileDecoder.h b/common/rfb/HextileDecoder.h
index 9163b5bb8..38e8b776e 100644
--- a/common/rfb/HextileDecoder.h
+++ b/common/rfb/HextileDecoder.h
@@ -29,11 +29,12 @@ namespace rfb {
   public:
     HextileDecoder();
     virtual ~HextileDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
   private:
     template<class T>
     inline T readPixel(rdr::InStream* is);
diff --git a/common/rfb/HextileEncoder.cxx b/common/rfb/HextileEncoder.cxx
index a63cf1fb1..0666d02d9 100644
--- a/common/rfb/HextileEncoder.cxx
+++ b/common/rfb/HextileEncoder.cxx
@@ -38,8 +38,8 @@ BoolParameter improvedHextile("ImprovedHextile",
                               "ratios by the cost of using more CPU time",
                               true);
 
-HextileEncoder::HextileEncoder(SConnection* conn) :
-  Encoder(conn, encodingHextile, EncoderPlain)
+HextileEncoder::HextileEncoder(SConnection* conn_) :
+  Encoder(conn_, encodingHextile, EncoderPlain)
 {
 }
 
@@ -365,7 +365,7 @@ class HextileTile {
 
 template<class T>
 HextileTile<T>::HextileTile()
-  : m_tile(NULL), m_width(0), m_height(0),
+  : m_tile(nullptr), m_width(0), m_height(0),
     m_size(0), m_flags(0), m_background(0), m_foreground(0),
     m_numSubrects(0)
 {
diff --git a/common/rfb/HextileEncoder.h b/common/rfb/HextileEncoder.h
index 20721b7c9..55f0508df 100644
--- a/common/rfb/HextileEncoder.h
+++ b/common/rfb/HextileEncoder.h
@@ -27,11 +27,11 @@ namespace rfb {
   public:
     HextileEncoder(SConnection* conn);
     virtual ~HextileEncoder();
-    virtual bool isSupported();
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    bool isSupported() override;
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
   private:
     template<class T>
     inline void writePixel(rdr::OutStream* os, T pixel);
diff --git a/common/rfb/Hostname.h b/common/rfb/Hostname.h
index 1971e3431..a09cca3f5 100644
--- a/common/rfb/Hostname.h
+++ b/common/rfb/Hostname.h
@@ -29,7 +29,7 @@
 namespace rfb {
 
   static bool isAllSpace(const char *string) {
-    if (string == NULL)
+    if (string == nullptr)
       return false;
     while(*string != '\0') {
       if (! isspace(*string))
@@ -46,7 +46,7 @@ namespace rfb {
     const char* hostEnd;
     const char* portStart;
 
-    if (hi == NULL)
+    if (hi == nullptr)
       throw rdr::Exception("NULL host specified");
 
     // Trim leading whitespace
@@ -59,19 +59,19 @@ namespace rfb {
     if (hi[0] == '[') {
       hostStart = &hi[1];
       hostEnd = strchr(hostStart, ']');
-      if (hostEnd == NULL)
+      if (hostEnd == nullptr)
         throw rdr::Exception("unmatched [ in host");
 
       portStart = hostEnd + 1;
       if (isAllSpace(portStart))
-        portStart = NULL;
+        portStart = nullptr;
     } else {
       hostStart = &hi[0];
       hostEnd = strrchr(hostStart, ':');
 
-      if (hostEnd == NULL) {
+      if (hostEnd == nullptr) {
         hostEnd = hostStart + strlen(hostStart);
-        portStart = NULL;
+        portStart = nullptr;
       } else {
         if ((hostEnd > hostStart) && (hostEnd[-1] == ':'))
           hostEnd--;
@@ -79,7 +79,7 @@ namespace rfb {
         if (portStart != hostEnd) {
           // We found more : in the host. This is probably an IPv6 address
           hostEnd = hostStart + strlen(hostStart);
-          portStart = NULL;
+          portStart = nullptr;
         }
       }
     }
@@ -93,7 +93,7 @@ namespace rfb {
     else
       *host = std::string(hostStart, hostEnd - hostStart);
 
-    if (portStart == NULL)
+    if (portStart == nullptr)
       *port = basePort;
     else {
       char* end;
diff --git a/common/rfb/JpegCompressor.cxx b/common/rfb/JpegCompressor.cxx
index a4dd5f393..42d5c475b 100644
--- a/common/rfb/JpegCompressor.cxx
+++ b/common/rfb/JpegCompressor.cxx
@@ -162,9 +162,9 @@ void JpegCompressor::compress(const uint8_t *buf, volatile int stride,
   int w = r.width();
   int h = r.height();
   int pixelsize;
-  uint8_t * volatile srcBuf = NULL;
+  uint8_t * volatile srcBuf = nullptr;
   volatile bool srcBufIsTemp = false;
-  JSAMPROW * volatile rowPointer = NULL;
+  JSAMPROW * volatile rowPointer = nullptr;
 
   if(setjmp(err->jmpBuffer)) {
     // this will execute if libjpeg has an error
diff --git a/common/rfb/JpegDecompressor.cxx b/common/rfb/JpegDecompressor.cxx
index 44c54fb23..92ef014fa 100644
--- a/common/rfb/JpegDecompressor.cxx
+++ b/common/rfb/JpegDecompressor.cxx
@@ -159,9 +159,9 @@ void JpegDecompressor::decompress(const uint8_t *jpegBuf,
   int h = r.height();
   int pixelsize;
   int dstBufStride;
-  uint8_t * volatile dstBuf = NULL;
+  uint8_t * volatile dstBuf = nullptr;
   volatile bool dstBufIsTemp = false;
-  JSAMPROW * volatile rowPointer = NULL;
+  JSAMPROW * volatile rowPointer = nullptr;
 
   if(setjmp(err->jmpBuffer)) {
     // this will execute if libjpeg has an error
diff --git a/common/rfb/KeyRemapper.cxx b/common/rfb/KeyRemapper.cxx
index 762eb413c..328955d7a 100644
--- a/common/rfb/KeyRemapper.cxx
+++ b/common/rfb/KeyRemapper.cxx
@@ -89,7 +89,7 @@ class KeyMapParameter : public StringParameter {
     : StringParameter("RemapKeys", "Comma-separated list of incoming keysyms to remap.  Mappings are expressed as two hex values, prefixed by 0x, and separated by ->", "") {
     KeyRemapper::defInstance.setMapping("");
   }
-  bool setParam(const char* v) {
+  bool setParam(const char* v) override {
     KeyRemapper::defInstance.setMapping(v);
     return StringParameter::setParam(v);
   }
diff --git a/common/rfb/LogWriter.cxx b/common/rfb/LogWriter.cxx
index dc9db9d1a..b222d268a 100644
--- a/common/rfb/LogWriter.cxx
+++ b/common/rfb/LogWriter.cxx
@@ -34,7 +34,8 @@ rfb::LogParameter rfb::logParams;
 using namespace rfb;
 
 
-LogWriter::LogWriter(const char* name) : m_name(name), m_level(0), m_log(0), m_next(log_writers) {
+LogWriter::LogWriter(const char* name)
+  : m_name(name), m_level(0), m_log(nullptr), m_next(log_writers) {
   log_writers = this;
 }
 
@@ -72,7 +73,7 @@ LogWriter::getLogWriter(const char* name) {
     if (strcasecmp(name, current->m_name) == 0) return current;
       current = current->m_next;
     }
-  return 0;
+  return nullptr;
 }
 
 bool LogWriter::setLogParams(const char* params) {
@@ -83,7 +84,7 @@ bool LogWriter::setLogParams(const char* params) {
     return false;
   }
   int level = atoi(parts[2].c_str());
-  Logger* logger = 0;
+  Logger* logger = nullptr;
   if (!parts[1].empty()) {
     logger = Logger::getLogger(parts[1].c_str());
     if (!logger)
diff --git a/common/rfb/LogWriter.h b/common/rfb/LogWriter.h
index 6eff6da10..d1fd49904 100644
--- a/common/rfb/LogWriter.h
+++ b/common/rfb/LogWriter.h
@@ -104,7 +104,7 @@ namespace rfb {
   class LogParameter : public StringParameter {
   public:
     LogParameter();
-    virtual bool setParam(const char* v);
+    bool setParam(const char* v) override;
   };
   extern LogParameter logParams;
 
diff --git a/common/rfb/Logger.cxx b/common/rfb/Logger.cxx
index 7e0895e44..25f7ccb7c 100644
--- a/common/rfb/Logger.cxx
+++ b/common/rfb/Logger.cxx
@@ -31,9 +31,11 @@
 
 using namespace rfb;
 
-Logger* Logger::loggers = 0;
+Logger* Logger::loggers = nullptr;
 
-Logger::Logger(const char* name) : registered(false), m_name(name), m_next(0) {
+Logger::Logger(const char* name)
+  : registered(false), m_name(name), m_next(nullptr)
+{
 }
 
 Logger::~Logger() {
@@ -78,7 +80,7 @@ Logger::getLogger(const char* name) {
     if (strcasecmp(name, current->m_name) == 0) return current;
     current = current->m_next;
   }
-  return 0;
+  return nullptr;
 }
 
 void
diff --git a/common/rfb/Logger_file.cxx b/common/rfb/Logger_file.cxx
index 099a35011..eabe420a4 100644
--- a/common/rfb/Logger_file.cxx
+++ b/common/rfb/Logger_file.cxx
@@ -33,7 +33,7 @@
 using namespace rfb;
 
 Logger_File::Logger_File(const char* loggerName)
-  : Logger(loggerName), indent(13), width(79), m_file(0),
+  : Logger(loggerName), indent(13), width(79), m_file(nullptr),
     m_lastLogTime(0)
 {
   m_filename[0] = '\0';
@@ -65,7 +65,7 @@ void Logger_File::write(int /*level*/, const char *logname, const char *message)
     if (!m_file) return;
   }
 
-  time_t current = time(0);
+  time_t current = time(nullptr);
   if (current != m_lastLogTime) {
     m_lastLogTime = current;
     fprintf(m_file, "\n%s", ctime(&m_lastLogTime));
@@ -115,7 +115,7 @@ void Logger_File::closeFile()
 {
   if (m_file) {
     fclose(m_file);
-    m_file = 0;
+    m_file = nullptr;
   }
 }
 
diff --git a/common/rfb/Logger_file.h b/common/rfb/Logger_file.h
index 4542d23ce..6f2a4ef65 100644
--- a/common/rfb/Logger_file.h
+++ b/common/rfb/Logger_file.h
@@ -35,7 +35,7 @@ namespace rfb {
     Logger_File(const char* loggerName);
     ~Logger_File();
 
-    virtual void write(int level, const char *logname, const char *message);
+    void write(int level, const char *logname, const char *message) override;
     void setFilename(const char* filename);
     void setFile(FILE* file);
 
diff --git a/common/rfb/Logger_syslog.cxx b/common/rfb/Logger_syslog.cxx
index 320ab4b0e..de9e425e2 100644
--- a/common/rfb/Logger_syslog.cxx
+++ b/common/rfb/Logger_syslog.cxx
@@ -35,7 +35,7 @@ using namespace rfb;
 Logger_Syslog::Logger_Syslog(const char* loggerName)
   : Logger(loggerName)
 {
-  openlog(0, LOG_CONS | LOG_PID, LOG_USER);
+  openlog(nullptr, LOG_CONS | LOG_PID, LOG_USER);
 }
 
 Logger_Syslog::~Logger_Syslog()
diff --git a/common/rfb/Logger_syslog.h b/common/rfb/Logger_syslog.h
index cf987281b..20c46a5f6 100644
--- a/common/rfb/Logger_syslog.h
+++ b/common/rfb/Logger_syslog.h
@@ -31,7 +31,7 @@ namespace rfb {
     Logger_Syslog(const char* loggerName);
     virtual ~Logger_Syslog();
 
-    virtual void write(int level, const char *logname, const char *message);
+    void write(int level, const char *logname, const char *message) override;
   };
 
   void initSyslogLogger();
diff --git a/common/rfb/Palette.h b/common/rfb/Palette.h
index 6b8cc57e5..d22af0dcc 100644
--- a/common/rfb/Palette.h
+++ b/common/rfb/Palette.h
@@ -75,10 +75,10 @@ inline bool rfb::Palette::insert(uint32_t colour, int numPixels)
   hash_key = genHash(colour);
 
   pnode = hash[hash_key];
-  prev_pnode = NULL;
+  prev_pnode = nullptr;
 
   // Do we already have an entry for this colour?
-  while (pnode != NULL) {
+  while (pnode != nullptr) {
     if (pnode->colour == colour) {
       // Yup
 
@@ -114,12 +114,12 @@ inline bool rfb::Palette::insert(uint32_t colour, int numPixels)
 
   // Create a new colour entry
   pnode = &list[numColours];
-  pnode->next = NULL;
+  pnode->next = nullptr;
   pnode->idx = 0;
   pnode->colour = colour;
 
   // Add it to the hash table
-  if (prev_pnode != NULL)
+  if (prev_pnode != nullptr)
     prev_pnode->next = pnode;
   else
     hash[hash_key] = pnode;
@@ -152,7 +152,7 @@ inline unsigned char rfb::Palette::lookup(uint32_t colour) const
   hash_key = genHash(colour);
   pnode = hash[hash_key];
 
-  while (pnode != NULL) {
+  while (pnode != nullptr) {
     if (pnode->colour == colour)
       return pnode->idx;
     pnode = pnode->next;
diff --git a/common/rfb/PixelBuffer.cxx b/common/rfb/PixelBuffer.cxx
index c8b5f3d7c..f1354a437 100644
--- a/common/rfb/PixelBuffer.cxx
+++ b/common/rfb/PixelBuffer.cxx
@@ -326,7 +326,7 @@ FullFramePixelBuffer::FullFramePixelBuffer(const PixelFormat& pf, int w, int h,
 {
 }
 
-FullFramePixelBuffer::FullFramePixelBuffer() : data(0) {}
+FullFramePixelBuffer::FullFramePixelBuffer() : data(nullptr) {}
 
 FullFramePixelBuffer::~FullFramePixelBuffer() {}
 
@@ -365,7 +365,7 @@ void FullFramePixelBuffer::setBuffer(int width, int height,
     throw rfb::Exception("Invalid PixelBuffer height of %d pixels requested", height);
   if ((stride_ < 0) || (stride_ > maxPixelBufferStride) || (stride_ < width))
     throw rfb::Exception("Invalid PixelBuffer stride of %d pixels requested", stride_);
-  if ((width != 0) && (height != 0) && (data_ == NULL))
+  if ((width != 0) && (height != 0) && (data_ == nullptr))
     throw rfb::Exception("PixelBuffer requested without a valid memory area");
 
   ModifiablePixelBuffer::setSize(width, height);
@@ -383,12 +383,12 @@ void FullFramePixelBuffer::setSize(int /*w*/, int /*h*/)
 // Automatically allocates enough space for the specified format & area
 
 ManagedPixelBuffer::ManagedPixelBuffer()
-  : data_(NULL), datasize(0)
+  : data_(nullptr), datasize(0)
 {
 }
 
 ManagedPixelBuffer::ManagedPixelBuffer(const PixelFormat& pf, int w, int h)
-  : FullFramePixelBuffer(pf, 0, 0, NULL, 0), data_(NULL), datasize(0)
+  : FullFramePixelBuffer(pf, 0, 0, nullptr, 0), data_(nullptr), datasize(0)
 {
   setSize(w, h);
 }
@@ -413,7 +413,7 @@ void ManagedPixelBuffer::setSize(int w, int h)
   if (datasize < new_datasize) {
     if (data_) {
       delete [] data_;
-      data_ = NULL;
+      data_ = nullptr;
       datasize = 0;
     }
     if (new_datasize) {
diff --git a/common/rfb/PixelBuffer.h b/common/rfb/PixelBuffer.h
index 33a9c7ae9..963fbbf6a 100644
--- a/common/rfb/PixelBuffer.h
+++ b/common/rfb/PixelBuffer.h
@@ -151,16 +151,16 @@ namespace rfb {
     virtual ~FullFramePixelBuffer();
 
   public:
-    virtual const uint8_t* getBuffer(const Rect& r, int* stride) const;
-    virtual uint8_t* getBufferRW(const Rect& r, int* stride);
-    virtual void commitBufferRW(const Rect& r);
+    const uint8_t* getBuffer(const Rect& r, int* stride) const override;
+    uint8_t* getBufferRW(const Rect& r, int* stride) override;
+    void commitBufferRW(const Rect& r) override;
 
   protected:
     FullFramePixelBuffer();
     virtual void setBuffer(int width, int height, uint8_t* data, int stride);
 
   private:
-    virtual void setSize(int w, int h);
+    void setSize(int w, int h) override;
 
   private:
     uint8_t* data;
@@ -178,7 +178,7 @@ namespace rfb {
 
     // Manage the pixel buffer layout
     virtual void setPF(const PixelFormat &pf);
-    virtual void setSize(int w, int h);
+    void setSize(int w, int h) override;
 
   private:
     uint8_t* data_; // Mirrors FullFramePixelBuffer::data
diff --git a/common/rfb/RREDecoder.h b/common/rfb/RREDecoder.h
index a1d7f9b8a..8490146c7 100644
--- a/common/rfb/RREDecoder.h
+++ b/common/rfb/RREDecoder.h
@@ -29,11 +29,12 @@ namespace rfb {
   public:
     RREDecoder();
     virtual ~RREDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
   private:
     template<class T>
     inline T readPixel(rdr::InStream* is);
diff --git a/common/rfb/RREEncoder.cxx b/common/rfb/RREEncoder.cxx
index e73a23bfc..f3e3b68a9 100644
--- a/common/rfb/RREEncoder.cxx
+++ b/common/rfb/RREEncoder.cxx
@@ -31,8 +31,8 @@
 
 using namespace rfb;
 
-RREEncoder::RREEncoder(SConnection* conn) :
-  Encoder(conn, encodingRRE, EncoderPlain)
+RREEncoder::RREEncoder(SConnection* conn_) :
+  Encoder(conn_, encodingRRE, EncoderPlain)
 {
 }
 
diff --git a/common/rfb/RREEncoder.h b/common/rfb/RREEncoder.h
index b13135b48..e21586ec3 100644
--- a/common/rfb/RREEncoder.h
+++ b/common/rfb/RREEncoder.h
@@ -29,11 +29,11 @@ namespace rfb {
   public:
     RREEncoder(SConnection* conn);
     virtual ~RREEncoder();
-    virtual bool isSupported();
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    bool isSupported() override;
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
   private:
     template<class T>
     inline void writePixel(rdr::OutStream* os, T pixel);
diff --git a/common/rfb/RawDecoder.h b/common/rfb/RawDecoder.h
index 33948ced4..2ac8b0bd4 100644
--- a/common/rfb/RawDecoder.h
+++ b/common/rfb/RawDecoder.h
@@ -25,11 +25,12 @@ namespace rfb {
   public:
     RawDecoder();
     virtual ~RawDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
   };
 }
 #endif
diff --git a/common/rfb/RawEncoder.cxx b/common/rfb/RawEncoder.cxx
index 2fa1af363..eff8999d1 100644
--- a/common/rfb/RawEncoder.cxx
+++ b/common/rfb/RawEncoder.cxx
@@ -29,8 +29,8 @@
 
 using namespace rfb;
 
-RawEncoder::RawEncoder(SConnection* conn) :
-  Encoder(conn, encodingRaw, EncoderPlain)
+RawEncoder::RawEncoder(SConnection* conn_) :
+  Encoder(conn_, encodingRaw, EncoderPlain)
 {
 }
 
diff --git a/common/rfb/RawEncoder.h b/common/rfb/RawEncoder.h
index 76da4c5b8..e191645ce 100644
--- a/common/rfb/RawEncoder.h
+++ b/common/rfb/RawEncoder.h
@@ -27,11 +27,11 @@ namespace rfb {
   public:
     RawEncoder(SConnection* conn);
     virtual ~RawEncoder();
-    virtual bool isSupported();
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    bool isSupported() override;
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
   };
 }
 #endif
diff --git a/common/rfb/SConnection.cxx b/common/rfb/SConnection.cxx
index 12ba0f1ab..866d19a2c 100644
--- a/common/rfb/SConnection.cxx
+++ b/common/rfb/SConnection.cxx
@@ -23,6 +23,9 @@
 
 #include <stdio.h>
 #include <string.h>
+
+#include <algorithm>
+
 #include <rfb/Exception.h>
 #include <rfb/Security.h>
 #include <rfb/clipboardTypes.h>
@@ -43,12 +46,12 @@ using namespace rfb;
 
 static LogWriter vlog("SConnection");
 
-SConnection::SConnection(AccessRights accessRights)
-  : readyForSetColourMapEntries(false),
-    is(0), os(0), reader_(0), writer_(0), ssecurity(0),
+SConnection::SConnection(AccessRights accessRights_)
+  : readyForSetColourMapEntries(false), is(nullptr), os(nullptr),
+    reader_(nullptr), writer_(nullptr), ssecurity(nullptr),
     authFailureTimer(this, &SConnection::handleAuthFailureTimeout),
     state_(RFBSTATE_UNINITIALISED), preferredEncoding(encodingRaw),
-    accessRights(accessRights), hasRemoteClipboard(false),
+    accessRights(accessRights_), hasRemoteClipboard(false),
     hasLocalClipboard(false),
     unsolicitedClipboardAttempt(false)
 {
@@ -206,12 +209,10 @@ void SConnection::processSecurityType(int secType)
 {
   // Verify that the requested security type should be offered
   std::list<uint8_t> secTypes;
-  std::list<uint8_t>::iterator i;
 
   secTypes = security.GetEnabledSecTypes();
-  for (i=secTypes.begin(); i!=secTypes.end(); i++)
-    if (*i == secType) break;
-  if (i == secTypes.end())
+  if (std::find(secTypes.begin(), secTypes.end(),
+                secType) == secTypes.end())
     throw Exception("Requested security type not available");
 
   vlog.info("Client requests security type %s(%d)",
@@ -586,7 +587,7 @@ void SConnection::sendClipboardData(const char* data)
     // FIXME: This conversion magic should be in SMsgWriter
     std::string filtered(convertCRLF(data));
     size_t sizes[1] = { filtered.size() + 1 };
-    const uint8_t* data[1] = { (const uint8_t*)filtered.c_str() };
+    const uint8_t* datas[1] = { (const uint8_t*)filtered.c_str() };
 
     if (unsolicitedClipboardAttempt) {
       unsolicitedClipboardAttempt = false;
@@ -598,7 +599,7 @@ void SConnection::sendClipboardData(const char* data)
       }
     }
 
-    writer()->writeClipboardProvide(rfb::clipboardUTF8, sizes, data);
+    writer()->writeClipboardProvide(rfb::clipboardUTF8, sizes, datas);
   } else {
     writer()->writeServerCutText(data);
   }
@@ -607,11 +608,11 @@ void SConnection::sendClipboardData(const char* data)
 void SConnection::cleanup()
 {
   delete ssecurity;
-  ssecurity = NULL;
+  ssecurity = nullptr;
   delete reader_;
-  reader_ = NULL;
+  reader_ = nullptr;
   delete writer_;
-  writer_ = NULL;
+  writer_ = nullptr;
 }
 
 void SConnection::writeFakeColourMap(void)
diff --git a/common/rfb/SConnection.h b/common/rfb/SConnection.h
index 5bc616776..2ac532693 100644
--- a/common/rfb/SConnection.h
+++ b/common/rfb/SConnection.h
@@ -71,7 +71,7 @@ namespace rfb {
     // later, after queryConnection() has returned.  It can only be called when
     // in state RFBSTATE_QUERYING.  On rejection, an AuthFailureException is
     // thrown, so this must be handled appropriately by the caller.
-    void approveConnection(bool accept, const char* reason=0);
+    void approveConnection(bool accept, const char* reason=nullptr);
 
 
     // Methods to terminate the connection
@@ -83,18 +83,17 @@ namespace rfb {
 
     // Overridden from SMsgHandler
 
-    virtual void setEncodings(int nEncodings, const int32_t* encodings);
+    void setEncodings(int nEncodings, const int32_t* encodings) override;
 
-    virtual void clientCutText(const char* str);
+    void clientCutText(const char* str) override;
 
-    virtual void handleClipboardRequest(uint32_t flags);
-    virtual void handleClipboardPeek();
-    virtual void handleClipboardNotify(uint32_t flags);
-    virtual void handleClipboardProvide(uint32_t flags,
-                                        const size_t* lengths,
-                                        const uint8_t* const* data);
+    void handleClipboardRequest(uint32_t flags) override;
+    void handleClipboardPeek() override;
+    void handleClipboardNotify(uint32_t flags) override;
+    void handleClipboardProvide(uint32_t flags, const size_t* lengths,
+                                const uint8_t* const* data) override;
 
-    virtual void supportsQEMUKeyEvent();
+    void supportsQEMUKeyEvent() override;
 
 
     // Methods to be overridden in a derived class
@@ -118,27 +117,27 @@ namespace rfb {
 
     // clientInit() is called when the ClientInit message is received.  The
     // derived class must call on to SConnection::clientInit().
-    virtual void clientInit(bool shared);
+    void clientInit(bool shared) override;
 
     // setPixelFormat() is called when a SetPixelFormat message is received.
     // The derived class must call on to SConnection::setPixelFormat().
-    virtual void setPixelFormat(const PixelFormat& pf);
+    void setPixelFormat(const PixelFormat& pf) override;
 
     // framebufferUpdateRequest() is called when a FramebufferUpdateRequest
     // message is received.  The derived class must call on to
     // SConnection::framebufferUpdateRequest().
-    virtual void framebufferUpdateRequest(const Rect& r, bool incremental);
+    void framebufferUpdateRequest(const Rect& r, bool incremental) override;
 
     // fence() is called when we get a fence request or response. By default
     // it responds directly to requests (stating it doesn't support any
     // synchronisation) and drops responses. Override to implement more proper
     // support.
-    virtual void fence(uint32_t flags, unsigned len, const uint8_t data[]);
+    void fence(uint32_t flags, unsigned len, const uint8_t data[]) override;
 
     // enableContinuousUpdates() is called when the client wants to enable
     // or disable continuous updates, or change the active area.
-    virtual void enableContinuousUpdates(bool enable,
-                                         int x, int y, int w, int h);
+    void enableContinuousUpdates(bool enable,
+                                 int x, int y, int w, int h) override;
 
     // handleClipboardRequest() is called whenever the client requests
     // the server to send over its clipboard data. It will only be
diff --git a/common/rfb/SDesktop.h b/common/rfb/SDesktop.h
index 94e4b0286..94fcaa28e 100644
--- a/common/rfb/SDesktop.h
+++ b/common/rfb/SDesktop.h
@@ -124,14 +124,18 @@ namespace rfb {
   //     a plain black desktop of the specified format.
   class SStaticDesktop : public SDesktop {
   public:
-    SStaticDesktop(const Point& size) : server(0), buffer(0) {
+    SStaticDesktop(const Point& size)
+      : server(nullptr), buffer(nullptr)
+    {
       PixelFormat pf;
       const uint8_t black[4] = { 0, 0, 0, 0 };
       buffer = new ManagedPixelBuffer(pf, size.x, size.y);
       if (buffer)
         buffer->fillRect(buffer->getRect(), black);
     }
-    SStaticDesktop(const Point& size, const PixelFormat& pf) : buffer(0) {
+    SStaticDesktop(const Point& size, const PixelFormat& pf)
+      : buffer(nullptr)
+    {
       const uint8_t black[4] = { 0, 0, 0, 0 };
       buffer = new ManagedPixelBuffer(pf, size.x, size.y);
       if (buffer)
@@ -141,13 +145,13 @@ namespace rfb {
       if (buffer) delete buffer;
     }
 
-    virtual void init(VNCServer* vs) {
+    void init(VNCServer* vs) override {
       server = vs;
       server->setPixelBuffer(buffer);
     }
-    virtual void queryConnection(network::Socket* sock,
-                                 const char* /*userName*/) {
-      server->approveConnection(sock, true, NULL);
+    void queryConnection(network::Socket* sock,
+                         const char* /*userName*/) override {
+      server->approveConnection(sock, true, nullptr);
     }
 
   protected:
diff --git a/common/rfb/SMsgReader.cxx b/common/rfb/SMsgReader.cxx
index 0792639a2..9ddea53df 100644
--- a/common/rfb/SMsgReader.cxx
+++ b/common/rfb/SMsgReader.cxx
@@ -418,7 +418,7 @@ bool SMsgReader::readExtendedClipboard(int32_t len)
     }
 
     zis.flushUnderlying();
-    zis.setUnderlying(NULL, 0);
+    zis.setUnderlying(nullptr, 0);
 
     handler->handleClipboardProvide(flags, lengths, buffers);
 
diff --git a/common/rfb/SMsgWriter.cxx b/common/rfb/SMsgWriter.cxx
index 8592e6f4b..0c03b51dc 100644
--- a/common/rfb/SMsgWriter.cxx
+++ b/common/rfb/SMsgWriter.cxx
@@ -93,7 +93,7 @@ void SMsgWriter::writeBell()
 
 void SMsgWriter::writeServerCutText(const char* str)
 {
-  if (strchr(str, '\r') != NULL)
+  if (strchr(str, '\r') != nullptr)
     throw Exception("Invalid carriage return in clipboard data");
 
   std::string latin1(utf8ToLatin1(str));
@@ -508,10 +508,9 @@ void SMsgWriter::writeNoDataRects()
 {
   if (!extendedDesktopSizeMsgs.empty()) {
     if (client->supportsEncoding(pseudoEncodingExtendedDesktopSize)) {
-      std::list<ExtendedDesktopSizeMsg>::const_iterator ri;
-      for (ri = extendedDesktopSizeMsgs.begin();ri != extendedDesktopSizeMsgs.end();++ri) {
+      for (ExtendedDesktopSizeMsg msg : extendedDesktopSizeMsgs) {
         // FIXME: We can probably skip multiple reasonServer entries
-        writeExtendedDesktopSizeRect(ri->reason, ri->result,
+        writeExtendedDesktopSizeRect(msg.reason, msg.result,
                                      client->width(), client->height(),
                                      client->screenLayout());
       }
diff --git a/common/rfb/SSecurityNone.h b/common/rfb/SSecurityNone.h
index f14d83a4b..a10b43697 100644
--- a/common/rfb/SSecurityNone.h
+++ b/common/rfb/SSecurityNone.h
@@ -28,10 +28,10 @@ namespace rfb {
 
   class SSecurityNone : public SSecurity {
   public:
-    SSecurityNone(SConnection* sc) : SSecurity(sc) {}
-    virtual bool processMsg() { return true; }
-    virtual int getType() const {return secTypeNone;}
-    virtual const char* getUserName() const {return 0;}
+    SSecurityNone(SConnection* sc_) : SSecurity(sc_) {}
+    bool processMsg() override { return true; }
+    int getType() const override {return secTypeNone;}
+    const char* getUserName() const override {return nullptr;}
   };
 }
 #endif
diff --git a/common/rfb/SSecurityPlain.cxx b/common/rfb/SSecurityPlain.cxx
index a100a7570..73a21335d 100644
--- a/common/rfb/SSecurityPlain.cxx
+++ b/common/rfb/SSecurityPlain.cxx
@@ -68,14 +68,14 @@ bool PasswordValidator::validUser(const char* username)
   return false;
 }
 
-SSecurityPlain::SSecurityPlain(SConnection* sc) : SSecurity(sc)
+SSecurityPlain::SSecurityPlain(SConnection* sc_) : SSecurity(sc_)
 {
 #ifdef WIN32
   valid = new WinPasswdValidator();
 #elif !defined(__APPLE__)
   valid = new UnixPasswordValidator();
 #else
-  valid = NULL;
+  valid = nullptr;
 #endif
 
   state = 0;
diff --git a/common/rfb/SSecurityPlain.h b/common/rfb/SSecurityPlain.h
index 4ca727815..c0ac049b0 100644
--- a/common/rfb/SSecurityPlain.h
+++ b/common/rfb/SSecurityPlain.h
@@ -43,9 +43,9 @@ namespace rfb {
   class SSecurityPlain : public SSecurity {
   public:
     SSecurityPlain(SConnection* sc);
-    virtual bool processMsg();
-    virtual int getType() const { return secTypePlain; };
-    virtual const char* getUserName() const { return username; }
+    bool processMsg() override;
+    int getType() const override { return secTypePlain; };
+    const char* getUserName() const override { return username; }
 
     virtual ~SSecurityPlain() { }
 
diff --git a/common/rfb/SSecurityRSAAES.cxx b/common/rfb/SSecurityRSAAES.cxx
index cea626441..13e03b22d 100644
--- a/common/rfb/SSecurityRSAAES.cxx
+++ b/common/rfb/SSecurityRSAAES.cxx
@@ -70,14 +70,15 @@ BoolParameter SSecurityRSAAES::requireUsername
 ("RequireUsername", "Require username for the RSA-AES security types",
  false, ConfServer);
 
-SSecurityRSAAES::SSecurityRSAAES(SConnection* sc, uint32_t _secType,
+SSecurityRSAAES::SSecurityRSAAES(SConnection* sc_, uint32_t _secType,
                                  int _keySize, bool _isAllEncrypted)
-  : SSecurity(sc), state(SendPublicKey),
+  : SSecurity(sc_), state(SendPublicKey),
     keySize(_keySize), isAllEncrypted(_isAllEncrypted), secType(_secType),
     serverKey(), clientKey(),
-    serverKeyN(NULL), serverKeyE(NULL), clientKeyN(NULL), clientKeyE(NULL),
+    serverKeyN(nullptr), serverKeyE(nullptr),
+    clientKeyN(nullptr), clientKeyE(nullptr),
     accessRights(AccessDefault),
-    rais(NULL), raos(NULL), rawis(NULL), rawos(NULL)
+    rais(nullptr), raos(nullptr), rawis(nullptr), rawos(nullptr)
 {
   assert(keySize == 128 || keySize == 256);
 }
@@ -514,10 +515,10 @@ void SSecurityRSAAES::clearSecrets()
   delete[] serverKeyE;
   delete[] clientKeyN;
   delete[] clientKeyE;
-  serverKeyN = NULL;
-  serverKeyE = NULL;
-  clientKeyN = NULL;
-  clientKeyE = NULL;
+  serverKeyN = nullptr;
+  serverKeyE = nullptr;
+  clientKeyN = nullptr;
+  clientKeyE = nullptr;
   memset(serverRandom, 0, sizeof(serverRandom));
   memset(clientRandom, 0, sizeof(clientRandom));
 }
diff --git a/common/rfb/SSecurityRSAAES.h b/common/rfb/SSecurityRSAAES.h
index 0c4fc8525..edac35c6d 100644
--- a/common/rfb/SSecurityRSAAES.h
+++ b/common/rfb/SSecurityRSAAES.h
@@ -36,10 +36,10 @@ namespace rfb {
     SSecurityRSAAES(SConnection* sc, uint32_t secType,
                     int keySize, bool isAllEncrypted);
     virtual ~SSecurityRSAAES();
-    virtual bool processMsg();
-    virtual const char* getUserName() const;
-    virtual int getType() const { return secType; }
-    virtual AccessRights getAccessRights() const
+    bool processMsg() override;
+    const char* getUserName() const override;
+    int getType() const override {return secType;}
+    AccessRights getAccessRights() const override
     {
       return accessRights;
     }
diff --git a/common/rfb/SSecurityStack.cxx b/common/rfb/SSecurityStack.cxx
index 9c0321d42..0ce6d7541 100644
--- a/common/rfb/SSecurityStack.cxx
+++ b/common/rfb/SSecurityStack.cxx
@@ -24,9 +24,9 @@
 
 using namespace rfb;
 
-SSecurityStack::SSecurityStack(SConnection* sc, int Type,
+SSecurityStack::SSecurityStack(SConnection* sc_, int Type,
                                SSecurity* s0, SSecurity* s1)
-  : SSecurity(sc), state(0), state0(s0), state1(s1), type(Type)
+  : SSecurity(sc_), state(0), state0(s0), state1(s1), type(Type)
 {
 }
 
@@ -61,7 +61,7 @@ bool SSecurityStack::processMsg()
 
 const char* SSecurityStack::getUserName() const
 {
-  const char* c = 0;
+  const char* c = nullptr;
 
   if (state1 && !c)
     c = state1->getUserName();
diff --git a/common/rfb/SSecurityStack.h b/common/rfb/SSecurityStack.h
index cf7b10d0e..d2949a21f 100644
--- a/common/rfb/SSecurityStack.h
+++ b/common/rfb/SSecurityStack.h
@@ -27,12 +27,12 @@ namespace rfb {
   class SSecurityStack : public SSecurity {
   public:
     SSecurityStack(SConnection* sc, int Type,
-                   SSecurity* s0 = NULL, SSecurity* s1 = NULL);
+                   SSecurity* s0 = nullptr, SSecurity* s1 = nullptr);
     ~SSecurityStack();
-    virtual bool processMsg();
-    virtual int getType() const { return type; };
-    virtual const char* getUserName() const;
-    virtual AccessRights getAccessRights() const;
+    bool processMsg() override;
+    int getType() const override { return type; };
+    const char* getUserName() const override;
+    AccessRights getAccessRights() const override;
   protected:
     short state;
     SSecurity* state0;
diff --git a/common/rfb/SSecurityTLS.cxx b/common/rfb/SSecurityTLS.cxx
index 1abfd774b..e2b82f898 100644
--- a/common/rfb/SSecurityTLS.cxx
+++ b/common/rfb/SSecurityTLS.cxx
@@ -66,13 +66,13 @@ StringParameter SSecurityTLS::X509_KeyFile
 
 static LogWriter vlog("TLS");
 
-SSecurityTLS::SSecurityTLS(SConnection* sc, bool _anon)
-  : SSecurity(sc), session(NULL), anon_cred(NULL),
-    cert_cred(NULL), anon(_anon), tlsis(NULL), tlsos(NULL),
-    rawis(NULL), rawos(NULL)
+SSecurityTLS::SSecurityTLS(SConnection* sc_, bool _anon)
+  : SSecurity(sc_), session(nullptr), anon_cred(nullptr),
+    cert_cred(nullptr), anon(_anon), tlsis(nullptr), tlsos(nullptr),
+    rawis(nullptr), rawos(nullptr)
 {
 #if defined (SSECURITYTLS__USE_DEPRECATED_DH)
-  dh_params = NULL;
+  dh_params = nullptr;
 #endif
 
   if (gnutls_global_init() != GNUTLS_E_SUCCESS)
@@ -99,32 +99,32 @@ void SSecurityTLS::shutdown()
 
   if (anon_cred) {
     gnutls_anon_free_server_credentials(anon_cred);
-    anon_cred = 0;
+    anon_cred = nullptr;
   }
 
   if (cert_cred) {
     gnutls_certificate_free_credentials(cert_cred);
-    cert_cred = 0;
+    cert_cred = nullptr;
   }
 
   if (rawis && rawos) {
     sc->setStreams(rawis, rawos);
-    rawis = NULL;
-    rawos = NULL;
+    rawis = nullptr;
+    rawos = nullptr;
   }
 
   if (tlsis) {
     delete tlsis;
-    tlsis = NULL;
+    tlsis = nullptr;
   }
   if (tlsos) {
     delete tlsos;
-    tlsos = NULL;
+    tlsos = nullptr;
   }
 
   if (session) {
     gnutls_deinit(session);
-    session = 0;
+    session = nullptr;
   }
 }
 
@@ -151,7 +151,7 @@ bool SSecurityTLS::processMsg()
       throw AuthFailureException("gnutls_set_default_priority failed");
 
     try {
-      setParams(session);
+      setParams();
     }
     catch(...) {
       os->writeU8(0);
@@ -190,7 +190,7 @@ bool SSecurityTLS::processMsg()
   return true;
 }
 
-void SSecurityTLS::setParams(gnutls_session_t session)
+void SSecurityTLS::setParams()
 {
   static const char kx_anon_priority[] = ":+ANON-ECDH:+ANON-DH";
 
@@ -203,7 +203,7 @@ void SSecurityTLS::setParams(gnutls_session_t session)
 
     prio = (char*)malloc(strlen(Security::GnuTLSPriority) +
                          strlen(kx_anon_priority) + 1);
-    if (prio == NULL)
+    if (prio == nullptr)
       throw AuthFailureException("Not enough memory for GnuTLS priority string");
 
     strcpy(prio, Security::GnuTLSPriority);
@@ -239,7 +239,7 @@ void SSecurityTLS::setParams(gnutls_session_t session)
 
     prio = (char*)malloc(strlen(gnutls_default_priority) +
                          strlen(kx_anon_priority) + 1);
-    if (prio == NULL)
+    if (prio == nullptr)
       throw AuthFailureException("Not enough memory for GnuTLS priority string");
 
     strcpy(prio, gnutls_default_priority);
diff --git a/common/rfb/SSecurityTLS.h b/common/rfb/SSecurityTLS.h
index d0f735fe4..c29ee4747 100644
--- a/common/rfb/SSecurityTLS.h
+++ b/common/rfb/SSecurityTLS.h
@@ -45,16 +45,16 @@ namespace rfb {
   public:
     SSecurityTLS(SConnection* sc, bool _anon);
     virtual ~SSecurityTLS();
-    virtual bool processMsg();
-    virtual const char* getUserName() const {return 0;}
-    virtual int getType() const { return anon ? secTypeTLSNone : secTypeX509None;}
+    bool processMsg() override;
+    const char* getUserName() const override {return nullptr;}
+    int getType() const override { return anon ? secTypeTLSNone : secTypeX509None;}
 
     static StringParameter X509_CertFile;
     static StringParameter X509_KeyFile;
 
   protected:
     void shutdown();
-    void setParams(gnutls_session_t session);
+    void setParams();
 
   private:
     gnutls_session_t session;
diff --git a/common/rfb/SSecurityVeNCrypt.cxx b/common/rfb/SSecurityVeNCrypt.cxx
index 2813f2997..ce160503b 100644
--- a/common/rfb/SSecurityVeNCrypt.cxx
+++ b/common/rfb/SSecurityVeNCrypt.cxx
@@ -38,10 +38,11 @@ using namespace std;
 
 static LogWriter vlog("SVeNCrypt");
 
-SSecurityVeNCrypt::SSecurityVeNCrypt(SConnection* sc, SecurityServer *sec)
-  : SSecurity(sc), security(sec)
+SSecurityVeNCrypt::SSecurityVeNCrypt(SConnection* sc_,
+                                     SecurityServer *sec)
+  : SSecurity(sc_), security(sec)
 {
-  ssecurity = NULL;
+  ssecurity = nullptr;
   haveSentVersion = false;
   haveRecvdMajorVersion = false;
   haveRecvdMinorVersion = false;
@@ -51,7 +52,7 @@ SSecurityVeNCrypt::SSecurityVeNCrypt(SConnection* sc, SecurityServer *sec)
   haveChosenType = false;
   chosenType = secTypeVeNCrypt;
   numTypes = 0;
-  subTypes = NULL;
+  subTypes = nullptr;
 }
 
 SSecurityVeNCrypt::~SSecurityVeNCrypt()
@@ -175,14 +176,14 @@ bool SSecurityVeNCrypt::processMsg()
 
 const char* SSecurityVeNCrypt::getUserName() const
 {
-  if (ssecurity == NULL)
-    return NULL;
+  if (ssecurity == nullptr)
+    return nullptr;
   return ssecurity->getUserName();
 }
 
 AccessRights SSecurityVeNCrypt::getAccessRights() const
 {
-  if (ssecurity == NULL)
+  if (ssecurity == nullptr)
     return SSecurity::getAccessRights();
   return ssecurity->getAccessRights();
 }
diff --git a/common/rfb/SSecurityVeNCrypt.h b/common/rfb/SSecurityVeNCrypt.h
index 91713f890..ea2bb6fb1 100644
--- a/common/rfb/SSecurityVeNCrypt.h
+++ b/common/rfb/SSecurityVeNCrypt.h
@@ -34,10 +34,10 @@ namespace rfb {
   public:
     SSecurityVeNCrypt(SConnection* sc, SecurityServer *sec);
     ~SSecurityVeNCrypt();
-    virtual bool processMsg();
-    virtual int getType() const { return chosenType; }
-    virtual const char* getUserName() const;
-    virtual AccessRights getAccessRights() const;
+    bool processMsg() override;
+    int getType() const override { return chosenType; }
+    const char* getUserName() const override;
+    AccessRights getAccessRights() const override;
 
   protected:
     SSecurity *ssecurity;
diff --git a/common/rfb/SSecurityVncAuth.cxx b/common/rfb/SSecurityVncAuth.cxx
index c1ef1f1c0..1276f68a8 100644
--- a/common/rfb/SSecurityVncAuth.cxx
+++ b/common/rfb/SSecurityVncAuth.cxx
@@ -52,8 +52,8 @@ VncAuthPasswdParameter SSecurityVncAuth::vncAuthPasswd
 ("Password", "Obfuscated binary encoding of the password which clients must supply to "
  "access the server", &SSecurityVncAuth::vncAuthPasswdFile);
 
-SSecurityVncAuth::SSecurityVncAuth(SConnection* sc)
-  : SSecurity(sc), sentChallenge(false),
+SSecurityVncAuth::SSecurityVncAuth(SConnection* sc_)
+  : SSecurity(sc_), sentChallenge(false),
     pg(&vncAuthPasswd), accessRights(AccessNone)
 {
 }
@@ -116,10 +116,12 @@ bool SSecurityVncAuth::processMsg()
   throw AuthFailureException();
 }
 
-VncAuthPasswdParameter::VncAuthPasswdParameter(const char* name,
+VncAuthPasswdParameter::VncAuthPasswdParameter(const char* name_,
                                                const char* desc,
                                                StringParameter* passwdFile_)
-: BinaryParameter(name, desc, 0, 0, ConfServer), passwdFile(passwdFile_) {
+: BinaryParameter(name_, desc, nullptr, 0, ConfServer),
+  passwdFile(passwdFile_)
+{
 }
 
 void VncAuthPasswdParameter::getVncAuthPasswd(std::string *password, std::string *readOnlyPassword) {
@@ -151,8 +153,8 @@ void VncAuthPasswdParameter::getVncAuthPasswd(std::string *password, std::string
     }
   }
 
-  assert(password != NULL);
-  assert(readOnlyPassword != NULL);
+  assert(password != nullptr);
+  assert(readOnlyPassword != nullptr);
 
   try {
     *password = deobfuscate(obfuscated.data(), obfuscated.size());
diff --git a/common/rfb/SSecurityVncAuth.h b/common/rfb/SSecurityVncAuth.h
index 7f27b02bf..532abe0ab 100644
--- a/common/rfb/SSecurityVncAuth.h
+++ b/common/rfb/SSecurityVncAuth.h
@@ -44,7 +44,7 @@ namespace rfb {
   class VncAuthPasswdParameter : public VncAuthPasswdGetter, BinaryParameter {
   public:
     VncAuthPasswdParameter(const char* name, const char* desc, StringParameter* passwdFile_);
-    virtual void getVncAuthPasswd(std::string *password, std::string *readOnlyPassword);
+    void getVncAuthPasswd(std::string *password, std::string *readOnlyPassword) override;
   protected:
     StringParameter* passwdFile;
   };
@@ -52,10 +52,10 @@ namespace rfb {
   class SSecurityVncAuth : public SSecurity {
   public:
     SSecurityVncAuth(SConnection* sc);
-    virtual bool processMsg();
-    virtual int getType() const {return secTypeVncAuth;}
-    virtual const char* getUserName() const {return 0;}
-    virtual AccessRights getAccessRights() const { return accessRights; }
+    bool processMsg() override;
+    int getType() const override {return secTypeVncAuth;}
+    const char* getUserName() const override {return nullptr;}
+    AccessRights getAccessRights() const override { return accessRights; }
     static StringParameter vncAuthPasswdFile;
     static VncAuthPasswdParameter vncAuthPasswd;
   private:
diff --git a/common/rfb/Security.cxx b/common/rfb/Security.cxx
index caf6420f6..01191c653 100644
--- a/common/rfb/Security.cxx
+++ b/common/rfb/Security.cxx
@@ -21,29 +21,14 @@
 #include <config.h>
 #endif
 
-#include <assert.h>
-#include <stdlib.h>
 #include <string.h>
-#include <rfb/CSecurityNone.h>
-#include <rfb/CSecurityStack.h>
-#include <rfb/CSecurityVeNCrypt.h>
-#include <rfb/CSecurityVncAuth.h>
-#include <rfb/CSecurityPlain.h>
-#include <rdr/Exception.h>
+
+#include <algorithm>
+
 #include <rfb/LogWriter.h>
 #include <rfb/Security.h>
-#include <rfb/SSecurityNone.h>
-#include <rfb/SSecurityStack.h>
-#include <rfb/SSecurityPlain.h>
-#include <rfb/SSecurityVncAuth.h>
-#include <rfb/SSecurityVeNCrypt.h>
-#ifdef HAVE_GNUTLS
-#include <rfb/CSecurityTLS.h>
-#include <rfb/SSecurityTLS.h>
-#endif
 #include <rfb/util.h>
 
-using namespace rdr;
 using namespace rfb;
 using namespace std;
 
@@ -67,23 +52,22 @@ Security::Security(StringParameter &secTypes)
 const std::list<uint8_t> Security::GetEnabledSecTypes(void)
 {
   list<uint8_t> result;
-  list<uint32_t>::iterator i;
 
   /* Partial workaround for Vino's stupid behaviour. It doesn't allow
    * the basic authentication types as part of the VeNCrypt handshake,
    * making it impossible for a client to do opportunistic encryption.
    * At least make it possible to connect when encryption is explicitly
    * disabled. */
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++) {
-    if (*i >= 0x100) {
+  for (uint32_t type : enabledSecTypes) {
+    if (type >= 0x100) {
       result.push_back(secTypeVeNCrypt);
       break;
     }
   }
 
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++)
-    if (*i < 0x100)
-      result.push_back(*i);
+  for (uint32_t type : enabledSecTypes)
+    if (type < 0x100)
+      result.push_back(type);
 
   return result;
 }
@@ -91,33 +75,28 @@ const std::list<uint8_t> Security::GetEnabledSecTypes(void)
 const std::list<uint32_t> Security::GetEnabledExtSecTypes(void)
 {
   list<uint32_t> result;
-  list<uint32_t>::iterator i;
 
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++)
-    if (*i != secTypeVeNCrypt) /* Do not include VeNCrypt type to avoid loops */
-      result.push_back(*i);
+  for (uint32_t type : enabledSecTypes)
+    if (type != secTypeVeNCrypt) /* Do not include VeNCrypt type to avoid loops */
+      result.push_back(type);
 
   return result;
 }
 
 void Security::EnableSecType(uint32_t secType)
 {
-  list<uint32_t>::iterator i;
-
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++)
-    if (*i == secType)
-      return;
+  if (std::find(enabledSecTypes.begin(), enabledSecTypes.end(),
+                secType) != enabledSecTypes.end())
+    return;
 
   enabledSecTypes.push_back(secType);
 }
 
 bool Security::IsSupported(uint32_t secType)
 {
-  list<uint32_t>::iterator i;
-
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++)
-    if (*i == secType)
-      return true;
+  if (std::find(enabledSecTypes.begin(), enabledSecTypes.end(),
+                secType) != enabledSecTypes.end())
+    return true;
   if (secType == secTypeVeNCrypt)
     return true;
 
@@ -126,15 +105,14 @@ bool Security::IsSupported(uint32_t secType)
 
 char *Security::ToString(void)
 {
-  list<uint32_t>::iterator i;
   static char out[128]; /* Should be enough */
   bool firstpass = true;
   const char *name;
 
   memset(out, 0, sizeof(out));
 
-  for (i = enabledSecTypes.begin(); i != enabledSecTypes.end(); i++) {
-    name = secTypeName(*i);
+  for (uint32_t type : enabledSecTypes) {
+    name = secTypeName(type);
     if (name[0] == '[') /* Unknown security type */
       continue;
 
diff --git a/common/rfb/SecurityClient.cxx b/common/rfb/SecurityClient.cxx
index 1350640d0..12860662f 100644
--- a/common/rfb/SecurityClient.cxx
+++ b/common/rfb/SecurityClient.cxx
@@ -41,9 +41,9 @@
 using namespace rdr;
 using namespace rfb;
 
-UserPasswdGetter *CSecurity::upg = NULL;
+UserPasswdGetter *CSecurity::upg = nullptr;
 #if defined(HAVE_GNUTLS) || defined(HAVE_NETTLE)
-UserMsgBox *CSecurity::msg = NULL;
+UserMsgBox *CSecurity::msg = nullptr;
 #endif
 
 StringParameter SecurityClient::secTypes
@@ -67,9 +67,9 @@ ConfViewer);
 
 CSecurity* SecurityClient::GetCSecurity(CConnection* cc, uint32_t secType)
 {
-  assert (CSecurity::upg != NULL); /* (upg == NULL) means bug in the viewer */
+  assert (CSecurity::upg != nullptr); /* (upg == nullptr) means bug in the viewer */
 #if defined(HAVE_GNUTLS) || defined(HAVE_NETTLE)
-  assert (CSecurity::msg != NULL);
+  assert (CSecurity::msg != nullptr);
 #endif
 
   if (!IsSupported(secType))
diff --git a/common/rfb/ServerParams.cxx b/common/rfb/ServerParams.cxx
index 6af446c21..9f6f53076 100644
--- a/common/rfb/ServerParams.cxx
+++ b/common/rfb/ServerParams.cxx
@@ -38,7 +38,7 @@ ServerParams::ServerParams()
 {
   setName("");
 
-  cursor_ = new Cursor(0, 0, Point(), NULL);
+  cursor_ = new Cursor(0, 0, Point(), nullptr);
 
   clipFlags = 0;
   memset(clipSizes, 0, sizeof(clipSizes));
diff --git a/common/rfb/TightDecoder.cxx b/common/rfb/TightDecoder.cxx
index 54b620ea8..807f71a5d 100644
--- a/common/rfb/TightDecoder.cxx
+++ b/common/rfb/TightDecoder.cxx
@@ -345,7 +345,7 @@ void TightDecoder::decodeRect(const Rect& r, const uint8_t* buffer,
   size_t rowSize, dataSize;
   uint8_t* netbuf;
 
-  netbuf = NULL;
+  netbuf = nullptr;
 
   if (palSize != 0) {
     if (palSize <= 2)
@@ -387,7 +387,7 @@ void TightDecoder::decodeRect(const Rect& r, const uint8_t* buffer,
     zis[streamId].readBytes(netbuf, dataSize);
 
     zis[streamId].flushUnderlying();
-    zis[streamId].setUnderlying(NULL, 0);
+    zis[streamId].setUnderlying(nullptr, 0);
     delete ms;
 
     bufptr = netbuf;
diff --git a/common/rfb/TightDecoder.h b/common/rfb/TightDecoder.h
index 764f138e1..d569a7fd6 100644
--- a/common/rfb/TightDecoder.h
+++ b/common/rfb/TightDecoder.h
@@ -31,18 +31,17 @@ namespace rfb {
   public:
     TightDecoder();
     virtual ~TightDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual bool doRectsConflict(const Rect& rectA,
-                                 const uint8_t* bufferA,
-                                 size_t buflenA,
-                                 const Rect& rectB,
-                                 const uint8_t* bufferB,
-                                 size_t buflenB,
-                                 const ServerParams& server);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    bool doRectsConflict(const Rect& rectA,
+                         const uint8_t* bufferA, size_t buflenA,
+                         const Rect& rectB,
+                         const uint8_t* bufferB, size_t buflenB,
+                         const ServerParams& server) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
 
   private:
     uint32_t readCompact(rdr::InStream* is);
diff --git a/common/rfb/TightEncoder.cxx b/common/rfb/TightEncoder.cxx
index 1a169a3db..169b74f76 100644
--- a/common/rfb/TightEncoder.cxx
+++ b/common/rfb/TightEncoder.cxx
@@ -60,8 +60,8 @@ static const TightConf conf[10] = {
   { 9, 9, 9 }  // 9
 };
 
-TightEncoder::TightEncoder(SConnection* conn) :
-  Encoder(conn, encodingTight, EncoderPlain, 256)
+TightEncoder::TightEncoder(SConnection* conn_) :
+  Encoder(conn_, encodingTight, EncoderPlain, 256)
 {
   setCompressLevel(-1);
 }
@@ -260,12 +260,12 @@ void TightEncoder::flushZlibOutStream(rdr::OutStream* os_)
   rdr::ZlibOutStream* zos;
 
   zos = dynamic_cast<rdr::ZlibOutStream*>(os_);
-  if (zos == NULL)
+  if (zos == nullptr)
     return;
 
   zos->cork(false);
   zos->flush();
-  zos->setUnderlying(NULL);
+  zos->setUnderlying(nullptr);
 
   os = conn->getOutStream();
 
diff --git a/common/rfb/TightEncoder.h b/common/rfb/TightEncoder.h
index 0608eb093..3a7210c7f 100644
--- a/common/rfb/TightEncoder.h
+++ b/common/rfb/TightEncoder.h
@@ -31,14 +31,14 @@ namespace rfb {
     TightEncoder(SConnection* conn);
     virtual ~TightEncoder();
 
-    virtual bool isSupported();
+    bool isSupported() override;
 
-    virtual void setCompressLevel(int level);
+    void setCompressLevel(int level) override;
 
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
 
   protected:
     void writeMonoRect(const PixelBuffer* pb, const Palette& palette);
diff --git a/common/rfb/TightJPEGEncoder.cxx b/common/rfb/TightJPEGEncoder.cxx
index 5c8706eee..de8fd77f1 100644
--- a/common/rfb/TightJPEGEncoder.cxx
+++ b/common/rfb/TightJPEGEncoder.cxx
@@ -68,8 +68,8 @@ static const struct TightJPEGConfiguration conf[10] = {
 };
 
 
-TightJPEGEncoder::TightJPEGEncoder(SConnection* conn) :
-  Encoder(conn, encodingTight,
+TightJPEGEncoder::TightJPEGEncoder(SConnection* conn_) :
+  Encoder(conn_, encodingTight,
           (EncoderFlags)(EncoderUseNativePF | EncoderLossy), -1, 9),
   qualityLevel(-1), fineQuality(-1), fineSubsampling(subsampleUndefined)
 {
diff --git a/common/rfb/TightJPEGEncoder.h b/common/rfb/TightJPEGEncoder.h
index 002deabb8..81d9f40de 100644
--- a/common/rfb/TightJPEGEncoder.h
+++ b/common/rfb/TightJPEGEncoder.h
@@ -30,17 +30,17 @@ namespace rfb {
     TightJPEGEncoder(SConnection* conn);
     virtual ~TightJPEGEncoder();
 
-    virtual bool isSupported();
+    bool isSupported() override;
 
-    virtual void setQualityLevel(int level);
-    virtual void setFineQualityLevel(int quality, int subsampling);
+    void setQualityLevel(int level) override;
+    void setFineQualityLevel(int quality, int subsampling) override;
 
-    virtual int getQualityLevel();
+    int getQualityLevel() override;
 
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
 
   protected:
     void writeCompact(uint32_t value, rdr::OutStream* os);
diff --git a/common/rfb/Timer.cxx b/common/rfb/Timer.cxx
index e9ae52276..5216c7e38 100644
--- a/common/rfb/Timer.cxx
+++ b/common/rfb/Timer.cxx
@@ -26,6 +26,8 @@
 #include <stdio.h>
 #include <sys/time.h>
 
+#include <algorithm>
+
 #include <rfb/Timer.h>
 #include <rfb/util.h>
 #include <rfb/LogWriter.h>
@@ -63,7 +65,7 @@ int Timer::checkTimeouts() {
   if (pending.empty())
     return -1;
 
-  gettimeofday(&start, 0);
+  gettimeofday(&start, nullptr);
   while (pending.front()->isBefore(start)) {
     Timer* timer;
 
@@ -81,7 +83,7 @@ int Timer::checkTimeouts() {
 
 int Timer::getNextTimeout() {
   timeval now;
-  gettimeofday(&now, 0);
+  gettimeofday(&now, nullptr);
 
   if (pending.empty())
     return -1;
@@ -115,7 +117,7 @@ void Timer::insertTimer(Timer* t) {
 
 void Timer::start(int timeoutMs_) {
   timeval now;
-  gettimeofday(&now, 0);
+  gettimeofday(&now, nullptr);
   stop();
   timeoutMs = timeoutMs_;
   dueTime = addMillis(now, timeoutMs);
@@ -125,7 +127,7 @@ void Timer::start(int timeoutMs_) {
 void Timer::repeat(int timeoutMs_) {
   timeval now;
 
-  gettimeofday(&now, 0);
+  gettimeofday(&now, nullptr);
 
   if (isStarted()) {
     vlog.error("Incorrectly repeating already running timer");
@@ -153,12 +155,8 @@ void Timer::stop() {
 }
 
 bool Timer::isStarted() {
-  std::list<Timer*>::iterator i;
-  for (i=pending.begin(); i!=pending.end(); i++) {
-    if (*i == this)
-      return true;
-  }
-  return false;
+  return std::find(pending.begin(), pending.end(),
+                   this) != pending.end();
 }
 
 int Timer::getTimeoutMs() {
@@ -167,7 +165,7 @@ int Timer::getTimeoutMs() {
 
 int Timer::getRemainingMs() {
   timeval now;
-  gettimeofday(&now, 0);
+  gettimeofday(&now, nullptr);
   return __rfbmax(0, diffTimeMillis(dueTime, now));
 }
 
diff --git a/common/rfb/Timer.h b/common/rfb/Timer.h
index 36ec46c51..362cb84ee 100644
--- a/common/rfb/Timer.h
+++ b/common/rfb/Timer.h
@@ -124,7 +124,7 @@ namespace rfb {
     MethodTimer(T* obj_, void (T::*cb_)(Timer*))
       : Timer(this), obj(obj_), cb(cb_) {}
 
-    virtual void handleTimeout(Timer* t) { (obj->*cb)(t); }
+    void handleTimeout(Timer* t) override { return (obj->*cb)(t); }
 
   private:
     T* obj;
diff --git a/common/rfb/UnixPasswordValidator.h b/common/rfb/UnixPasswordValidator.h
index 28d083a15..4d623d6c3 100644
--- a/common/rfb/UnixPasswordValidator.h
+++ b/common/rfb/UnixPasswordValidator.h
@@ -28,7 +28,7 @@ namespace rfb
   class UnixPasswordValidator: public PasswordValidator {
   protected:
     bool validateInternal(SConnection * sc, const char *username,
-			   const char *password);
+			   const char *password) override;
   };
 }
 
diff --git a/common/rfb/UpdateTracker.h b/common/rfb/UpdateTracker.h
index 8983b378a..e91b96214 100644
--- a/common/rfb/UpdateTracker.h
+++ b/common/rfb/UpdateTracker.h
@@ -53,14 +53,14 @@ namespace rfb {
 
   class ClippingUpdateTracker : public UpdateTracker {
   public:
-    ClippingUpdateTracker() : ut(0) {}
+    ClippingUpdateTracker() : ut(nullptr) {}
     ClippingUpdateTracker(UpdateTracker* ut_, const Rect& r=Rect()) : ut(ut_), clipRect(r) {}
     
     void setUpdateTracker(UpdateTracker* ut_) {ut = ut_;}
     void setClipRect(const Rect& cr) {clipRect = cr;}
 
-    virtual void add_changed(const Region &region);
-    virtual void add_copied(const Region &dest, const Point &delta);
+    void add_changed(const Region &region) override;
+    void add_copied(const Region &dest, const Point &delta) override;
   protected:
     UpdateTracker* ut;
     Rect clipRect;
@@ -71,8 +71,8 @@ namespace rfb {
     SimpleUpdateTracker();
     virtual ~SimpleUpdateTracker();
 
-    virtual void add_changed(const Region &region);
-    virtual void add_copied(const Region &dest, const Point &delta);
+    void add_changed(const Region &region) override;
+    void add_copied(const Region &dest, const Point &delta) override;
     virtual void subtract(const Region& region);
 
     // Fill the supplied UpdateInfo structure with update information
diff --git a/common/rfb/VNCSConnectionST.cxx b/common/rfb/VNCSConnectionST.cxx
index 306bba1dc..a40a1a30e 100644
--- a/common/rfb/VNCSConnectionST.cxx
+++ b/common/rfb/VNCSConnectionST.cxx
@@ -48,7 +48,7 @@ using namespace rfb;
 
 static LogWriter vlog("VNCSConnST");
 
-static Cursor emptyCursor(0, 0, Point(0, 0), NULL);
+static Cursor emptyCursor(0, 0, Point(0, 0), nullptr);
 
 VNCSConnectionST::VNCSConnectionST(VNCServerST* server_, network::Socket *s,
                                    bool reverse, AccessRights ar)
@@ -56,7 +56,7 @@ VNCSConnectionST::VNCSConnectionST(VNCServerST* server_, network::Socket *s,
     sock(s), reverseConnection(reverse),
     inProcessMessages(false),
     pendingSyncFence(false), syncFence(false), fenceFlags(0),
-    fenceDataLen(0), fenceData(NULL), congestionTimer(this),
+    fenceDataLen(0), fenceData(nullptr), congestionTimer(this),
     losslessTimer(this), server(server_),
     updateRenderedCursor(false), removeRenderedCursor(false),
     continuousUpdates(false), encodeManager(this), idleTimer(this),
@@ -409,7 +409,7 @@ bool VNCSConnectionST::needRenderedCursor()
   if (!client.supportsLocalCursor())
     return true;
   if ((server->getCursorPos() != pointerEventPos) &&
-      (time(0) - pointerEventTime) > 0)
+      (time(nullptr) - pointerEventTime) > 0)
     return true;
 
   return false;
@@ -481,7 +481,7 @@ void VNCSConnectionST::pointerEvent(const Point& pos, int buttonMask)
 {
   if (rfb::Server::idleTimeout)
     idleTimer.start(secsToMillis(rfb::Server::idleTimeout));
-  pointerEventTime = time(0);
+  pointerEventTime = time(nullptr);
   if (!accessCheck(AccessPtrEvents)) return;
   if (!rfb::Server::acceptPointerEvents) return;
   pointerEventPos = pos;
@@ -690,7 +690,7 @@ void VNCSConnectionST::fence(uint32_t flags, unsigned len, const uint8_t data[])
       fenceFlags = flags & (fenceFlagBlockBefore | fenceFlagBlockAfter | fenceFlagSyncNext);
       fenceDataLen = len;
       delete [] fenceData;
-      fenceData = NULL;
+      fenceData = nullptr;
       if (len > 0) {
         fenceData = new uint8_t[len];
         memcpy(fenceData, data, len);
@@ -1001,7 +1001,7 @@ void VNCSConnectionST::writeDataUpdate()
 
   // Does the client need a server-side rendered cursor?
 
-  cursor = NULL;
+  cursor = nullptr;
   if (needRenderedCursor()) {
     Rect renderedCursorRect;
 
@@ -1083,7 +1083,7 @@ void VNCSConnectionST::writeLosslessRefresh()
 
   // Prepare the cursor in case it overlaps with a region getting
   // refreshed
-  cursor = NULL;
+  cursor = nullptr;
   if (needRenderedCursor())
     cursor = server->getRenderedCursor();
 
diff --git a/common/rfb/VNCSConnectionST.h b/common/rfb/VNCSConnectionST.h
index 3a9ec2422..e9badd72c 100644
--- a/common/rfb/VNCSConnectionST.h
+++ b/common/rfb/VNCSConnectionST.h
@@ -46,8 +46,8 @@ namespace rfb {
 
     // SConnection methods
 
-    virtual bool accessCheck(AccessRights ar) const;
-    virtual void close(const char* reason);
+    bool accessCheck(AccessRights ar) const override;
+    void close(const char* reason) override;
 
     using SConnection::authenticated;
 
@@ -118,30 +118,32 @@ namespace rfb {
   private:
     // SConnection callbacks
 
-    // These methods are invoked as callbacks from processMsg()
-
-    virtual void authSuccess();
-    virtual void queryConnection(const char* userName);
-    virtual void clientInit(bool shared);
-    virtual void setPixelFormat(const PixelFormat& pf);
-    virtual void pointerEvent(const Point& pos, int buttonMask);
-    virtual void keyEvent(uint32_t keysym, uint32_t keycode, bool down);
-    virtual void framebufferUpdateRequest(const Rect& r, bool incremental);
-    virtual void setDesktopSize(int fb_width, int fb_height,
-                                const ScreenSet& layout);
-    virtual void fence(uint32_t flags, unsigned len, const uint8_t data[]);
-    virtual void enableContinuousUpdates(bool enable,
-                                         int x, int y, int w, int h);
-    virtual void handleClipboardRequest();
-    virtual void handleClipboardAnnounce(bool available);
-    virtual void handleClipboardData(const char* data);
-    virtual void supportsLocalCursor();
-    virtual void supportsFence();
-    virtual void supportsContinuousUpdates();
-    virtual void supportsLEDState();
+    // These methods are invoked as callbacks from processMsg(
+    void authSuccess() override;
+    void queryConnection(const char* userName) override;
+    void clientInit(bool shared) override;
+    void setPixelFormat(const PixelFormat& pf) override;
+    void pointerEvent(const Point& pos, int buttonMask) override;
+    void keyEvent(uint32_t keysym, uint32_t keycode,
+                  bool down) override;
+    void framebufferUpdateRequest(const Rect& r,
+                                  bool incremental) override;
+    void setDesktopSize(int fb_width, int fb_height,
+                        const ScreenSet& layout) override;
+    void fence(uint32_t flags, unsigned len,
+               const uint8_t data[]) override;
+    void enableContinuousUpdates(bool enable,
+                                 int x, int y, int w, int h) override;
+    void handleClipboardRequest() override;
+    void handleClipboardAnnounce(bool available) override;
+    void handleClipboardData(const char* data) override;
+    void supportsLocalCursor() override;
+    void supportsFence() override;
+    void supportsContinuousUpdates() override;
+    void supportsLEDState() override;
 
     // Timer callbacks
-    virtual void handleTimeout(Timer* t);
+    void handleTimeout(Timer* t) override;
 
     // Internal methods
 
diff --git a/common/rfb/VNCServer.h b/common/rfb/VNCServer.h
index 3ac9fb946..4e3a5b23d 100644
--- a/common/rfb/VNCServer.h
+++ b/common/rfb/VNCServer.h
@@ -115,7 +115,7 @@ namespace rfb {
     // acceptance, or false for rejection, in which case a string
     // reason may also be given.
     virtual void approveConnection(network::Socket* sock, bool accept,
-                                   const char* reason = NULL) = 0;
+                                   const char* reason = nullptr) = 0;
 
     // - Close all currently-connected clients, by calling
     //   their close() method with the supplied reason.
diff --git a/common/rfb/VNCServerST.cxx b/common/rfb/VNCServerST.cxx
index b9579f12a..a8fa1739d 100644
--- a/common/rfb/VNCServerST.cxx
+++ b/common/rfb/VNCServerST.cxx
@@ -83,10 +83,10 @@ static LogWriter connectionsLog("Connections");
 
 VNCServerST::VNCServerST(const char* name_, SDesktop* desktop_)
   : blHosts(&blacklist), desktop(desktop_), desktopStarted(false),
-    blockCounter(0), pb(0), ledState(ledUnknown),
-    name(name_), pointerClient(0), clipboardClient(0),
+    blockCounter(0), pb(nullptr), ledState(ledUnknown),
+    name(name_), pointerClient(nullptr), clipboardClient(nullptr),
     pointerClientTime(0),
-    comparer(0), cursor(new Cursor(0, 0, Point(), NULL)),
+    comparer(nullptr), cursor(new Cursor(0, 0, Point(), nullptr)),
     renderedCursorInvalid(false),
     keyRemapper(&KeyRemapper::defInstance),
     idleTimer(this), disconnectTimer(this), connectTimer(this),
@@ -177,19 +177,19 @@ void VNCServerST::removeSocket(network::Socket* sock) {
     if ((*ci)->getSock() == sock) {
       // - Remove any references to it
       if (pointerClient == *ci)
-        pointerClient = NULL;
+        pointerClient = nullptr;
       if (clipboardClient == *ci)
         handleClipboardAnnounce(*ci, false);
       clipboardRequestors.remove(*ci);
 
-      std::string name((*ci)->getPeerEndpoint());
+      std::string peer((*ci)->getPeerEndpoint());
 
       // - Delete the per-Socket resources
       delete *ci;
 
       clients.remove(*ci);
 
-      connectionsLog.status("closed: %s", name.c_str());
+      connectionsLog.status("closed: %s", peer.c_str());
 
       // - Check that the desktop object is still required
       if (authClientCount() == 0)
@@ -275,7 +275,7 @@ void VNCServerST::setPixelBuffer(PixelBuffer* pb_, const ScreenSet& layout)
 
   pb = pb_;
   delete comparer;
-  comparer = 0;
+  comparer = nullptr;
 
   if (!pb) {
     screenLayout = ScreenSet();
@@ -297,9 +297,8 @@ void VNCServerST::setPixelBuffer(PixelBuffer* pb_, const ScreenSet& layout)
   renderedCursorInvalid = true;
   add_changed(pb->getRect());
 
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci=clients.begin();ci!=clients.end();ci=ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci) {
     (*ci)->pixelBufferChange();
     // Since the new pixel buffer means an ExtendedDesktopSize needs to
     // be sent anyway, we don't need to call screenLayoutChange.
@@ -346,16 +345,14 @@ void VNCServerST::setScreenLayout(const ScreenSet& layout)
 
   screenLayout = layout;
 
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci=clients.begin();ci!=clients.end();ci=ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci)
     (*ci)->screenLayoutChangeOrClose(reasonServer);
-  }
 }
 
 void VNCServerST::requestClipboard()
 {
-  if (clipboardClient == NULL) {
+  if (clipboardClient == nullptr) {
     slog.debug("Got request for client clipboard but no client currently owns the clipboard");
     return;
   }
@@ -365,54 +362,46 @@ void VNCServerST::requestClipboard()
 
 void VNCServerST::announceClipboard(bool available)
 {
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
+  std::list<VNCSConnectionST*>::iterator ci;
 
   clipboardRequestors.clear();
 
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  for (ci = clients.begin(); ci != clients.end(); ++ci)
     (*ci)->announceClipboardOrClose(available);
-  }
 }
 
 void VNCServerST::sendClipboardData(const char* data)
 {
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
+  std::list<VNCSConnectionST*>::iterator ci;
 
-  if (strchr(data, '\r') != NULL)
+  if (strchr(data, '\r') != nullptr)
     throw Exception("Invalid carriage return in clipboard data");
 
   for (ci = clipboardRequestors.begin();
-       ci != clipboardRequestors.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+       ci != clipboardRequestors.end(); ++ci)
     (*ci)->sendClipboardDataOrClose(data);
-  }
 
   clipboardRequestors.clear();
 }
 
 void VNCServerST::bell()
 {
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci)
     (*ci)->bellOrClose();
-  }
 }
 
 void VNCServerST::setName(const char* name_)
 {
   name = name_;
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci)
     (*ci)->setDesktopNameOrClose(name_);
-  }
 }
 
 void VNCServerST::add_changed(const Region& region)
 {
-  if (comparer == NULL)
+  if (comparer == nullptr)
     return;
 
   comparer->add_changed(region);
@@ -421,7 +410,7 @@ void VNCServerST::add_changed(const Region& region)
 
 void VNCServerST::add_copied(const Region& dest, const Point& delta)
 {
-  if (comparer == NULL)
+  if (comparer == nullptr)
     return;
 
   comparer->add_copied(dest, delta);
@@ -437,9 +426,8 @@ void VNCServerST::setCursor(int width, int height, const Point& newHotspot,
 
   renderedCursorInvalid = true;
 
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci) {
     (*ci)->renderedCursorChange();
     (*ci)->setCursorOrClose();
   }
@@ -461,17 +449,15 @@ void VNCServerST::setCursorPos(const Point& pos, bool warped)
 
 void VNCServerST::setLEDState(unsigned int state)
 {
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
+  std::list<VNCSConnectionST*>::iterator ci;
 
   if (state == ledState)
     return;
 
   ledState = state;
 
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  for (ci = clients.begin(); ci != clients.end(); ++ci)
     (*ci)->setLEDStateOrClose(state);
-  }
 }
 
 // Event handlers
@@ -498,14 +484,14 @@ void VNCServerST::keyEvent(uint32_t keysym, uint32_t keycode, bool down)
 void VNCServerST::pointerEvent(VNCSConnectionST* client,
                                const Point& pos, int buttonMask)
 {
-  time_t now = time(0);
+  time_t now = time(nullptr);
   if (rfb::Server::maxIdleTime)
     idleTimer.start(secsToMillis(rfb::Server::maxIdleTime));
 
   // Let one client own the cursor whilst buttons are pressed in order
   // to provide a bit more sane user experience. But limit the time to
   // prevent locking out all others when e.g. the network is down.
-  if ((pointerClient != NULL) && (pointerClient != client) &&
+  if ((pointerClient != nullptr) && (pointerClient != client) &&
       ((now - pointerClientTime) < 10))
     return;
 
@@ -513,7 +499,7 @@ void VNCServerST::pointerEvent(VNCSConnectionST* client,
   if (buttonMask)
     pointerClient = client;
   else
-    pointerClient = NULL;
+    pointerClient = nullptr;
 
   desktop->pointerEvent(pos, buttonMask);
 }
@@ -533,7 +519,7 @@ void VNCServerST::handleClipboardAnnounce(VNCSConnectionST* client,
   else {
     if (client != clipboardClient)
       return;
-    clipboardClient = NULL;
+    clipboardClient = nullptr;
   }
   desktop->handleClipboardAnnounce(available);
 }
@@ -553,7 +539,7 @@ unsigned int VNCServerST::setDesktopSize(VNCSConnectionST* requester,
                                          const ScreenSet& layout)
 {
   unsigned int result;
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
+  std::list<VNCSConnectionST*>::iterator ci;
 
   // We can't handle a framebuffer larger than this, so don't let a
   // client set one (see PixelBuffer.cxx)
@@ -580,8 +566,7 @@ unsigned int VNCServerST::setDesktopSize(VNCSConnectionST* requester,
     throw Exception("Desktop configured a different screen layout than requested");
 
   // Notify other clients
-  for (ci=clients.begin();ci!=clients.end();ci=ci_next) {
-    ci_next = ci; ci_next++;
+  for (ci = clients.begin(); ci != clients.end(); ++ci) {
     if ((*ci) == requester)
       continue;
     (*ci)->screenLayoutChangeOrClose(reasonOtherClient);
@@ -606,9 +591,8 @@ void VNCServerST::approveConnection(network::Socket* sock, bool accept,
 
 void VNCServerST::closeClients(const char* reason, network::Socket* except)
 {
-  std::list<VNCSConnectionST*>::iterator i, next_i;
-  for (i=clients.begin(); i!=clients.end(); i=next_i) {
-    next_i = i; next_i++;
+  std::list<VNCSConnectionST*>::iterator i;
+  for (i = clients.begin(); i != clients.end(); ++i) {
     if ((*i)->getSock() != except)
       (*i)->close(reason);
   }
@@ -633,7 +617,7 @@ SConnection* VNCServerST::getConnection(network::Socket* sock) {
     if ((*ci)->getSock() == sock)
       return (SConnection*)*ci;
   }
-  return 0;
+  return nullptr;
 }
 
 void VNCServerST::handleTimeout(Timer* t)
@@ -697,14 +681,14 @@ void VNCServerST::queryConnection(VNCSConnectionST* client,
   // - Are we configured to do queries?
   if (!rfb::Server::queryConnect &&
       !client->getSock()->requiresQuery()) {
-    approveConnection(client->getSock(), true, NULL);
+    approveConnection(client->getSock(), true, nullptr);
     return;
   }
 
   // - Does the client have the right to bypass the query?
   if (client->accessCheck(AccessNoQuery))
   {
-    approveConnection(client->getSock(), true, NULL);
+    approveConnection(client->getSock(), true, nullptr);
     return;
   }
 
@@ -832,7 +816,7 @@ void VNCServerST::writeUpdate()
   UpdateInfo ui;
   Region toCheck;
 
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
+  std::list<VNCSConnectionST*>::iterator ci;
 
   assert(blockCounter == 0);
   assert(desktopStarted);
@@ -861,8 +845,7 @@ void VNCServerST::writeUpdate()
 
   comparer->clear();
 
-  for (ci = clients.begin(); ci != clients.end(); ci = ci_next) {
-    ci_next = ci; ci_next++;
+  for (ci = clients.begin(); ci != clients.end(); ++ci) {
     (*ci)->add_copied(ui.copied, ui.copy_delta);
     (*ci)->add_changed(ui.changed);
     (*ci)->writeFramebufferUpdateOrClose();
@@ -906,9 +889,8 @@ bool VNCServerST::getComparerState()
   if (rfb::Server::compareFB != 2)
     return true;
 
-  std::list<VNCSConnectionST*>::iterator ci, ci_next;
-  for (ci=clients.begin();ci!=clients.end();ci=ci_next) {
-    ci_next = ci; ci_next++;
+  std::list<VNCSConnectionST*>::iterator ci;
+  for (ci = clients.begin(); ci != clients.end(); ++ci) {
     if ((*ci)->getComparerState())
       return true;
   }
diff --git a/common/rfb/VNCServerST.h b/common/rfb/VNCServerST.h
index 90c8d7539..501882aad 100644
--- a/common/rfb/VNCServerST.h
+++ b/common/rfb/VNCServerST.h
@@ -56,54 +56,54 @@ namespace rfb {
     // addSocket
     //   Causes the server to allocate an RFB-protocol management
     //   structure for the socket & initialise it.
-    virtual void addSocket(network::Socket* sock, bool outgoing=false,
-                           AccessRights ar=AccessDefault);
+    void addSocket(network::Socket* sock, bool outgoing=false,
+                   AccessRights ar=AccessDefault) override;
 
     // removeSocket
     //   Clean up any resources associated with the Socket
-    virtual void removeSocket(network::Socket* sock);
+    void removeSocket(network::Socket* sock) override;
 
     // getSockets() gets a list of sockets.  This can be used to generate an
     // fd_set for calling select().
-    virtual void getSockets(std::list<network::Socket*>* sockets);
+    void getSockets(std::list<network::Socket*>* sockets) override;
 
     // processSocketReadEvent
     //   Read more RFB data from the Socket.  If an error occurs during
     //   processing then shutdown() is called on the Socket, causing
     //   removeSocket() to be called by the caller at a later time.
-    virtual void processSocketReadEvent(network::Socket* sock);
+    void processSocketReadEvent(network::Socket* sock) override;
 
     // processSocketWriteEvent
     //   Flush pending data from the Socket on to the network.
-    virtual void processSocketWriteEvent(network::Socket* sock);
-
-    virtual void blockUpdates();
-    virtual void unblockUpdates();
-    virtual uint64_t getMsc();
-    virtual void queueMsc(uint64_t target);
-    virtual void setPixelBuffer(PixelBuffer* pb, const ScreenSet& layout);
-    virtual void setPixelBuffer(PixelBuffer* pb);
-    virtual void setScreenLayout(const ScreenSet& layout);
-    virtual const PixelBuffer* getPixelBuffer() const { return pb; }
-
-    virtual void requestClipboard();
-    virtual void announceClipboard(bool available);
-    virtual void sendClipboardData(const char* data);
-
-    virtual void approveConnection(network::Socket* sock, bool accept,
-                                   const char* reason);
-    virtual void closeClients(const char* reason) {closeClients(reason, 0);}
-    virtual SConnection* getConnection(network::Socket* sock);
-
-    virtual void add_changed(const Region &region);
-    virtual void add_copied(const Region &dest, const Point &delta);
-    virtual void setCursor(int width, int height, const Point& hotspot,
-                           const uint8_t* data);
-    virtual void setCursorPos(const Point& p, bool warped);
-    virtual void setName(const char* name_);
-    virtual void setLEDState(unsigned state);
-
-    virtual void bell();
+    void processSocketWriteEvent(network::Socket* sock) override;
+
+    void blockUpdates() override;
+    void unblockUpdates() override;
+    uint64_t getMsc() override;
+    void queueMsc(uint64_t target) override;
+    void setPixelBuffer(PixelBuffer* pb, const ScreenSet& layout) override;
+    void setPixelBuffer(PixelBuffer* pb) override;
+    void setScreenLayout(const ScreenSet& layout) override;
+    const PixelBuffer* getPixelBuffer() const override { return pb; }
+
+    void requestClipboard() override;
+    void announceClipboard(bool available) override;
+    void sendClipboardData(const char* data) override;
+
+    void approveConnection(network::Socket* sock, bool accept,
+                           const char* reason) override;
+    void closeClients(const char* reason) override {closeClients(reason, nullptr);}
+    SConnection* getConnection(network::Socket* sock) override;
+
+    void add_changed(const Region &region) override;
+    void add_copied(const Region &dest, const Point &delta) override;
+    void setCursor(int width, int height, const Point& hotspot,
+                   const uint8_t* data) override;
+    void setCursorPos(const Point& p, bool warped) override;
+    void setName(const char* name_) override;
+    void setLEDState(unsigned state) override;
+
+    void bell() override;
 
     // VNCServerST-only methods
 
@@ -155,7 +155,7 @@ namespace rfb {
   protected:
 
     // Timer callbacks
-    virtual void handleTimeout(Timer* t);
+    void handleTimeout(Timer* t) override;
 
     // - Internal methods
 
diff --git a/common/rfb/WinPasswdValidator.h b/common/rfb/WinPasswdValidator.h
index ef2310a9a..340a62348 100644
--- a/common/rfb/WinPasswdValidator.h
+++ b/common/rfb/WinPasswdValidator.h
@@ -30,7 +30,7 @@ namespace rfb
     WinPasswdValidator() {};
     virtual ~WinPasswdValidator() {};
   protected:
-    bool validateInternal(SConnection *sc, const char* username, const char* password);
+    bool validateInternal(SConnection *sc, const char* username, const char* password) override;
   };
 }
 
diff --git a/common/rfb/ZRLEDecoder.cxx b/common/rfb/ZRLEDecoder.cxx
index 4b768afcb..474fd6ca1 100644
--- a/common/rfb/ZRLEDecoder.cxx
+++ b/common/rfb/ZRLEDecoder.cxx
@@ -106,20 +106,19 @@ void ZRLEDecoder::decodeRect(const Rect& r, const uint8_t* buffer,
   rdr::MemInStream is(buffer, buflen);
   const rfb::PixelFormat& pf = server.pf();
   switch (pf.bpp) {
-  case 8:  zrleDecode<uint8_t>(r, &is, &zis, pf, pb); break;
-  case 16: zrleDecode<uint16_t>(r, &is, &zis, pf, pb); break;
-  case 32: zrleDecode<uint32_t>(r, &is, &zis, pf, pb); break;
+  case 8:  zrleDecode<uint8_t>(r, &is, pf, pb); break;
+  case 16: zrleDecode<uint16_t>(r, &is, pf, pb); break;
+  case 32: zrleDecode<uint32_t>(r, &is, pf, pb); break;
   }
 }
 
 template<class T>
 void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
-                             rdr::ZlibInStream* zis,
                              const PixelFormat& pf,
                              ModifiablePixelBuffer* pb)
 {
   int length = is->readU32();
-  zis->setUnderlying(is, length);
+  zis.setUnderlying(is, length);
   Rect t;
   T buf[64 * 64];
 
@@ -141,24 +140,24 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
 
       t.br.x = __rfbmin(r.br.x, t.tl.x + 64);
 
-      zlibHasData(zis, 1);
-      int mode = zis->readU8();
+      zlibHasData(&zis, 1);
+      int mode = zis.readU8();
       bool rle = mode & 128;
       int palSize = mode & 127;
       T palette[128];
 
       if (isLowCPixel || isHighCPixel)
-        zlibHasData(zis, 3 * palSize);
+        zlibHasData(&zis, 3 * palSize);
       else
-        zlibHasData(zis, sizeof(T) * palSize);
+        zlibHasData(&zis, sizeof(T) * palSize);
 
       for (int i = 0; i < palSize; i++) {
         if (isLowCPixel)
-          palette[i] = readOpaque24A(zis);
+          palette[i] = readOpaque24A(&zis);
         else if (isHighCPixel)
-          palette[i] = readOpaque24B(zis);
+          palette[i] = readOpaque24B(&zis);
         else
-          palette[i] = readPixel<T>(zis);
+          palette[i] = readPixel<T>(&zis);
       }
 
       if (palSize == 1) {
@@ -173,19 +172,19 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
           // raw
 
           if (isLowCPixel || isHighCPixel)
-            zlibHasData(zis, 3 * t.area());
+            zlibHasData(&zis, 3 * t.area());
           else
-            zlibHasData(zis, sizeof(T) * t.area());
+            zlibHasData(&zis, sizeof(T) * t.area());
 
           if (isLowCPixel || isHighCPixel) {
             for (T* ptr = buf; ptr < buf+t.area(); ptr++) {
               if (isLowCPixel)
-                *ptr = readOpaque24A(zis);
+                *ptr = readOpaque24A(&zis);
               else
-                *ptr = readOpaque24B(zis);
+                *ptr = readOpaque24B(&zis);
             }
           } else {
-            zis->readBytes((uint8_t*)buf, t.area() * sizeof(T));
+            zis.readBytes((uint8_t*)buf, t.area() * sizeof(T));
           }
 
         } else {
@@ -203,8 +202,8 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
 
             while (ptr < eol) {
               if (nbits == 0) {
-                zlibHasData(zis, 1);
-                byte = zis->readU8();
+                zlibHasData(&zis, 1);
+                byte = zis.readU8();
                 nbits = 8;
               }
               nbits -= bppp;
@@ -225,20 +224,20 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
           while (ptr < end) {
             T pix;
             if (isLowCPixel || isHighCPixel)
-              zlibHasData(zis, 3);
+              zlibHasData(&zis, 3);
             else
-              zlibHasData(zis, sizeof(T));
+              zlibHasData(&zis, sizeof(T));
             if (isLowCPixel)
-              pix = readOpaque24A(zis);
+              pix = readOpaque24A(&zis);
             else if (isHighCPixel)
-              pix = readOpaque24B(zis);
+              pix = readOpaque24B(&zis);
             else
-              pix = readPixel<T>(zis);
+              pix = readPixel<T>(&zis);
             int len = 1;
             int b;
             do {
-              zlibHasData(zis, 1);
-              b = zis->readU8();
+              zlibHasData(&zis, 1);
+              b = zis.readU8();
               len += b;
             } while (b == 255);
 
@@ -256,14 +255,14 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
           T* ptr = buf;
           T* end = ptr + t.area();
           while (ptr < end) {
-            zlibHasData(zis, 1);
-            int index = zis->readU8();
+            zlibHasData(&zis, 1);
+            int index = zis.readU8();
             int len = 1;
             if (index & 128) {
               int b;
               do {
-                zlibHasData(zis, 1);
-                b = zis->readU8();
+                zlibHasData(&zis, 1);
+                b = zis.readU8();
                 len += b;
               } while (b == 255);
 
@@ -285,6 +284,6 @@ void ZRLEDecoder::zrleDecode(const Rect& r, rdr::InStream* is,
     }
   }
 
-  zis->flushUnderlying();
-  zis->setUnderlying(NULL, 0);
+  zis.flushUnderlying();
+  zis.setUnderlying(nullptr, 0);
 }
diff --git a/common/rfb/ZRLEDecoder.h b/common/rfb/ZRLEDecoder.h
index e72bf1b67..facf0adca 100644
--- a/common/rfb/ZRLEDecoder.h
+++ b/common/rfb/ZRLEDecoder.h
@@ -30,16 +30,16 @@ namespace rfb {
   public:
     ZRLEDecoder();
     virtual ~ZRLEDecoder();
-    virtual bool readRect(const Rect& r, rdr::InStream* is,
-                          const ServerParams& server, rdr::OutStream* os);
-    virtual void decodeRect(const Rect& r, const uint8_t* buffer,
-                            size_t buflen, const ServerParams& server,
-                            ModifiablePixelBuffer* pb);
+    bool readRect(const Rect& r, rdr::InStream* is,
+                  const ServerParams& server,
+                  rdr::OutStream* os) override;
+    void decodeRect(const Rect& r, const uint8_t* buffer,
+                    size_t buflen, const ServerParams& server,
+                    ModifiablePixelBuffer* pb) override;
 
   private:
     template<class T>
     void zrleDecode(const Rect& r, rdr::InStream* is,
-                    rdr::ZlibInStream* zis,
                     const PixelFormat& pf, ModifiablePixelBuffer* pb);
 
   private:
diff --git a/common/rfb/ZRLEEncoder.cxx b/common/rfb/ZRLEEncoder.cxx
index ad3aec1a8..1e2c6ef47 100644
--- a/common/rfb/ZRLEEncoder.cxx
+++ b/common/rfb/ZRLEEncoder.cxx
@@ -36,9 +36,9 @@ static LogWriter vlog("ZRLEEncoder");
 
 IntParameter zlibLevel("ZlibLevel","[DEPRECATED] Zlib compression level",-1);
 
-ZRLEEncoder::ZRLEEncoder(SConnection* conn)
-  : Encoder(conn, encodingZRLE, EncoderPlain, 127),
-  zos(0, 2), mos(129*1024)
+ZRLEEncoder::ZRLEEncoder(SConnection* conn_)
+  : Encoder(conn_, encodingZRLE, EncoderPlain, 127),
+  zos(nullptr, 2), mos(129*1024)
 {
   if (zlibLevel != -1) {
     vlog.info("Warning: The ZlibLevel option is deprecated and is "
@@ -50,7 +50,7 @@ ZRLEEncoder::ZRLEEncoder(SConnection* conn)
 
 ZRLEEncoder::~ZRLEEncoder()
 {
-  zos.setUnderlying(NULL);
+  zos.setUnderlying(nullptr);
 }
 
 bool ZRLEEncoder::isSupported()
diff --git a/common/rfb/ZRLEEncoder.h b/common/rfb/ZRLEEncoder.h
index fa89f10f3..87d87e94f 100644
--- a/common/rfb/ZRLEEncoder.h
+++ b/common/rfb/ZRLEEncoder.h
@@ -30,14 +30,14 @@ namespace rfb {
     ZRLEEncoder(SConnection* conn);
     virtual ~ZRLEEncoder();
 
-    virtual bool isSupported();
+    bool isSupported() override;
 
-    virtual void setCompressLevel(int level);
+    void setCompressLevel(int level) override;
 
-    virtual void writeRect(const PixelBuffer* pb, const Palette& palette);
-    virtual void writeSolidRect(int width, int height,
-                                const PixelFormat& pf,
-                                const uint8_t* colour);
+    void writeRect(const PixelBuffer* pb,
+                   const Palette& palette) override;
+    void writeSolidRect(int width, int height, const PixelFormat& pf,
+                        const uint8_t* colour) override;
 
   protected:
     void writePaletteTile(const Rect& tile, const PixelBuffer* pb,
diff --git a/common/rfb/obfuscate.cxx b/common/rfb/obfuscate.cxx
index d40e25c3e..2afc15123 100644
--- a/common/rfb/obfuscate.cxx
+++ b/common/rfb/obfuscate.cxx
@@ -41,7 +41,7 @@ std::vector<uint8_t> rfb::obfuscate(const char *str)
 {
   std::vector<uint8_t> buf(8);
 
-  assert(str != NULL);
+  assert(str != nullptr);
 
   size_t l = strlen(str), i;
   for (i=0; i<8; i++)
@@ -59,7 +59,7 @@ std::string rfb::deobfuscate(const uint8_t *data, size_t len)
   if (len != 8)
     throw rdr::Exception("bad obfuscated password length");
 
-  assert(data != NULL);
+  assert(data != nullptr);
 
   deskey(d3desObfuscationKey, DE1);
   des((uint8_t*)data, (uint8_t*)buf);
diff --git a/common/rfb/util.cxx b/common/rfb/util.cxx
index 48f59846d..3c62b1dfb 100644
--- a/common/rfb/util.cxx
+++ b/common/rfb/util.cxx
@@ -40,7 +40,7 @@ namespace rfb {
     std::string out;
 
     va_start(ap, fmt);
-    len = vsnprintf(NULL, 0, fmt, ap);
+    len = vsnprintf(nullptr, 0, fmt, ap);
     va_end(ap);
 
     if (len < 0)
@@ -68,13 +68,13 @@ namespace rfb {
     start = src;
     do {
       stop = strchr(start, delimiter);
-      if (stop == NULL) {
+      if (stop == nullptr) {
         out.push_back(start);
       } else {
         out.push_back(std::string(start, stop-start));
         start = stop + 1;
       }
-    } while (stop != NULL);
+    } while (stop != nullptr);
 
     return out;
   }
@@ -621,7 +621,7 @@ namespace rfb {
   {
     struct timeval now;
 
-    gettimeofday(&now, NULL);
+    gettimeofday(&now, nullptr);
 
     return msBetween(then, &now);
   }
diff --git a/release/CMakeLists.txt b/release/CMakeLists.txt
index 043cc1c50..6cb14de0c 100644
--- a/release/CMakeLists.txt
+++ b/release/CMakeLists.txt
@@ -18,7 +18,7 @@ configure_file(tigervnc.iss.in tigervnc.iss)
 add_custom_target(installer
   iscc -o. ${INST_DEFS} -F${CMAKE_PROJECT_NAME}${INST_SUFFIX}-${VERSION} tigervnc.iss
   DEPENDS vncviewer
-  SOURCES tigervnc.iss)
+  SOURCES ${CMAKE_CURRENT_BINARY_DIR}/tigervnc.iss)
 
 if(BUILD_WINVNC)
   configure_file(winvnc.iss.in winvnc.iss)
@@ -26,7 +26,7 @@ if(BUILD_WINVNC)
   add_custom_target(winvnc_installer
     iscc -o. ${INST_DEFS} -F${CMAKE_PROJECT_NAME}${INST_SUFFIX}-winvnc-${VERSION} winvnc.iss
     DEPENDS winvnc4 wm_hooks vncconfig
-    SOURCES winvnc.iss)
+    SOURCES ${CMAKE_CURRENT_BINARY_DIR}/winvnc.iss)
 endif()
 
 endif() # WIN32
diff --git a/tests/perf/decperf.cxx b/tests/perf/decperf.cxx
index c72ec1d7c..66a50d024 100644
--- a/tests/perf/decperf.cxx
+++ b/tests/perf/decperf.cxx
@@ -52,11 +52,11 @@ class DummyOutStream : public rdr::OutStream {
 public:
   DummyOutStream();
 
-  virtual size_t length();
-  virtual void flush();
+  size_t length() override;
+  void flush() override;
 
 private:
-  virtual void overrun(size_t needed);
+  void overrun(size_t needed) override;
 
   int offset;
   uint8_t buf[131072];
@@ -67,15 +67,15 @@ class CConn : public rfb::CConnection {
   CConn(const char *filename);
   ~CConn();
 
-  virtual void initDone();
-  virtual void setPixelFormat(const rfb::PixelFormat& pf);
-  virtual void setCursor(int, int, const rfb::Point&, const uint8_t*);
-  virtual void setCursorPos(const rfb::Point&);
-  virtual void framebufferUpdateStart();
-  virtual void framebufferUpdateEnd();
-  virtual void setColourMapEntries(int, int, uint16_t*);
-  virtual void bell();
-  virtual void serverCutText(const char*);
+  void initDone() override;
+  void setPixelFormat(const rfb::PixelFormat& pf) override;
+  void setCursor(int, int, const rfb::Point&, const uint8_t*) override;
+  void setCursorPos(const rfb::Point&) override;
+  void framebufferUpdateStart() override;
+  void framebufferUpdateEnd() override;
+  void setColourMapEntries(int, int, uint16_t*) override;
+  void bell() override;
+  void serverCutText(const char*) override;
 
 public:
   double cpuTime;
@@ -193,7 +193,7 @@ static struct stats runTest(const char *fn)
   struct timeval start, stop;
   struct stats s;
 
-  gettimeofday(&start, NULL);
+  gettimeofday(&start, nullptr);
 
   try {
     cc = new CConn(fn);
@@ -211,7 +211,7 @@ static struct stats runTest(const char *fn)
     exit(1);
   }
 
-  gettimeofday(&stop, NULL);
+  gettimeofday(&stop, nullptr);
 
   s.decodeTime = cc->cpuTime;
   s.realTime = (double)stop.tv_sec - start.tv_sec;
diff --git a/tests/perf/encperf.cxx b/tests/perf/encperf.cxx
index 388dcc955..25dca4908 100644
--- a/tests/perf/encperf.cxx
+++ b/tests/perf/encperf.cxx
@@ -80,11 +80,11 @@ class DummyOutStream : public rdr::OutStream {
 public:
   DummyOutStream();
 
-  virtual size_t length();
-  virtual void flush();
+  size_t length() override;
+  void flush() override;
 
 private:
-  virtual void overrun(size_t needed);
+  void overrun(size_t needed) override;
 
   int offset;
   uint8_t buf[131072];
@@ -98,16 +98,16 @@ class CConn : public rfb::CConnection {
   void getStats(double& ratio, unsigned long long& bytes,
                 unsigned long long& rawEquivalent);
 
-  virtual void initDone() {};
-  virtual void resizeFramebuffer();
-  virtual void setCursor(int, int, const rfb::Point&, const uint8_t*);
-  virtual void setCursorPos(const rfb::Point&);
-  virtual void framebufferUpdateStart();
-  virtual void framebufferUpdateEnd();
-  virtual bool dataRect(const rfb::Rect&, int);
-  virtual void setColourMapEntries(int, int, uint16_t*);
-  virtual void bell();
-  virtual void serverCutText(const char*);
+  void initDone() override {};
+  void resizeFramebuffer() override;
+  void setCursor(int, int, const rfb::Point&, const uint8_t*) override;
+  void setCursorPos(const rfb::Point&) override;
+  void framebufferUpdateStart() override;
+  void framebufferUpdateEnd() override;
+  bool dataRect(const rfb::Rect&, int) override;
+  void setColourMapEntries(int, int, uint16_t*) override;
+  void bell() override;
+  void serverCutText(const char*) override;
 
 public:
   double decodeTime;
@@ -136,10 +136,10 @@ class SConn : public rfb::SConnection {
 
   void getStats(double&, unsigned long long&, unsigned long long&);
 
-  virtual void setAccessRights(rfb::AccessRights ar);
+  void setAccessRights(rfb::AccessRights ar) override;
 
-  virtual void setDesktopSize(int fb_width, int fb_height,
-                              const rfb::ScreenSet& layout);
+  void setDesktopSize(int fb_width, int fb_height,
+                      const rfb::ScreenSet& layout) override;
 
 protected:
   DummyOutStream *out;
@@ -279,8 +279,8 @@ void CConn::serverCutText(const char*)
 {
 }
 
-Manager::Manager(class rfb::SConnection *conn) :
-  EncodeManager(conn)
+Manager::Manager(class rfb::SConnection *conn_) :
+  EncodeManager(conn_)
 {
 }
 
@@ -308,7 +308,7 @@ SConn::SConn()
 : SConnection(rfb::AccessDefault)
 {
   out = new DummyOutStream;
-  setStreams(NULL, out);
+  setStreams(nullptr, out);
 
   setWriter(new rfb::SMsgWriter(&client, out));
 
@@ -323,7 +323,7 @@ SConn::~SConn()
 
 void SConn::writeUpdate(const rfb::UpdateInfo& ui, const rfb::PixelBuffer* pb)
 {
-  manager->writeUpdate(ui, pb, NULL);
+  manager->writeUpdate(ui, pb, nullptr);
 }
 
 void SConn::getStats(double& ratio, unsigned long long& bytes,
@@ -357,7 +357,7 @@ static struct stats runTest(const char *fn)
   struct stats s;
   struct timeval start, stop;
 
-  gettimeofday(&start, NULL);
+  gettimeofday(&start, nullptr);
 
   try {
     cc = new CConn(fn);
@@ -375,7 +375,7 @@ static struct stats runTest(const char *fn)
     exit(1);
   }
 
-  gettimeofday(&stop, NULL);
+  gettimeofday(&stop, nullptr);
 
   s.decodeTime = cc->decodeTime;
   s.encodeTime = cc->encodeTime;
@@ -388,13 +388,13 @@ static struct stats runTest(const char *fn)
   return s;
 }
 
-static void sort(double *array, int count)
+static void sort(double *array, int len)
 {
   bool sorted;
   int i;
   do {
     sorted = true;
-    for (i = 1; i < count; i++) {
+    for (i = 1; i < len; i++) {
       if (array[i-1] > array[i]) {
         double d;
         d = array[i];
@@ -420,7 +420,7 @@ int main(int argc, char **argv)
 
   const char *fn;
 
-  fn = NULL;
+  fn = nullptr;
   for (i = 1; i < argc; i++) {
     if (rfb::Configuration::setParam(argv[i]))
       continue;
@@ -435,7 +435,7 @@ int main(int argc, char **argv)
       usage(argv[0]);
     }
 
-    if (fn != NULL)
+    if (fn != nullptr)
       usage(argv[0]);
 
     fn = argv[i];
@@ -447,7 +447,7 @@ int main(int argc, char **argv)
   double *dev = new double[runCount];
   double median, meddev;
 
-  if (fn == NULL) {
+  if (fn == nullptr) {
     fprintf(stderr, "No file specified!\n\n");
     usage(argv[0]);
   }
diff --git a/tests/perf/fbperf.cxx b/tests/perf/fbperf.cxx
index dddf19fb4..357aede2b 100644
--- a/tests/perf/fbperf.cxx
+++ b/tests/perf/fbperf.cxx
@@ -43,10 +43,10 @@ class TestWindow: public Fl_Window {
   virtual void start(int width, int height);
   virtual void stop();
 
-  virtual void draw();
+  void draw() override;
 
 protected:
-  virtual void flush();
+  void flush() override;
 
   void update();
   virtual void changefb();
@@ -63,17 +63,17 @@ class TestWindow: public Fl_Window {
 
 class PartialTestWindow: public TestWindow {
 protected:
-  virtual void changefb();
+  void changefb() override;
 };
 
 class OverlayTestWindow: public PartialTestWindow {
 public:
   OverlayTestWindow();
 
-  virtual void start(int width, int height);
-  virtual void stop();
+  void start(int width, int height) override;
+  void stop() override;
 
-  virtual void draw();
+  void draw() override;
 
 protected:
   Surface* overlay;
@@ -82,7 +82,7 @@ class OverlayTestWindow: public PartialTestWindow {
 
 TestWindow::TestWindow() :
   Fl_Window(0, 0, "Framebuffer Performance Test"),
-  fb(NULL)
+  fb(nullptr)
 {
 }
 
@@ -116,7 +116,7 @@ void TestWindow::stop()
   hide();
 
   delete fb;
-  fb = NULL;
+  fb = nullptr;
 
   Fl::remove_idle(timer, this);
 }
@@ -208,7 +208,7 @@ void PartialTestWindow::changefb()
 }
 
 OverlayTestWindow::OverlayTestWindow() :
-  overlay(NULL), offscreen(NULL)
+  overlay(nullptr), offscreen(nullptr)
 {
 }
 
@@ -224,7 +224,7 @@ void OverlayTestWindow::start(int width, int height)
 #if !defined(__APPLE__)
   offscreen = new Surface(w(), h());
 #else
-  offscreen = NULL;
+  offscreen = nullptr;
 #endif
 }
 
@@ -233,9 +233,9 @@ void OverlayTestWindow::stop()
   PartialTestWindow::stop();
 
   delete offscreen;
-  offscreen = NULL;
+  offscreen = nullptr;
   delete overlay;
-  overlay = NULL;
+  overlay = nullptr;
 }
 
 void OverlayTestWindow::draw()
@@ -299,7 +299,7 @@ static void dosubtest(TestWindow* win, int width, int height,
 
   win->start(width, height);
 
-  gettimeofday(&start, NULL);
+  gettimeofday(&start, nullptr);
   while (rfb::msSince(&start) < 3000)
     Fl::wait();
 
diff --git a/tests/perf/util.cxx b/tests/perf/util.cxx
index 98b2568e8..2720c237c 100644
--- a/tests/perf/util.cxx
+++ b/tests/perf/util.cxx
@@ -65,8 +65,8 @@ cpucounter_t newCpuCounter(void)
   syscounter_t *c;
 
   c = (syscounter_t*)malloc(sizeof(syscounter_t) * 2);
-  if (c == NULL)
-    return NULL;
+  if (c == nullptr)
+    return nullptr;
 
   memset(c, 0, sizeof(syscounter_t) * 2);
 
@@ -149,7 +149,7 @@ void startTimeCounter(void)
 #ifdef WIN32
   QueryPerformanceCounter(&timeStart);
 #else
-  gettimeofday(&timeStart, NULL);
+  gettimeofday(&timeStart, nullptr);
 #endif
 }
 
@@ -158,7 +158,7 @@ void endTimeCounter(void)
 #ifdef WIN32
   QueryPerformanceCounter(&timeEnd);
 #else
-  gettimeofday(&timeEnd, NULL);
+  gettimeofday(&timeEnd, nullptr);
 #endif
 }
 
diff --git a/tests/unit/emulatemb.cxx b/tests/unit/emulatemb.cxx
index 7dfc2541f..662eedef5 100644
--- a/tests/unit/emulatemb.cxx
+++ b/tests/unit/emulatemb.cxx
@@ -42,7 +42,7 @@ rfb::BoolParameter emulateMiddleButton("dummy_name", "dummy_desc", true);
 class TestClass : public EmulateMB
 {
 public:
-  virtual void sendPointerEvent(const rfb::Point& pos, int buttonMask);
+  void sendPointerEvent(const rfb::Point& pos, int buttonMask) override;
 
   struct PointerEventParams {rfb::Point pos; int mask; };
 
diff --git a/tests/unit/gesturehandler.cxx b/tests/unit/gesturehandler.cxx
index bc39c24c1..73b8c62cf 100644
--- a/tests/unit/gesturehandler.cxx
+++ b/tests/unit/gesturehandler.cxx
@@ -30,7 +30,7 @@
 class TestClass : public GestureHandler
 {
   protected:
-    virtual void handleGestureEvent(const GestureEvent& event);
+    void handleGestureEvent(const GestureEvent& event) override;
 
   public:
     std::vector<GestureEvent> events;
diff --git a/tests/unit/pixelformat.cxx b/tests/unit/pixelformat.cxx
index a2ca50d03..614d12554 100644
--- a/tests/unit/pixelformat.cxx
+++ b/tests/unit/pixelformat.cxx
@@ -36,7 +36,7 @@ static void doTest(bool should_fail, int b, int d, bool e, bool t,
 
     try {
         pf = new rfb::PixelFormat(b, d, e, t, rm, gm, bm, rs, gs, bs);
-    } catch(rfb::Exception &e) {
+    } catch(rfb::Exception&) {
         if (should_fail)
             printf("OK");
         else
diff --git a/tests/unit/unicode.cxx b/tests/unit/unicode.cxx
index cb15e7e1d..718150421 100644
--- a/tests/unit/unicode.cxx
+++ b/tests/unit/unicode.cxx
@@ -180,7 +180,7 @@ int main(int /*argc*/, char** /*argv*/)
 
     for (i = 0;i < ARRAY_SIZE(latin1utf8);i++) {
         /* Expected failure? */
-        if (strchr(latin1utf8[i].latin1, '?') != NULL)
+        if (strchr(latin1utf8[i].latin1, '?') != nullptr)
             continue;
 
         out = rfb::latin1ToUTF8(latin1utf8[i].latin1);
@@ -212,7 +212,7 @@ int main(int /*argc*/, char** /*argv*/)
 
     for (i = 0;i < ARRAY_SIZE(utf8utf16);i++) {
         /* Expected failure? */
-        if (strstr(utf8utf16[i].utf8, "\xef\xbf\xbd") != NULL)
+        if (strstr(utf8utf16[i].utf8, "\xef\xbf\xbd") != nullptr)
             continue;
 
         wout = rfb::utf8ToUTF16(utf8utf16[i].utf8);
diff --git a/unix/common/randr.cxx b/unix/common/randr.cxx
index 12c4841f4..e4e2d7bed 100644
--- a/unix/common/randr.cxx
+++ b/unix/common/randr.cxx
@@ -236,10 +236,14 @@ static unsigned int _setScreenLayout(bool dryrun,
   /* Next, reconfigure all known outputs */
   for (int i = 0;i < vncRandRGetOutputCount();i++) {
     unsigned int output;
+    char *name_;
+    std::string name;
 
     rfb::ScreenSet::const_iterator iter;
 
     output = vncRandRGetOutputId(i);
+    name = name_ = vncRandRGetOutputName(i);
+    free(name_);
 
     /* Known? */
     if (outputIdMap->count(output) == 0)
@@ -259,31 +263,24 @@ static unsigned int _setScreenLayout(bool dryrun,
 
     /* Probably not needed, but let's be safe */
     if (!vncRandRIsOutputUsable(i)) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("Required output '%s' cannot be used", name);
-        free(name);
-      }
+      if (logErrors)
+        vlog.error("Required output '%s' cannot be used", name.c_str());
       return rfb::resultInvalid;
     }
 
     /* Possible mode? */
     if (!vncRandRCheckOutputMode(i, iter->dimensions.width(),
                                  iter->dimensions.height())) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("Output '%s' does not support required mode %dx%d", name,
+      if (logErrors)
+        vlog.error("Output '%s' does not support required mode %dx%d",
+                   name.c_str(),
                    iter->dimensions.width(), iter->dimensions.height());
-        free(name);
-      }
       return rfb::resultInvalid;
     }
 
-    char *name = vncRandRGetOutputName(i);
-    vlog.debug("Reconfiguring output '%s' to %dx%d+%d+%d", name,
+    vlog.debug("Reconfiguring output '%s' to %dx%d+%d+%d", name.c_str(),
                iter->dimensions.width(), iter->dimensions.height(),
                iter->dimensions.tl.x, iter->dimensions.tl.y);
-    free(name);
 
     if (dryrun)
       continue;
@@ -295,13 +292,11 @@ static unsigned int _setScreenLayout(bool dryrun,
                                     iter->dimensions.width(),
                                     iter->dimensions.height());
     if (!ret) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("Failed to reconfigure output '%s' to %dx%d+%d+%d", name,
+      if (logErrors)
+        vlog.error("Failed to reconfigure output '%s' to %dx%d+%d+%d",
+                   name.c_str(),
                    iter->dimensions.width(), iter->dimensions.height(),
                    iter->dimensions.tl.x, iter->dimensions.tl.y);
-        free(name);
-      }
       return rfb::resultInvalid;
     }
   }
@@ -311,6 +306,8 @@ static unsigned int _setScreenLayout(bool dryrun,
   for (iter = layout.begin();iter != layout.end();++iter) {
     OutputIdMap::const_iterator oi;
     unsigned int output;
+    char *name_;
+    std::string name;
     int i;
 
     /* Does this screen have an output already? */
@@ -332,6 +329,8 @@ static unsigned int _setScreenLayout(bool dryrun,
       return rfb::resultInvalid;
     }
     output = vncRandRGetOutputId(i);
+    name = name_ = vncRandRGetOutputName(i);
+    free(name_);
 
     /*
      * Make sure we already have an entry for this, or
@@ -342,31 +341,24 @@ static unsigned int _setScreenLayout(bool dryrun,
 
     /* Probably not needed, but let's be safe */
     if (!vncRandRIsOutputUsable(i)) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("Required new output '%s' cannot be used", name);
-        free(name);
-      }
+      if (logErrors)
+        vlog.error("Required new output '%s' cannot be used", name.c_str());
       return rfb::resultInvalid;
     }
 
     /* Possible mode? */
     if (!vncRandRCheckOutputMode(i, iter->dimensions.width(),
                                  iter->dimensions.height())) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("New output '%s' does not support required mode %dx%d", name,
+      if (logErrors)
+        vlog.error("New output '%s' does not support required mode %dx%d",
+                   name.c_str(),
                    iter->dimensions.width(), iter->dimensions.height());
-        free(name);
-      }
       return rfb::resultInvalid;
     }
 
-    char *name = vncRandRGetOutputName(i);
-    vlog.debug("Reconfiguring new output '%s' to %dx%d+%d+%d", name,
+    vlog.debug("Reconfiguring new output '%s' to %dx%d+%d+%d", name.c_str(),
                iter->dimensions.width(), iter->dimensions.height(),
                iter->dimensions.tl.x, iter->dimensions.tl.y);
-    free(name);
 
     if (dryrun)
       continue;
@@ -378,13 +370,11 @@ static unsigned int _setScreenLayout(bool dryrun,
                                     iter->dimensions.width(),
                                     iter->dimensions.height());
     if (!ret) {
-      if (logErrors) {
-        char *name = vncRandRGetOutputName(i);
-        vlog.error("Failed to reconfigure new output '%s' to %dx%d+%d+%d", name,
+      if (logErrors)
+        vlog.error("Failed to reconfigure new output '%s' to %dx%d+%d+%d",
+                   name.c_str(),
                    iter->dimensions.width(), iter->dimensions.height(),
                    iter->dimensions.tl.x, iter->dimensions.tl.y);
-        free(name);
-      }
       return rfb::resultInvalid;
     }
   }
diff --git a/unix/tx/TXButton.h b/unix/tx/TXButton.h
index a51f2ecd2..889648333 100644
--- a/unix/tx/TXButton.h
+++ b/unix/tx/TXButton.h
@@ -41,14 +41,15 @@ class TXButtonCallback {
 class TXButton : public TXWindow, public TXEventHandler {
 public:
 
-  TXButton(Display* dpy_, const char* text_, TXButtonCallback* cb_=0,
-           TXWindow* parent_=0, int w=1, int h=1)
+  TXButton(Display* dpy_, const char* text_,
+           TXButtonCallback* cb_=nullptr,
+           TXWindow* parent_=nullptr, int w=1, int h=1)
     : TXWindow(dpy_, w, h, parent_), cb(cb_), down(false),
       disabled_(false)
   {
     setEventHandler(this);
     setText(text_);
-    gc = XCreateGC(dpy, win(), 0, 0);
+    gc = XCreateGC(dpy, win(), 0, nullptr);
     XSetFont(dpy, gc, defaultFont);
     addEventMask(ExposureMask | ButtonPressMask | ButtonReleaseMask);
   }
@@ -91,7 +92,7 @@ class TXButton : public TXWindow, public TXEventHandler {
     XDrawString(dpy, win(), gc, startx, starty, text.data(), text.size());
   }
 
-  virtual void handleEvent(TXWindow* /*w*/, XEvent* ev) {
+  void handleEvent(TXWindow* /*w*/, XEvent* ev) override {
     switch (ev->type) {
     case Expose:
       paint();
diff --git a/unix/tx/TXCheckbox.h b/unix/tx/TXCheckbox.h
index 76cdc9508..179e3e848 100644
--- a/unix/tx/TXCheckbox.h
+++ b/unix/tx/TXCheckbox.h
@@ -48,14 +48,15 @@ class TXCheckboxCallback {
 class TXCheckbox : public TXWindow, public TXEventHandler {
 public:
   TXCheckbox(Display* dpy_, const char* text_, TXCheckboxCallback* cb_,
-             bool radio_=false, TXWindow* parent_=0, int w=1, int h=1)
-    : TXWindow(dpy_, w, h, parent_), cb(cb_), text(0),
+             bool radio_=false, TXWindow* parent_=nullptr,
+             int w=1, int h=1)
+    : TXWindow(dpy_, w, h, parent_), cb(cb_), text(nullptr),
       boxSize(radio_ ? 12 : 13), boxPad(4),
       checked_(false), disabled_(false), radio(radio_)
   {
     setEventHandler(this);
     setText(text_);
-    gc = XCreateGC(dpy, win(), 0, 0);
+    gc = XCreateGC(dpy, win(), 0, nullptr);
     XSetFont(dpy, gc, defaultFont);
     addEventMask(ExposureMask| ButtonPressMask | ButtonReleaseMask);
   }
@@ -109,7 +110,7 @@ class TXCheckbox : public TXWindow, public TXEventHandler {
                 text, strlen(text));
   }
 
-  virtual void handleEvent(TXWindow* /*w*/, XEvent* ev) {
+  void handleEvent(TXWindow* /*w*/, XEvent* ev) override {
     switch (ev->type) {
     case Expose:
       paint();
diff --git a/unix/tx/TXDialog.h b/unix/tx/TXDialog.h
index 861a20bec..720c50d0d 100644
--- a/unix/tx/TXDialog.h
+++ b/unix/tx/TXDialog.h
@@ -33,9 +33,9 @@
 
 class TXDialog : public TXWindow, public TXDeleteWindowCallback {
 public:
-  TXDialog(Display* dpy, int width, int height, const char* name,
+  TXDialog(Display* dpy_, int width, int height, const char* name,
            bool modal_=false)
-    : TXWindow(dpy, width, height), done(false), ok(false), modal(modal_)
+    : TXWindow(dpy_, width, height), done(false), ok(false), modal(modal_)
   {
     toplevel(name, this);
     resize(width, height);
@@ -62,7 +62,7 @@ class TXDialog : public TXWindow, public TXDeleteWindowCallback {
         fd_set rfds;
         FD_ZERO(&rfds);
         FD_SET(ConnectionNumber(dpy), &rfds);
-        int n = select(FD_SETSIZE, &rfds, 0, 0, 0);
+        int n = select(FD_SETSIZE, &rfds, nullptr, nullptr, nullptr);
         if (n < 0) throw rdr::SystemException("select",errno);
       }
     }
@@ -82,7 +82,7 @@ class TXDialog : public TXWindow, public TXDeleteWindowCallback {
   }    
 
 protected:
-  virtual void deleteWindow(TXWindow* /*w*/) {
+  void deleteWindow(TXWindow* /*w*/) override {
     ok = false;
     done = true;
     unmap();
diff --git a/unix/tx/TXLabel.h b/unix/tx/TXLabel.h
index 24b8cbb38..1e0cc0e51 100644
--- a/unix/tx/TXLabel.h
+++ b/unix/tx/TXLabel.h
@@ -35,7 +35,7 @@ class TXLabel : public TXWindow, public TXEventHandler {
   enum HAlign { left, centre, right };
   enum VAlign { top, middle, bottom };
 
-  TXLabel(Display* dpy_, const char* text_, TXWindow* parent_=0,
+  TXLabel(Display* dpy_, const char* text_, TXWindow* parent_=nullptr,
           int w=1, int h=1, HAlign ha=centre, VAlign va=middle)
     : TXWindow(dpy_, w, h, parent_), lineSpacing(2), lines(0),
       halign(ha), valign(va)
@@ -108,7 +108,7 @@ class TXLabel : public TXWindow, public TXEventHandler {
     } while (i < text.size());
   }
 
-  virtual void handleEvent(TXWindow* /*w*/, XEvent* ev) {
+  void handleEvent(TXWindow* /*w*/, XEvent* ev) override {
     switch (ev->type) {
     case Expose:
       paint();
diff --git a/unix/tx/TXWindow.cxx b/unix/tx/TXWindow.cxx
index ee097e45e..343b9c28c 100644
--- a/unix/tx/TXWindow.cxx
+++ b/unix/tx/TXWindow.cxx
@@ -44,15 +44,15 @@ unsigned long TXWindow::disabledFg, TXWindow::disabledBg;
 unsigned long TXWindow::enabledBg;
 unsigned long TXWindow::scrollbarBg;
 Colormap TXWindow::cmap = 0;
-GC TXWindow::defaultGC = 0;
+GC TXWindow::defaultGC = nullptr;
 Font TXWindow::defaultFont = 0;
-XFontStruct* TXWindow::defaultFS = 0;
+XFontStruct* TXWindow::defaultFS = nullptr;
 Time TXWindow::cutBufferTime = 0;
 Pixmap TXWindow::dot = 0, TXWindow::tick = 0;
 const int TXWindow::dotSize = 4, TXWindow::tickSize = 8;
 char* TXWindow::defaultWindowClass;
 
-TXGlobalEventHandler* TXWindow::globalEventHandler = NULL;
+TXGlobalEventHandler* TXWindow::globalEventHandler = nullptr;
 
 void TXWindow::init(Display* dpy, const char* defaultWindowClass_)
 {
@@ -79,7 +79,7 @@ void TXWindow::init(Display* dpy, const char* defaultWindowClass_)
   darkBg = disabledFg = cols[3].pixel;
   scrollbarBg = cols[4].pixel;
   white = enabledBg = cols[5].pixel;
-  defaultGC = XCreateGC(dpy, DefaultRootWindow(dpy), 0, 0);
+  defaultGC = XCreateGC(dpy, DefaultRootWindow(dpy), 0, nullptr);
   defaultFS
     = XLoadQueryFont(dpy, "-*-helvetica-medium-r-*-*-12-*-*-*-*-*-*-*");
   if (!defaultFS) {
@@ -258,7 +258,8 @@ Window TXWindow::windowWithName(Display* dpy, Window top, const char* name)
 TXWindow::TXWindow(Display* dpy_, int w, int h, TXWindow* parent_,
                    int borderWidth)
   : dpy(dpy_), xPad(3), yPad(3), bevel(2), parent(parent_), width_(w),
-    height_(h), eventHandler(0), dwc(0), eventMask(0), toplevel_(false)
+    height_(h), eventHandler(nullptr), dwc(nullptr), eventMask(0),
+    toplevel_(false)
 {
   sizeHints.flags = 0;
   XSetWindowAttributes attr;
@@ -266,7 +267,8 @@ TXWindow::TXWindow(Display* dpy_, int w, int h, TXWindow* parent_,
   attr.border_pixel = 0;
   Window par = parent ? parent->win() : DefaultRootWindow(dpy);
   win_ = XCreateWindow(dpy, par, 0, 0, width_, height_, borderWidth,
-                      CopyFromParent, CopyFromParent, CopyFromParent,
+                      CopyFromParent, CopyFromParent,
+                      (Visual*)CopyFromParent,
                       CWBackPixel | CWBorderPixel, &attr);
   if (parent) map();
 
@@ -292,7 +294,7 @@ void TXWindow::toplevel(const char* name, TXDeleteWindowCallback* dwc_,
   if (!windowClass) windowClass = defaultWindowClass;
   classHint.res_name = (char*)name;
   classHint.res_class = (char*)windowClass;
-  XSetWMProperties(dpy, win(), 0, 0, argv, argc,
+  XSetWMProperties(dpy, win(), nullptr, nullptr, argv, argc,
                    &sizeHints, &wmHints, &classHint);
   XStoreName(dpy, win(), name);
   XSetIconName(dpy, win(), name);
@@ -443,7 +445,7 @@ void TXWindow::handleXEvent(XEvent* ev)
         break;
       }
     }
-    selectionNotify(&ev->xselection, 0, 0, 0, 0);
+    selectionNotify(&ev->xselection, 0, 0, 0, nullptr);
     break;
 
   case SelectionRequest:
diff --git a/unix/tx/TXWindow.h b/unix/tx/TXWindow.h
index 223c07a84..9f2a30cb2 100644
--- a/unix/tx/TXWindow.h
+++ b/unix/tx/TXWindow.h
@@ -65,7 +65,8 @@ class TXWindow {
   // background (currently grey).  It is mapped by default if it has a parent.
   // If no parent is specified its parent is the root window and it will remain
   // unmapped.
-  TXWindow(Display* dpy_, int width=1, int height=1, TXWindow* parent_=0,
+  TXWindow(Display* dpy_, int width=1, int height=1,
+           TXWindow* parent_=nullptr,
            int borderWidth=0);
   virtual ~TXWindow();
 
@@ -73,8 +74,9 @@ class TXWindow {
   // window-manager-related properties are set on the window.  The given
   // TXDeleteWindowCallback is notified when the window is "deleted" (cloesd)
   // by the user.
-  void toplevel(const char* name, TXDeleteWindowCallback* dwc=0,
-                int argc=0, char** argv=0, const char* windowClass=0,
+  void toplevel(const char* name, TXDeleteWindowCallback* dwc=nullptr,
+                int argc=0, char** argv=nullptr,
+                const char* windowClass=nullptr,
                 bool iconic=false);
 
   // setMaxSize() tells the window manager the maximum size to allow a
@@ -181,7 +183,7 @@ class TXWindow {
 
   // strEmptyToNull() returns the string it's given but turns an empty string
   // into null, which can be useful for passing rfb parameters to Xlib calls.
-  static char* strEmptyToNull(char* s) { return s && s[0] ? s : 0; }
+  static char* strEmptyToNull(char* s) { return s && s[0] ? s : nullptr; }
 
   // The following are default values for various things.
   static unsigned long black, white;
diff --git a/unix/vncconfig/QueryConnectDialog.cxx b/unix/vncconfig/QueryConnectDialog.cxx
index e725de7d1..aa1b78ad0 100644
--- a/unix/vncconfig/QueryConnectDialog.cxx
+++ b/unix/vncconfig/QueryConnectDialog.cxx
@@ -25,12 +25,12 @@
 #include "QueryConnectDialog.h"
 #include "vncExt.h"
 
-QueryConnectDialog::QueryConnectDialog(Display* dpy,
+QueryConnectDialog::QueryConnectDialog(Display* dpy_,
                                        const char* address_,
                                        const char* user_,
                                        int timeout_,
                                        QueryResultCallback* cb)
-  : TXDialog(dpy, 300, 100, "VNC Server : Accept Connection?"),
+  : TXDialog(dpy_, 300, 100, "VNC Server : Accept Connection?"),
     addressLbl(dpy, "Host:",this),
     address(dpy, address_, this),
     userLbl(dpy, "User:", this),
diff --git a/unix/vncconfig/QueryConnectDialog.h b/unix/vncconfig/QueryConnectDialog.h
index dcf64e402..5763e1cec 100644
--- a/unix/vncconfig/QueryConnectDialog.h
+++ b/unix/vncconfig/QueryConnectDialog.h
@@ -40,10 +40,10 @@ class QueryConnectDialog : public TXDialog, public TXEventHandler,
   QueryConnectDialog(Display* dpy, const char* address_,
                      const char* user_, int timeout_,
                      QueryResultCallback* cb);
-  void handleEvent(TXWindow*, XEvent* ) { }
-  void deleteWindow(TXWindow*);
-  void buttonActivate(TXButton* b);
-  void handleTimeout(rfb::Timer* t);
+  void handleEvent(TXWindow*, XEvent* ) override { }
+  void deleteWindow(TXWindow*) override;
+  void buttonActivate(TXButton* b) override;
+  void handleTimeout(rfb::Timer* t) override;
  private:
   void refreshTimeout();
   TXLabel addressLbl, address, userLbl, user, timeoutLbl, timeout;
diff --git a/unix/vncconfig/vncconfig.cxx b/unix/vncconfig/vncconfig.cxx
index 30d04ca6c..ab7c6315d 100644
--- a/unix/vncconfig/vncconfig.cxx
+++ b/unix/vncconfig/vncconfig.cxx
@@ -62,14 +62,14 @@ BoolParameter iconic("iconic", "Start with window iconified", 0);
 #define SET_PRIMARY "SetPrimary"
 #define SEND_PRIMARY "SendPrimary"
 
-char* programName = 0;
+char* programName = nullptr;
 Display* dpy;
 int vncExtEventBase, vncExtErrorBase;
 
-static bool getBoolParam(Display* dpy, const char* param) {
+static bool getBoolParam(Display* dpy_, const char* param) {
   char* data;
   int len;
-  if (XVncExtGetParam(dpy, param, &data, &len)) {
+  if (XVncExtGetParam(dpy_, param, &data, &len)) {
     if (strcmp(data,"1") == 0) return true;
   }
   return false;
@@ -80,13 +80,13 @@ class VncConfigWindow : public TXWindow, public TXEventHandler,
                         public TXCheckboxCallback,
                         public QueryResultCallback {
 public:
-  VncConfigWindow(Display* dpy)
-    : TXWindow(dpy, 300, 100),
-      acceptClipboard(dpy, "Accept clipboard from viewers", this, false, this),
-      setPrimaryCB(dpy, "Also set primary selection", this, false, this),
-      sendClipboard(dpy, "Send clipboard to viewers", this, false, this),
-      sendPrimaryCB(dpy, "Send primary selection to viewers", this,false,this),
-      queryConnectDialog(0)
+  VncConfigWindow(Display* dpy_)
+    : TXWindow(dpy_, 300, 100),
+      acceptClipboard(dpy_, "Accept clipboard from viewers", this, false, this),
+      setPrimaryCB(dpy_, "Also set primary selection", this, false, this),
+      sendClipboard(dpy_, "Send clipboard to viewers", this, false, this),
+      sendPrimaryCB(dpy_, "Send primary selection to viewers", this,false,this),
+      queryConnectDialog(nullptr)
   {
     int y = yPad;
     acceptClipboard.move(xPad, y);
@@ -104,18 +104,18 @@ class VncConfigWindow : public TXWindow, public TXEventHandler,
     sendPrimaryCB.disabled(!sendClipboard.checked());
     y += sendPrimaryCB.height();
     setEventHandler(this);
-    toplevel("VNC config", this, 0, 0, 0, iconic);
+    toplevel("VNC config", this, 0, nullptr, nullptr, iconic);
     XVncExtSelectInput(dpy, win(), VncExtQueryConnectMask);
   }
 
   // handleEvent()
 
-  virtual void handleEvent(TXWindow* /*w*/, XEvent* ev) {
+  void handleEvent(TXWindow* /*w*/, XEvent* ev) override {
     if (ev->type == vncExtEventBase + VncExtQueryConnectNotify) {
        vlog.debug("query connection event");
        if (queryConnectDialog)
          delete queryConnectDialog;
-       queryConnectDialog = 0;
+       queryConnectDialog = nullptr;
        char* qcAddress;
        char* qcUser;
        int qcTimeout;
@@ -134,12 +134,12 @@ class VncConfigWindow : public TXWindow, public TXEventHandler,
   }
 
   // TXDeleteWindowCallback method
-  virtual void deleteWindow(TXWindow* /*w*/) {
+  void deleteWindow(TXWindow* /*w*/) override {
     exit(1);
   }
 
   // TXCheckboxCallback method
-  virtual void checkboxSelect(TXCheckbox* checkbox) {
+  void checkboxSelect(TXCheckbox* checkbox) override {
     if (checkbox == &acceptClipboard) {
       XVncExtSetParam(dpy, (acceptClipboard.checked()
                             ? ACCEPT_CUT_TEXT "=1" : ACCEPT_CUT_TEXT "=0"));
@@ -158,10 +158,10 @@ class VncConfigWindow : public TXWindow, public TXEventHandler,
   }
 
   // QueryResultCallback interface
-  virtual void queryApproved() {
+  void queryApproved() override {
     XVncExtApproveConnect(dpy, queryConnectId, 1);
   }
-  virtual void queryRejected() {
+  void queryRejected() override {
     XVncExtApproveConnect(dpy, queryConnectId, 0);
   }
 
@@ -278,8 +278,8 @@ int main(int argc, char** argv)
       } else if (strcmp(argv[i], "-list") == 0) {
         int nParams;
         char** list = XVncExtListParams(dpy, &nParams);
-        for (int i = 0; i < nParams; i++) {
-          printf("%s\n",list[i]);
+        for (int n = 0; n < nParams; n++) {
+          printf("%s\n",list[n]);
         }
         XVncExtFreeParamList(list);
       } else if (strcmp(argv[i], "-set") == 0) {
@@ -306,7 +306,7 @@ int main(int argc, char** argv)
 
     while (true) {
       struct timeval tv;
-      struct timeval* tvp = 0;
+      struct timeval* tvp = nullptr;
 
       // Process any incoming X events
       TXWindow::handleXEvents(dpy);
@@ -329,7 +329,7 @@ int main(int argc, char** argv)
       fd_set rfds;
       FD_ZERO(&rfds);
       FD_SET(ConnectionNumber(dpy), &rfds);
-      int n = select(FD_SETSIZE, &rfds, 0, 0, tvp);
+      int n = select(FD_SETSIZE, &rfds, nullptr, nullptr, tvp);
       if (n < 0) throw rdr::SystemException("select",errno);
     }
 
diff --git a/unix/vncpasswd/vncpasswd.cxx b/unix/vncpasswd/vncpasswd.cxx
index 30091a3db..877ebcbd4 100644
--- a/unix/vncpasswd/vncpasswd.cxx
+++ b/unix/vncpasswd/vncpasswd.cxx
@@ -72,7 +72,7 @@ static const char* getpassword(const char* prompt) {
       result[strlen(result)-1] = 0;
     return buf;
   }
-  return 0;
+  return nullptr;
 }
 
 // Reads passwords from stdin and prints encrypted passwords to stdout.
@@ -81,7 +81,7 @@ static int encrypt_pipe() {
 
   // We support a maximum of two passwords right now
   for (i = 0;i < 2;i++) {
-    const char *result = getpassword(NULL);
+    const char *result = getpassword(nullptr);
     if (!result)
       break;
 
@@ -102,7 +102,7 @@ static int encrypt_pipe() {
 static std::vector<uint8_t> readpassword() {
   while (true) {
     const char *passwd = getpassword("Password:");
-    if (passwd == NULL) {
+    if (passwd == nullptr) {
       perror("getpassword error");
       exit(1);
     }
@@ -117,7 +117,7 @@ static std::vector<uint8_t> readpassword() {
     }
 
     passwd = getpassword("Verify:");
-    if (passwd == NULL) {
+    if (passwd == nullptr) {
       perror("getpass error");
       exit(1);
     }
@@ -158,7 +158,7 @@ int main(int argc, char** argv)
 
   if (fname[0] == '\0') {
     const char *configDir = os::getvncconfigdir();
-    if (configDir == NULL) {
+    if (configDir == nullptr) {
       fprintf(stderr, "Can't obtain VNC config directory\n");
       exit(1);
     }
@@ -175,7 +175,7 @@ int main(int argc, char** argv)
 
     fprintf(stderr, "Would you like to enter a view-only password (y/n)? ");
     char yesno[3];
-    if (fgets(yesno, 3, stdin) != NULL && (yesno[0] == 'y' || yesno[0] == 'Y')) {
+    if (fgets(yesno, 3, stdin) != nullptr && (yesno[0] == 'y' || yesno[0] == 'Y')) {
       obfuscatedReadOnly = readpassword();
     } else {
       fprintf(stderr, "A view-only password is not used\n");
diff --git a/unix/x0vncserver/Geometry.cxx b/unix/x0vncserver/Geometry.cxx
index 3f7f28630..28e71be41 100644
--- a/unix/x0vncserver/Geometry.cxx
+++ b/unix/x0vncserver/Geometry.cxx
@@ -71,7 +71,7 @@ Rect Geometry::parseString(const char *arg) const
 {
   Rect result;                  // empty by default
 
-  if (arg != NULL && strlen(arg) > 0) {
+  if (arg != nullptr && strlen(arg) > 0) {
     int w, h;
     int x = 0, y = 0;
     char sign_x[2] = "+";
diff --git a/unix/x0vncserver/Image.cxx b/unix/x0vncserver/Image.cxx
index 755da787a..c20261347 100644
--- a/unix/x0vncserver/Image.cxx
+++ b/unix/x0vncserver/Image.cxx
@@ -63,13 +63,13 @@ ImageCleanup imageCleanup;
 static rfb::LogWriter vlog("Image");
 
 Image::Image(Display *d)
-  : xim(NULL), dpy(d)
+  : xim(nullptr), dpy(d)
 {
   imageCleanup.images.push_back(this);
 }
 
 Image::Image(Display *d, int width, int height)
-  : xim(NULL), dpy(d)
+  : xim(nullptr), dpy(d)
 {
   imageCleanup.images.push_back(this);
   Init(width, height);
@@ -85,10 +85,11 @@ void Image::Init(int width, int height)
   }
 
   xim = XCreateImage(dpy, vis, DefaultDepth(dpy, DefaultScreen(dpy)),
-                     ZPixmap, 0, 0, width, height, BitmapPad(dpy), 0);
+                     ZPixmap, 0, nullptr, width, height,
+                     BitmapPad(dpy), 0);
 
   xim->data = (char *)malloc(xim->bytes_per_line * xim->height);
-  if (xim->data == NULL) {
+  if (xim->data == nullptr) {
     vlog.error("malloc() failed");
     exit(1);
   }
@@ -99,7 +100,7 @@ Image::~Image()
   imageCleanup.images.remove(this);
 
   // XDestroyImage will free xim->data if necessary
-  if (xim != NULL)
+  if (xim != nullptr)
     XDestroyImage(xim);
 }
 
@@ -217,12 +218,12 @@ static int ShmCreationXErrorHandler(Display* /*dpy*/,
 }
 
 ShmImage::ShmImage(Display *d)
-  : Image(d), shminfo(NULL)
+  : Image(d), shminfo(nullptr)
 {
 }
 
 ShmImage::ShmImage(Display *d, int width, int height)
-  : Image(d), shminfo(NULL)
+  : Image(d), shminfo(nullptr)
 {
   Init(width, height);
 }
@@ -241,7 +242,7 @@ void ShmImage::Init(int width, int height, const XVisualInfo *vinfo)
   Visual *visual;
   int depth;
 
-  if (vinfo == NULL) {
+  if (vinfo == nullptr) {
     visual = DefaultVisual(dpy, DefaultScreen(dpy));
     depth = DefaultDepth(dpy, DefaultScreen(dpy));
   } else {
@@ -256,12 +257,12 @@ void ShmImage::Init(int width, int height, const XVisualInfo *vinfo)
 
   shminfo = new XShmSegmentInfo;
 
-  xim = XShmCreateImage(dpy, visual, depth, ZPixmap, 0, shminfo,
+  xim = XShmCreateImage(dpy, visual, depth, ZPixmap, nullptr, shminfo,
 			width, height);
-  if (xim == NULL) {
+  if (xim == nullptr) {
     vlog.error("XShmCreateImage() failed");
     delete shminfo;
-    shminfo = NULL;
+    shminfo = nullptr;
     return;
   }
 
@@ -273,22 +274,22 @@ void ShmImage::Init(int width, int height, const XVisualInfo *vinfo)
     vlog.error("shmget() failed (%d bytes requested)",
                int(xim->bytes_per_line * xim->height));
     XDestroyImage(xim);
-    xim = NULL;
+    xim = nullptr;
     delete shminfo;
-    shminfo = NULL;
+    shminfo = nullptr;
     return;
   }
 
-  shminfo->shmaddr = xim->data = (char *)shmat(shminfo->shmid, 0, 0);
+  shminfo->shmaddr = xim->data = (char *)shmat(shminfo->shmid, nullptr, 0);
   if (shminfo->shmaddr == (char *)-1) {
     perror("shmat");
     vlog.error("shmat() failed (%d bytes requested)",
                int(xim->bytes_per_line * xim->height));
-    shmctl(shminfo->shmid, IPC_RMID, 0);
+    shmctl(shminfo->shmid, IPC_RMID, nullptr);
     XDestroyImage(xim);
-    xim = NULL;
+    xim = nullptr;
     delete shminfo;
-    shminfo = NULL;
+    shminfo = nullptr;
     return;
   }
 
@@ -301,21 +302,21 @@ void ShmImage::Init(int width, int height, const XVisualInfo *vinfo)
   if (caughtShmError) {
     vlog.error("XShmAttach() failed");
     shmdt(shminfo->shmaddr);
-    shmctl(shminfo->shmid, IPC_RMID, 0);
+    shmctl(shminfo->shmid, IPC_RMID, nullptr);
     XDestroyImage(xim);
-    xim = NULL;
+    xim = nullptr;
     delete shminfo;
-    shminfo = NULL;
+    shminfo = nullptr;
     return;
   }
 }
 
 ShmImage::~ShmImage()
 {
-  if (shminfo != NULL) {
+  if (shminfo != nullptr) {
     XShmDetach(dpy, shminfo);
     shmdt(shminfo->shmaddr);
-    shmctl(shminfo->shmid, IPC_RMID, 0);
+    shmctl(shminfo->shmid, IPC_RMID, nullptr);
     delete shminfo;
   }
 }
@@ -354,13 +355,13 @@ ImageFactory::~ImageFactory()
 
 Image *ImageFactory::newImage(Display *d, int width, int height)
 {
-  Image *image = NULL;
+  Image *image = nullptr;
 
   // Now, try to use shared memory image.
 
   if (mayUseShm) {
     image = new ShmImage(d, width, height);
-    if (image->xim != NULL) {
+    if (image->xim != nullptr) {
       return image;
     }
 
diff --git a/unix/x0vncserver/Image.h b/unix/x0vncserver/Image.h
index bf62e7d0b..a89a26ad2 100644
--- a/unix/x0vncserver/Image.h
+++ b/unix/x0vncserver/Image.h
@@ -98,20 +98,20 @@ class ShmImage : public Image {
   ShmImage(Display *d, int width, int height);
   virtual ~ShmImage();
 
-  virtual const char *className() const {
+  const char *className() const override {
     return "ShmImage";
   }
-  virtual const char *classDesc() const {
+  const char *classDesc() const override {
     return "shared memory image";
   }
 
-  virtual void get(Window wnd, int x = 0, int y = 0);
-  virtual void get(Window wnd, int x, int y, int w, int h,
-                   int dst_x = 0, int dst_y = 0);
+  void get(Window wnd, int x = 0, int y = 0) override;
+  void get(Window wnd, int x, int y, int w, int h,
+           int dst_x = 0, int dst_y = 0) override;
 
 protected:
 
-  void Init(int width, int height, const XVisualInfo *vinfo = NULL);
+  void Init(int width, int height, const XVisualInfo *vinfo = nullptr);
 
   XShmSegmentInfo *shminfo;
 
diff --git a/unix/x0vncserver/XDesktop.cxx b/unix/x0vncserver/XDesktop.cxx
index 55ea9667e..4286c5416 100644
--- a/unix/x0vncserver/XDesktop.cxx
+++ b/unix/x0vncserver/XDesktop.cxx
@@ -26,6 +26,8 @@
 #include <signal.h>
 #include <unistd.h>
 
+#include <algorithm>
+
 #include <network/Socket.h>
 
 #include <rfb/LogWriter.h>
@@ -80,11 +82,11 @@ static const char * ledNames[XDESKTOP_N_LEDS] = {
 };
 
 XDesktop::XDesktop(Display* dpy_, Geometry *geometry_)
-  : dpy(dpy_), geometry(geometry_), pb(0), server(0),
-    queryConnectDialog(0), queryConnectSock(0),
+  : dpy(dpy_), geometry(geometry_), pb(nullptr), server(nullptr),
+    queryConnectDialog(nullptr), queryConnectSock(nullptr),
     oldButtonMask(0), haveXtest(false), haveDamage(false),
     maxButtons(0), running(false), ledMasks(), ledState(0),
-    codeMap(0), codeMapLen(0)
+    codeMap(nullptr), codeMapLen(0)
 {
   int major, minor;
 
@@ -108,7 +110,7 @@ XDesktop::XDesktop(Display* dpy_, Geometry *geometry_)
     Bool on;
 
     a = XInternAtom(dpy, ledNames[i], True);
-    if (!a || !XkbGetNamedIndicator(dpy, a, &shift, &on, NULL, NULL))
+    if (!a || !XkbGetNamedIndicator(dpy, a, &shift, &on, nullptr, nullptr))
       continue;
 
     ledMasks[i] = 1u << shift;
@@ -283,7 +285,7 @@ void XDesktop::stop() {
 
 #ifdef HAVE_XTEST
   // Delete added keycodes
-  deleteAddedKeysyms(dpy);
+  deleteAddedKeysyms();
 #endif
 
 #ifdef HAVE_XDAMAGE
@@ -292,12 +294,12 @@ void XDesktop::stop() {
 #endif
 
   delete queryConnectDialog;
-  queryConnectDialog = 0;
+  queryConnectDialog = nullptr;
 
-  server->setPixelBuffer(0);
+  server->setPixelBuffer(nullptr);
 
   delete pb;
-  pb = 0;
+  pb = nullptr;
 }
 
 void XDesktop::terminate() {
@@ -316,15 +318,13 @@ void XDesktop::queryConnection(network::Socket* sock,
   // Someone already querying?
   if (queryConnectSock) {
     std::list<network::Socket*> sockets;
-    std::list<network::Socket*>::iterator i;
 
     // Check if this socket is still valid
     server->getSockets(&sockets);
-    for (i = sockets.begin(); i != sockets.end(); i++) {
-      if (*i == queryConnectSock) {
-        server->approveConnection(sock, false, "Another connection is currently being queried.");
-        return;
-      }
+    if (std::find(sockets.begin(), sockets.end(),
+                  queryConnectSock) != sockets.end()) {
+      server->approveConnection(sock, false, "Another connection is currently being queried.");
+      return;
     }
   }
 
@@ -368,7 +368,7 @@ void XDesktop::pointerEvent(const Point& pos, int buttonMask) {
 }
 
 #ifdef HAVE_XTEST
-KeyCode XDesktop::XkbKeysymToKeycode(Display* dpy, KeySym keysym) {
+KeyCode XDesktop::XkbKeysymToKeycode(KeySym keysym) {
   XkbDescPtr xkb;
   XkbStateRec state;
   unsigned int mods;
@@ -401,12 +401,12 @@ KeyCode XDesktop::XkbKeysymToKeycode(Display* dpy, KeySym keysym) {
   // Shift+Tab is usually ISO_Left_Tab, but RFB hides this fact. Do
   // another attempt if we failed the initial lookup
   if ((keycode == 0) && (keysym == XK_Tab) && (mods & ShiftMask))
-    return XkbKeysymToKeycode(dpy, XK_ISO_Left_Tab);
+    return XkbKeysymToKeycode(XK_ISO_Left_Tab);
 
   return keycode;
 }
 
-KeyCode XDesktop::addKeysym(Display* dpy, KeySym keysym)
+KeyCode XDesktop::addKeysym(KeySym keysym)
 {
   int types[1];
   unsigned int key;
@@ -460,7 +460,7 @@ KeyCode XDesktop::addKeysym(Display* dpy, KeySym keysym)
   return 0;
 }
 
-void XDesktop::deleteAddedKeysyms(Display* dpy) {
+void XDesktop::deleteAddedKeysyms() {
   XkbDescPtr xkb;
   xkb = XkbGetMap(dpy, XkbAllComponentsMask, XkbUseCoreKbd);
 
@@ -476,10 +476,10 @@ void XDesktop::deleteAddedKeysyms(Display* dpy) {
   for (it = addedKeysyms.begin(); it != addedKeysyms.end(); it++) {
     if (XkbKeyNumGroups(xkb, it->second) != 0) {
       // Check if we are removing keysym we added ourself
-      if (XkbKeysymToKeycode(dpy, it->first) != it->second)
+      if (XkbKeysymToKeycode(it->first) != it->second)
         continue;
 
-      XkbChangeTypesOfKey(xkb, it->second, 0, XkbGroup1Mask, NULL, &changes);
+      XkbChangeTypesOfKey(xkb, it->second, 0, XkbGroup1Mask, nullptr, &changes);
 
       if (it->second < lowestKeyCode)
         lowestKeyCode = it->second;
@@ -501,19 +501,19 @@ void XDesktop::deleteAddedKeysyms(Display* dpy) {
   addedKeysyms.clear();
 }
 
-KeyCode XDesktop::keysymToKeycode(Display* dpy, KeySym keysym) {
+KeyCode XDesktop::keysymToKeycode(KeySym keysym) {
   int keycode = 0;
 
   // XKeysymToKeycode() doesn't respect state, so we have to use
   // something slightly more complex
-  keycode = XkbKeysymToKeycode(dpy, keysym);
+  keycode = XkbKeysymToKeycode(keysym);
 
   if (keycode != 0)
     return keycode;
 
   // TODO: try to further guess keycode with all possible mods as Xvnc does
 
-  keycode = addKeysym(dpy, keysym);
+  keycode = addKeysym(keysym);
 
   if (keycode == 0)
     vlog.error("Failure adding new keysym 0x%lx", keysym);
@@ -538,7 +538,7 @@ void XDesktop::keyEvent(uint32_t keysym, uint32_t xtcode, bool down) {
     if (pressedKeys.find(keysym) != pressedKeys.end())
       keycode = pressedKeys[keysym];
     else {
-      keycode = keysymToKeycode(dpy, keysym);
+      keycode = keysymToKeycode(keysym);
     }
   }
 
@@ -931,7 +931,7 @@ bool XDesktop::handleGlobalEvent(XEvent* ev) {
     if (cev->window == cev->root)
       return false;
 
-    server->setCursor(0, 0, Point(), NULL);
+    server->setCursor(0, 0, Point(), nullptr);
     return true;
 #endif
   }
@@ -942,8 +942,8 @@ bool XDesktop::handleGlobalEvent(XEvent* ev) {
 void XDesktop::queryApproved()
 {
   assert(isRunning());
-  server->approveConnection(queryConnectSock, true, 0);
-  queryConnectSock = 0;
+  server->approveConnection(queryConnectSock, true, nullptr);
+  queryConnectSock = nullptr;
 }
 
 void XDesktop::queryRejected()
@@ -951,7 +951,7 @@ void XDesktop::queryRejected()
   assert(isRunning());
   server->approveConnection(queryConnectSock, false,
                             "Connection rejected by local user");
-  queryConnectSock = 0;
+  queryConnectSock = nullptr;
 }
 
 #ifdef HAVE_XFIXES
@@ -960,7 +960,7 @@ bool XDesktop::setCursor()
   XFixesCursorImage *cim;
 
   cim = XFixesGetCursorImage(dpy);
-  if (cim == NULL)
+  if (cim == nullptr)
     return false;
 
   // Copied from XserverDesktop::setCursor() in
diff --git a/unix/x0vncserver/XDesktop.h b/unix/x0vncserver/XDesktop.h
index fc230e5b8..125ddeb07 100644
--- a/unix/x0vncserver/XDesktop.h
+++ b/unix/x0vncserver/XDesktop.h
@@ -47,25 +47,25 @@ class XDesktop : public rfb::SDesktop,
   virtual ~XDesktop();
   void poll();
   // -=- SDesktop interface
-  virtual void init(rfb::VNCServer* vs);
-  virtual void start();
-  virtual void stop();
-  virtual void terminate();
+  void init(rfb::VNCServer* vs) override;
+  void start() override;
+  void stop() override;
+  void terminate() override;
   bool isRunning();
-  virtual void queryConnection(network::Socket* sock,
-                               const char* userName);
-  virtual void pointerEvent(const rfb::Point& pos, int buttonMask);
-  virtual void keyEvent(uint32_t keysym, uint32_t xtcode, bool down);
-  virtual void clientCutText(const char* str);
-  virtual unsigned int setScreenLayout(int fb_width, int fb_height,
-                                       const rfb::ScreenSet& layout);
+  void queryConnection(network::Socket* sock,
+                       const char* userName) override;
+  void pointerEvent(const rfb::Point& pos, int buttonMask) override;
+  void keyEvent(uint32_t keysym, uint32_t xtcode, bool down) override;
+  void clientCutText(const char* str) override;
+  unsigned int setScreenLayout(int fb_width, int fb_height,
+                               const rfb::ScreenSet& layout) override;
 
   // -=- TXGlobalEventHandler interface
-  virtual bool handleGlobalEvent(XEvent* ev);
+  bool handleGlobalEvent(XEvent* ev) override;
 
   // -=- QueryResultCallback interface
-  virtual void queryApproved();
-  virtual void queryRejected();
+  void queryApproved() override;
+  void queryRejected() override;
 
 protected:
   Display* dpy;
@@ -101,10 +101,10 @@ class XDesktop : public rfb::SDesktop,
 
 protected:
 #ifdef HAVE_XTEST
-  KeyCode XkbKeysymToKeycode(Display* dpy, KeySym keysym);
-  KeyCode addKeysym(Display* dpy, KeySym keysym);
-  void deleteAddedKeysyms(Display* dpy);
-  KeyCode keysymToKeycode(Display* dpy, KeySym keysym);
+  KeyCode XkbKeysymToKeycode(KeySym keysym);
+  KeyCode addKeysym(KeySym keysym);
+  void deleteAddedKeysyms();
+  KeyCode keysymToKeycode(KeySym keysym);
 #endif
 #ifdef HAVE_XFIXES
   bool setCursor();
diff --git a/unix/x0vncserver/XPixelBuffer.cxx b/unix/x0vncserver/XPixelBuffer.cxx
index b75065135..0e24cc513 100644
--- a/unix/x0vncserver/XPixelBuffer.cxx
+++ b/unix/x0vncserver/XPixelBuffer.cxx
@@ -35,7 +35,7 @@ using namespace rfb;
 XPixelBuffer::XPixelBuffer(Display *dpy, ImageFactory &factory,
                            const Rect &rect)
   : FullFramePixelBuffer(),
-    m_poller(0),
+    m_poller(nullptr),
     m_dpy(dpy),
     m_image(factory.newImage(dpy, rect.width(), rect.height())),
     m_offsetLeft(rect.tl.x),
diff --git a/unix/x0vncserver/XPixelBuffer.h b/unix/x0vncserver/XPixelBuffer.h
index 18c85fe29..7556e6ef6 100644
--- a/unix/x0vncserver/XPixelBuffer.h
+++ b/unix/x0vncserver/XPixelBuffer.h
@@ -45,7 +45,7 @@ class XPixelBuffer : public rfb::FullFramePixelBuffer
   inline void poll(rfb::VNCServer *server) { m_poller->poll(server); }
 
   // Override PixelBuffer::grabRegion().
-  virtual void grabRegion(const rfb::Region& region);
+  void grabRegion(const rfb::Region& region) override;
 
 protected:
   PollingManager *m_poller;
diff --git a/unix/x0vncserver/x0vncserver.cxx b/unix/x0vncserver/x0vncserver.cxx
index ffaf57889..49c951375 100644
--- a/unix/x0vncserver/x0vncserver.cxx
+++ b/unix/x0vncserver/x0vncserver.cxx
@@ -90,10 +90,10 @@ static const char* defaultDesktopName()
     return "";
 
   struct passwd* pwent = getpwuid(getuid());
-  if (pwent == NULL)
+  if (pwent == nullptr)
     return "";
 
-  int len = snprintf(NULL, 0, "%s@%s", pwent->pw_name, hostname.data());
+  int len = snprintf(nullptr, 0, "%s@%s", pwent->pw_name, hostname.data());
   if (len < 0)
     return "";
 
@@ -154,19 +154,19 @@ class FileTcpFilter : public TcpFilter
 public:
 
   FileTcpFilter(const char *fname)
-    : TcpFilter("-"), fileName(NULL), lastModTime(0)
+    : TcpFilter("-"), fileName(nullptr), lastModTime(0)
   {
-    if (fname != NULL)
+    if (fname != nullptr)
       fileName = strdup((char *)fname);
   }
 
   virtual ~FileTcpFilter()
   {
-    if (fileName != NULL)
+    if (fileName != nullptr)
       free(fileName);
   }
 
-  virtual bool verifyConnection(Socket* s)
+  bool verifyConnection(Socket* s) override
   {
     if (!reloadRules()) {
       vlog.error("Could not read IP filtering rules: rejecting all clients");
@@ -182,7 +182,7 @@ class FileTcpFilter : public TcpFilter
 
   bool reloadRules()
   {
-    if (fileName == NULL)
+    if (fileName == nullptr)
       return true;
 
     struct stat st;
@@ -192,7 +192,7 @@ class FileTcpFilter : public TcpFilter
     if (st.st_mtime != lastModTime) {
       // Actually reload only if the file was modified
       FILE *fp = fopen(fileName, "r");
-      if (fp == NULL)
+      if (fp == nullptr)
         return false;
 
       // Remove all the rules from the parent class
@@ -225,14 +225,14 @@ class FileTcpFilter : public TcpFilter
 
   bool readLine(char *buf, int bufSize, FILE *fp)
   {
-    if (fp == NULL || buf == NULL || bufSize == 0)
+    if (fp == nullptr || buf == nullptr || bufSize == 0)
       return false;
 
-    if (fgets(buf, bufSize, fp) == NULL)
+    if (fgets(buf, bufSize, fp) == nullptr)
       return false;
 
     char *ptr = strchr(buf, '\n');
-    if (ptr != NULL) {
+    if (ptr != nullptr) {
       *ptr = '\0';              // remove newline at the end
     } else {
       if (!feof(fp)) {
@@ -353,7 +353,7 @@ int main(int argc, char** argv)
       const char *addr = interface;
 
       if (strcasecmp(addr, "all") == 0)
-        addr = 0;
+        addr = nullptr;
       if (localhostOnly)
         createLocalTcpListeners(&tcp_listeners, (int)rfbport);
       else
@@ -368,10 +368,8 @@ int main(int argc, char** argv)
 
       FileTcpFilter fileTcpFilter(hostsFile);
       if (strlen(hostsFile) != 0)
-        for (std::list<SocketListener*>::iterator i = listeners.begin();
-             i != listeners.end();
-             i++)
-          (*i)->setFilter(&fileTcpFilter);
+        for (SocketListener* listener : listeners)
+          listener->setFilter(&fileTcpFilter);
     }
 
     if (listeners.empty()) {
@@ -395,10 +393,8 @@ int main(int argc, char** argv)
       FD_ZERO(&wfds);
 
       FD_SET(ConnectionNumber(dpy), &rfds);
-      for (std::list<SocketListener*>::iterator i = listeners.begin();
-           i != listeners.end();
-           i++)
-        FD_SET((*i)->getFd(), &rfds);
+      for (SocketListener* listener : listeners)
+        FD_SET(listener->getFd(), &rfds);
 
       server.getSockets(&sockets);
       int clients_connected = 0;
@@ -436,8 +432,8 @@ int main(int argc, char** argv)
 
       // Do the wait...
       sched.sleepStarted();
-      int n = select(FD_SETSIZE, &rfds, &wfds, 0,
-                     wait_ms ? &tv : NULL);
+      int n = select(FD_SETSIZE, &rfds, &wfds, nullptr,
+                     wait_ms ? &tv : nullptr);
       sched.sleepFinished();
 
       if (n < 0) {
@@ -450,11 +446,9 @@ int main(int argc, char** argv)
       }
 
       // Accept new VNC connections
-      for (std::list<SocketListener*>::iterator i = listeners.begin();
-           i != listeners.end();
-           i++) {
-        if (FD_ISSET((*i)->getFd(), &rfds)) {
-          Socket* sock = (*i)->accept();
+      for (SocketListener* listener : listeners) {
+        if (FD_ISSET(listener->getFd(), &rfds)) {
+          Socket* sock = listener->accept();
           if (sock) {
             server.addSocket(sock);
           } else {
@@ -494,11 +488,8 @@ int main(int argc, char** argv)
   TXWindow::handleXEvents(dpy);
 
   // Run listener destructors; remove UNIX sockets etc
-  for (std::list<SocketListener*>::iterator i = listeners.begin();
-       i != listeners.end();
-       i++) {
-    delete *i;
-  }
+  for (SocketListener* listener : listeners)
+    delete listener;
 
   vlog.info("Terminated");
   return 0;
diff --git a/unix/xserver/hw/vnc/Makefile.am b/unix/xserver/hw/vnc/Makefile.am
index f93721832..d344c85d5 100644
--- a/unix/xserver/hw/vnc/Makefile.am
+++ b/unix/xserver/hw/vnc/Makefile.am
@@ -14,6 +14,8 @@ AM_CPPFLAGS = \
 	-I$(TIGERVNC_SRCDIR)/unix/common \
 	$(DIX_CFLAGS)
 
+AM_CXXFLAGS = -std=gnu++11
+
 noinst_LTLIBRARIES = libvnccommon.la
 
 HDRS = vncExtInit.h vncHooks.h \
diff --git a/unix/xserver/hw/vnc/RFBGlue.cc b/unix/xserver/hw/vnc/RFBGlue.cc
index 25431b655..2cbee35c5 100644
--- a/unix/xserver/hw/vnc/RFBGlue.cc
+++ b/unix/xserver/hw/vnc/RFBGlue.cc
@@ -51,7 +51,7 @@ void vncLogError(const char *name, const char *format, ...)
   LogWriter *vlog;
   va_list ap;
   vlog = LogWriter::getLogWriter(name);
-  if (vlog == NULL)
+  if (vlog == nullptr)
     return;
   va_start(ap, format);
   vlog->verror(format, ap);
@@ -63,7 +63,7 @@ void vncLogStatus(const char *name, const char *format, ...)
   LogWriter *vlog;
   va_list ap;
   vlog = LogWriter::getLogWriter(name);
-  if (vlog == NULL)
+  if (vlog == nullptr)
     return;
   va_start(ap, format);
   vlog->vstatus(format, ap);
@@ -75,7 +75,7 @@ void vncLogInfo(const char *name, const char *format, ...)
   LogWriter *vlog;
   va_list ap;
   vlog = LogWriter::getLogWriter(name);
-  if (vlog == NULL)
+  if (vlog == nullptr)
     return;
   va_start(ap, format);
   vlog->vinfo(format, ap);
@@ -87,7 +87,7 @@ void vncLogDebug(const char *name, const char *format, ...)
   LogWriter *vlog;
   va_list ap;
   vlog = LogWriter::getLogWriter(name);
-  if (vlog == NULL)
+  if (vlog == nullptr)
     return;
   va_start(ap, format);
   vlog->vdebug(format, ap);
@@ -96,12 +96,12 @@ void vncLogDebug(const char *name, const char *format, ...)
 
 int vncSetParam(const char *name, const char *value)
 {
-  if (value != NULL)
+  if (value != nullptr)
     return rfb::Configuration::setParam(name, value);
   else {
     VoidParameter *param;
     param = rfb::Configuration::getParam(name);
-    if (param == NULL)
+    if (param == nullptr)
       return false;
     return param->setParam();
   }
@@ -118,11 +118,11 @@ char* vncGetParam(const char *name)
 
   // Hack to avoid exposing password!
   if (strcasecmp(name, "Password") == 0)
-    return NULL;
+    return nullptr;
 
   param = rfb::Configuration::getParam(name);
-  if (param == NULL)
-    return NULL;
+  if (param == nullptr)
+    return nullptr;
 
   return strdup(param->getValueStr().c_str());
 }
@@ -132,8 +132,8 @@ const char* vncGetParamDesc(const char *name)
   rfb::VoidParameter *param;
 
   param = rfb::Configuration::getParam(name);
-  if (param == NULL)
-    return NULL;
+  if (param == nullptr)
+    return nullptr;
 
   return param->getDescription();
 }
@@ -144,11 +144,11 @@ int vncIsParamBool(const char *name)
   BoolParameter *bparam;
 
   param = rfb::Configuration::getParam(name);
-  if (param == NULL)
+  if (param == nullptr)
     return false;
 
   bparam = dynamic_cast<BoolParameter*>(param);
-  if (bparam == NULL)
+  if (bparam == nullptr)
     return false;
 
   return true;
@@ -179,8 +179,8 @@ char *vncGetParamList(void)
   }
 
   data = (char*)malloc(len + 1);
-  if (data == NULL)
-    return NULL;
+  if (data == nullptr)
+    return nullptr;
 
   ptr = data;
   for (ParameterIterator i; i.param; i.next()) {
@@ -227,7 +227,7 @@ char* vncConvertLF(const char* src, size_t bytes)
   try {
     return strdup(convertLF(src, bytes).c_str());
   } catch (...) {
-    return NULL;
+    return nullptr;
   }
 }
 
@@ -236,7 +236,7 @@ char* vncLatin1ToUTF8(const char* src, size_t bytes)
   try {
     return strdup(latin1ToUTF8(src, bytes).c_str());
   } catch (...) {
-    return NULL;
+    return nullptr;
   }
 }
 
@@ -245,7 +245,7 @@ char* vncUTF8ToLatin1(const char* src, size_t bytes)
   try {
     return strdup(utf8ToLatin1(src, bytes).c_str());
   } catch (...) {
-    return NULL;
+    return nullptr;
   }
 }
 
diff --git a/unix/xserver/hw/vnc/XserverDesktop.cc b/unix/xserver/hw/vnc/XserverDesktop.cc
index d4ee16b83..0c2b5bf99 100644
--- a/unix/xserver/hw/vnc/XserverDesktop.cc
+++ b/unix/xserver/hw/vnc/XserverDesktop.cc
@@ -80,7 +80,7 @@ XserverDesktop::XserverDesktop(int screenIndex_,
                                void* fbptr, int stride_)
   : screenIndex(screenIndex_),
     server(0), listeners(listeners_),
-    shadowFramebuffer(NULL),
+    shadowFramebuffer(nullptr),
     queryConnectId(0), queryConnectTimer(this)
 {
   format = pf;
@@ -88,11 +88,8 @@ XserverDesktop::XserverDesktop(int screenIndex_,
   server = new VNCServerST(name, this);
   setFramebuffer(width, height, fbptr, stride_);
 
-  for (std::list<SocketListener*>::iterator i = listeners.begin();
-       i != listeners.end();
-       i++) {
-    vncSetNotifyFd((*i)->getFd(), screenIndex, true, false);
-  }
+  for (SocketListener* listener : listeners)
+    vncSetNotifyFd(listener->getFd(), screenIndex, true, false);
 }
 
 XserverDesktop::~XserverDesktop()
@@ -123,7 +120,7 @@ void XserverDesktop::setFramebuffer(int w, int h, void* fbptr, int stride_)
 
   if (shadowFramebuffer) {
     delete [] shadowFramebuffer;
-    shadowFramebuffer = NULL;
+    shadowFramebuffer = nullptr;
   }
 
   if (!fbptr) {
@@ -521,7 +518,7 @@ void XserverDesktop::handleClipboardData(const char* data_)
 
 void XserverDesktop::grabRegion(const rfb::Region& region)
 {
-  if (shadowFramebuffer == NULL)
+  if (shadowFramebuffer == nullptr)
     return;
 
   std::vector<rfb::Rect> rects;
diff --git a/unix/xserver/hw/vnc/XserverDesktop.h b/unix/xserver/hw/vnc/XserverDesktop.h
index e604295b0..3b0f869fb 100644
--- a/unix/xserver/hw/vnc/XserverDesktop.h
+++ b/unix/xserver/hw/vnc/XserverDesktop.h
@@ -91,21 +91,21 @@ class XserverDesktop : public rfb::SDesktop, public rfb::FullFramePixelBuffer,
                          const char* rejectMsg=0);
 
   // rfb::SDesktop callbacks
-  virtual void init(rfb::VNCServer* vs);
-  virtual void terminate();
-  virtual void queryConnection(network::Socket* sock,
-                               const char* userName);
-  virtual void pointerEvent(const rfb::Point& pos, int buttonMask);
-  virtual void keyEvent(uint32_t keysym, uint32_t keycode, bool down);
-  virtual unsigned int setScreenLayout(int fb_width, int fb_height,
-                                       const rfb::ScreenSet& layout);
-  virtual void frameTick(uint64_t msc);
-  virtual void handleClipboardRequest();
-  virtual void handleClipboardAnnounce(bool available);
-  virtual void handleClipboardData(const char* data);
+  void init(rfb::VNCServer* vs) override;
+  void terminate() override;
+  void queryConnection(network::Socket* sock,
+                       const char* userName) override;
+  void pointerEvent(const rfb::Point& pos, int buttonMask) override;
+  void keyEvent(uint32_t keysym, uint32_t keycode, bool down) override;
+  unsigned int setScreenLayout(int fb_width, int fb_height,
+                               const rfb::ScreenSet& layout) override;
+  void frameTick(uint64_t msc) override;
+  void handleClipboardRequest() override;
+  void handleClipboardAnnounce(bool available) override;
+  void handleClipboardData(const char* data) override;
 
   // rfb::PixelBuffer callbacks
-  virtual void grabRegion(const rfb::Region& r);
+  void grabRegion(const rfb::Region& r) override;
 
 protected:
   bool handleListenerEvent(int fd,
@@ -115,7 +115,7 @@ class XserverDesktop : public rfb::SDesktop, public rfb::FullFramePixelBuffer,
                          rfb::VNCServer* sockserv,
                          bool read, bool write);
 
-  virtual void handleTimeout(rfb::Timer* t);
+  void handleTimeout(rfb::Timer* t) override;
 
 private:
 
diff --git a/unix/xserver/hw/vnc/vncExtInit.cc b/unix/xserver/hw/vnc/vncExtInit.cc
index 4003e768b..073b07e29 100644
--- a/unix/xserver/hw/vnc/vncExtInit.cc
+++ b/unix/xserver/hw/vnc/vncExtInit.cc
@@ -114,10 +114,10 @@ static const char* defaultDesktopName()
     return "";
 
   struct passwd* pwent = getpwuid(getuid());
-  if (pwent == NULL)
+  if (pwent == nullptr)
     return "";
 
-  size_t len = snprintf(NULL, 0, "%s@%s", pwent->pw_name, hostname.data());
+  size_t len = snprintf(nullptr, 0, "%s@%s", pwent->pw_name, hostname.data());
   if (len < 0)
     return "";
 
@@ -286,7 +286,7 @@ void vncExtensionClose(void)
   try {
     for (int scr = 0; scr < vncGetScreenCount(); scr++) {
       delete desktop[scr];
-      desktop[scr] = NULL;
+      desktop[scr] = nullptr;
     }
   } catch (rdr::Exception& e) {
     vncFatalError("vncExtInit: %s\n",e.str());
diff --git a/vncviewer/BaseTouchHandler.cxx b/vncviewer/BaseTouchHandler.cxx
index 1bcf66c94..6552634b4 100644
--- a/vncviewer/BaseTouchHandler.cxx
+++ b/vncviewer/BaseTouchHandler.cxx
@@ -40,7 +40,7 @@ static const unsigned DOUBLE_TAP_THRESHOLD = 50;
 
 BaseTouchHandler::BaseTouchHandler()
 {
-  gettimeofday(&lastTapTime, NULL);
+  gettimeofday(&lastTapTime, nullptr);
 }
 
 BaseTouchHandler::~BaseTouchHandler()
@@ -188,7 +188,7 @@ void BaseTouchHandler::handleTapEvent(const GestureEvent& ev,
   } else {
     firstDoubleTapEvent = ev;
   }
-  gettimeofday(&lastTapTime, NULL);
+  gettimeofday(&lastTapTime, nullptr);
 
   fakeMotionEvent(newEv);
   fakeButtonEvent(true, buttonEvent, newEv);
diff --git a/vncviewer/CConn.cxx b/vncviewer/CConn.cxx
index 82c4af410..31f5b74dd 100644
--- a/vncviewer/CConn.cxx
+++ b/vncviewer/CConn.cxx
@@ -72,8 +72,8 @@ static const PixelFormat mediumColourPF(8, 8, false, true,
 // Time new bandwidth estimates are weighted against (in ms)
 static const unsigned bpsEstimateWindow = 1000;
 
-CConn::CConn(const char* vncServerName, network::Socket* socket=NULL)
-  : serverPort(0), desktop(NULL), updateCount(0), pixelCount(0),
+CConn::CConn(const char* vncServerName, network::Socket* socket=nullptr)
+  : serverPort(0), desktop(nullptr), updateCount(0), pixelCount(0),
     lastServerEncoding((unsigned int)-1), bpsEstimate(20000000)
 {
   setShared(::shared);
@@ -90,10 +90,10 @@ CConn::CConn(const char* vncServerName, network::Socket* socket=NULL)
   if (!noJpeg)
     setQualityLevel(::qualityLevel);
 
-  if(sock == NULL) {
+  if(sock == nullptr) {
     try {
 #ifndef WIN32
-      if (strchr(vncServerName, '/') != NULL) {
+      if (strchr(vncServerName, '/') != nullptr) {
         sock = new network::UnixSocket(vncServerName);
         serverHost = sock->getPeerAddress();
         vlog.info(_("Connected to socket %s"), serverHost.c_str());
@@ -346,7 +346,7 @@ void CConn::framebufferUpdateStart()
   CConnection::framebufferUpdateStart();
 
   // For bandwidth estimate
-  gettimeofday(&updateStartTime, NULL);
+  gettimeofday(&updateStartTime, nullptr);
   updateStartPos = sock->inStream().pos();
 
   // Update the screen prematurely for very slow updates
@@ -367,7 +367,7 @@ void CConn::framebufferUpdateEnd()
   updateCount++;
 
   // Calculate bandwidth everything managed to maintain during this update
-  gettimeofday(&now, NULL);
+  gettimeofday(&now, nullptr);
   elapsed = (now.tv_sec - updateStartTime.tv_sec) * 1000000;
   elapsed += now.tv_usec - updateStartTime.tv_usec;
   if (elapsed == 0)
diff --git a/vncviewer/CConn.h b/vncviewer/CConn.h
index 835699e5c..fcaf49f6e 100644
--- a/vncviewer/CConn.h
+++ b/vncviewer/CConn.h
@@ -45,37 +45,40 @@ class CConn : public rfb::CConnection
   static void socketEvent(FL_SOCKET fd, void *data);
 
   // CConnection callback methods
-  void initDone();
+  void initDone() override;
 
-  void setDesktopSize(int w, int h);
+  void setDesktopSize(int w, int h) override;
   void setExtendedDesktopSize(unsigned reason, unsigned result,
-                              int w, int h, const rfb::ScreenSet& layout);
+                              int w, int h,
+                              const rfb::ScreenSet& layout) override;
 
-  void setName(const char* name);
+  void setName(const char* name) override;
 
-  void setColourMapEntries(int firstColour, int nColours, uint16_t* rgbs);
+  void setColourMapEntries(int firstColour, int nColours,
+                           uint16_t* rgbs) override;
 
-  void bell();
+  void bell() override;
 
-  void framebufferUpdateStart();
-  void framebufferUpdateEnd();
-  bool dataRect(const rfb::Rect& r, int encoding);
+  void framebufferUpdateStart() override;
+  void framebufferUpdateEnd() override;
+  bool dataRect(const rfb::Rect& r, int encoding) override;
 
   void setCursor(int width, int height, const rfb::Point& hotspot,
-                 const uint8_t* data);
-  void setCursorPos(const rfb::Point& pos);
+                 const uint8_t* data) override;
+  void setCursorPos(const rfb::Point& pos) override;
 
-  void fence(uint32_t flags, unsigned len, const uint8_t data[]);
+  void fence(uint32_t flags, unsigned len,
+             const uint8_t data[]) override;
 
-  void setLEDState(unsigned int state);
+  void setLEDState(unsigned int state) override;
 
-  virtual void handleClipboardRequest();
-  virtual void handleClipboardAnnounce(bool available);
-  virtual void handleClipboardData(const char* data);
+  void handleClipboardRequest() override;
+  void handleClipboardAnnounce(bool available) override;
+  void handleClipboardData(const char* data) override;
 
 private:
 
-  void resizeFramebuffer();
+  void resizeFramebuffer() override;
 
   void autoSelectFormatAndEncoding();
   void updatePixelFormat();
diff --git a/vncviewer/DesktopWindow.cxx b/vncviewer/DesktopWindow.cxx
index 7d7ae7c3f..b0f79933a 100644
--- a/vncviewer/DesktopWindow.cxx
+++ b/vncviewer/DesktopWindow.cxx
@@ -81,18 +81,18 @@ static std::set<DesktopWindow *> instances;
 DesktopWindow::DesktopWindow(int w, int h, const char *name,
                              const rfb::PixelFormat& serverPF,
                              CConn* cc_)
-  : Fl_Window(w, h), cc(cc_), offscreen(NULL), overlay(NULL),
+  : Fl_Window(w, h), cc(cc_), offscreen(nullptr), overlay(nullptr),
     firstUpdate(true),
     delayedFullscreen(false), delayedDesktopSize(false),
     keyboardGrabbed(false), mouseGrabbed(false),
     statsLastUpdates(0), statsLastPixels(0), statsLastPosition(0),
-    statsGraph(NULL)
+    statsGraph(nullptr)
 {
   Fl_Group* group;
 
   // Dummy group to prevent FLTK from moving our widgets around
   group = new Fl_Group(0, 0, w, h);
-  group->resizable(NULL);
+  group->resizable(nullptr);
   resizable(group);
 
   viewport = new Viewport(w, h, serverPF, cc);
@@ -342,9 +342,9 @@ void DesktopWindow::resizeFramebuffer(int new_w, int new_h)
 
   XGetWindowProperty(fl_display, fl_xid(this), net_wm_state, 0, 1024, False, XA_ATOM, &type, &format, &nitems, &remain, (unsigned char**)&atoms);
 
-  for (unsigned long i = 0;i < nitems;i++) {
-    if ((atoms[i] == net_wm_state_maximized_vert) ||
-        (atoms[i] == net_wm_state_maximized_horz)) {
+  for (unsigned long n = 0;n < nitems;n++) {
+    if ((atoms[n] == net_wm_state_maximized_vert) ||
+        (atoms[n] == net_wm_state_maximized_horz)) {
       maximized = true;
       break;
     }
@@ -438,7 +438,7 @@ void DesktopWindow::draw()
 #if !defined(__APPLE__)
 
   // Adjust offscreen surface dimensions
-  if ((offscreen == NULL) ||
+  if ((offscreen == nullptr) ||
       (offscreen->width() != w()) || (offscreen->height() != h())) {
     delete offscreen;
     offscreen = new Surface(w(), h());
@@ -513,8 +513,8 @@ void DesktopWindow::draw()
       windowRect.setXYWH(x(), y(), w(), h());
 
       bool foundEnclosedScreen = false;
-      for (int i = 0; i < Fl::screen_count(); i++) {
-        Fl::screen_xywh(sx, sy, sw, sh, i);
+      for (int idx = 0; idx < Fl::screen_count(); idx++) {
+        Fl::screen_xywh(sx, sy, sw, sh, idx);
 
         // The screen with the smallest index that are enclosed by
         // the viewport will be used for showing the overlay.
@@ -632,10 +632,10 @@ void DesktopWindow::resize(int x, int y, int w, int h)
     }
 
     if (resize_req) {
-      for (int i = 0;i < Fl::screen_count();i++) {
+      for (int idx = 0;idx < Fl::screen_count();idx++) {
         int sx, sy, sw, sh;
 
-        Fl::screen_xywh(sx, sy, sw, sh, i);
+        Fl::screen_xywh(sx, sy, sw, sh, idx);
 
         // We can't trust x and y if the window isn't mapped as the
         // window manager might adjust those numbers
@@ -786,7 +786,7 @@ void DesktopWindow::setOverlay(const char* text, ...)
 
   overlay = new Surface(image);
   overlayAlpha = 0;
-  gettimeofday(&overlayStart, NULL);
+  gettimeofday(&overlayStart, nullptr);
 
   delete image;
   delete [] buffer;
@@ -814,7 +814,7 @@ void DesktopWindow::updateOverlay(void *data)
     Fl::add_timeout(1.0/60, updateOverlay, self);
   } else {
     delete self->overlay;
-    self->overlay = NULL;
+    self->overlay = nullptr;
   }
 
   self->damage(FL_DAMAGE_USER1);
@@ -891,7 +891,7 @@ int DesktopWindow::fltkDispatch(int event, Fl_Window *win)
   // FLTK keeps spamming bogus FL_MOVE events if _any_ X event is
   // received with the mouse pointer outside our windows
   // https://github.com/fltk/fltk/issues/76
-  if ((event == FL_MOVE) && (win == NULL))
+  if ((event == FL_MOVE) && (win == nullptr))
     return 0;
 
   ret = Fl::handle_(event, win);
@@ -977,9 +977,8 @@ void DesktopWindow::fullscreen_on()
       std::set<int> selected = fullScreenSelectedMonitors.getParam();
       monitors.insert(selected.begin(), selected.end());
     } else {
-      for (int i = 0; i < Fl::screen_count(); i++) {
-        monitors.insert(i);
-      }
+      for (int idx = 0; idx < Fl::screen_count(); idx++)
+        monitors.insert(idx);
     }
 
     // If no monitors were found in the selected monitors case, we want
@@ -1332,7 +1331,6 @@ void DesktopWindow::remoteResize(int width, int height)
     layout.begin()->dimensions.br.x = width;
     layout.begin()->dimensions.br.y = height;
   } else {
-    int i;
     uint32_t id;
     int sx, sy, sw, sh;
     rfb::Rect viewport_rect, screen_rect;
@@ -1348,8 +1346,8 @@ void DesktopWindow::remoteResize(int width, int height)
     // FIXME: We should really track screens better so we can handle
     //        a resized one.
     //
-    for (i = 0;i < Fl::screen_count();i++) {
-      Fl::screen_xywh(sx, sy, sw, sh, i);
+    for (int idx = 0;idx < Fl::screen_count();idx++) {
+      Fl::screen_xywh(sx, sy, sw, sh, idx);
 
       // Check that the screen is fully inside the framebuffer
       screen_rect.setXYWH(sx, sy, sw, sh);
@@ -1658,7 +1656,7 @@ void DesktopWindow::handleStatsTimeout(void *data)
   self->stats[statsCount-1].pps = (pixels - self->statsLastPixels) * 1000 / elapsed;
   self->stats[statsCount-1].bps = (pos - self->statsLastPosition) * 1000 / elapsed;
 
-  gettimeofday(&self->statsLastTime, NULL);
+  gettimeofday(&self->statsLastTime, nullptr);
   self->statsLastUpdates = updates;
   self->statsLastPixels = pixels;
   self->statsLastPosition = pos;
diff --git a/vncviewer/DesktopWindow.h b/vncviewer/DesktopWindow.h
index fd622c6d1..ce7960ce6 100644
--- a/vncviewer/DesktopWindow.h
+++ b/vncviewer/DesktopWindow.h
@@ -71,11 +71,11 @@ class DesktopWindow : public Fl_Window {
   void handleClipboardData(const char* data);
 
   // Fl_Window callback methods
-  virtual void show();
-  virtual void draw();
-  virtual void resize(int x, int y, int w, int h);
+  void show() override;
+  void draw() override;
+  void resize(int x, int y, int w, int h) override;
 
-  virtual int handle(int event);
+  int handle(int event) override;
 
   void fullscreen_on();
 
diff --git a/vncviewer/EmulateMB.h b/vncviewer/EmulateMB.h
index 77fdec669..caf3c32a2 100644
--- a/vncviewer/EmulateMB.h
+++ b/vncviewer/EmulateMB.h
@@ -31,7 +31,7 @@ class EmulateMB : public rfb::Timer::Callback {
 protected:
   virtual void sendPointerEvent(const rfb::Point& pos, int buttonMask)=0;
 
-  virtual void handleTimeout(rfb::Timer *t);
+  void handleTimeout(rfb::Timer *t) override;
 
 private:
   void sendAction(const rfb::Point& pos, int buttonMask, int action);
diff --git a/vncviewer/GestureHandler.cxx b/vncviewer/GestureHandler.cxx
index ed99555e7..121ceecf2 100644
--- a/vncviewer/GestureHandler.cxx
+++ b/vncviewer/GestureHandler.cxx
@@ -95,7 +95,7 @@ void GestureHandler::handleTouchBegin(int id, double x, double y)
     return;
   }
 
-  gettimeofday(&ght.started, NULL);
+  gettimeofday(&ght.started, nullptr);
   ght.active = true;
   ght.lastX = ght.firstX = x;
   ght.lastY = ght.firstY = y;
@@ -238,7 +238,7 @@ void GestureHandler::handleTouchEnd(int id)
     longpressTimer.stop();
 
     if (!waitingRelease) {
-      gettimeofday(&releaseStart, NULL);
+      gettimeofday(&releaseStart, nullptr);
       waitingRelease = true;
 
       // Can't be a tap that requires more touches than we current have
@@ -375,19 +375,19 @@ void GestureHandler::pushEvent(GestureEventType t)
 
   // For most gesture events the current (average) position is the
   // most useful
-  getPosition(NULL, NULL, &avgX, &avgY);
+  getPosition(nullptr, nullptr, &avgX, &avgY);
 
   // However we have a slight distance to detect gestures, so for the
   // first gesture event we want to use the first positions we saw
   if (t == GestureBegin)
-    getPosition(&avgX, &avgY, NULL, NULL);
+    getPosition(&avgX, &avgY, nullptr, nullptr);
 
   // For these gestures, we always want the event coordinates
   // to be where the gesture began, not the current touch location.
   switch (state) {
     case GH_TWODRAG:
     case GH_PINCH:
-      getPosition(&avgX, &avgY, NULL, NULL);
+      getPosition(&avgX, &avgY, nullptr, nullptr);
       break;
   }
 
@@ -398,9 +398,9 @@ void GestureHandler::pushEvent(GestureEventType t)
   if (state == GH_PINCH) {
     if (t == GestureBegin)
       getAverageDistance(&gev.magnitudeX, &gev.magnitudeY,
-                         NULL, NULL);
+                         nullptr, nullptr);
     else
-      getAverageDistance(NULL, NULL,
+      getAverageDistance(nullptr, nullptr,
                          &gev.magnitudeX, &gev.magnitudeY);
   } else if (state == GH_TWODRAG) {
     if (t == GestureBegin)
diff --git a/vncviewer/GestureHandler.h b/vncviewer/GestureHandler.h
index b07454df8..2b31703a9 100644
--- a/vncviewer/GestureHandler.h
+++ b/vncviewer/GestureHandler.h
@@ -42,12 +42,12 @@ class GestureHandler : public rfb::Timer::Callback {
   private:
     bool hasDetectedGesture();
 
-    virtual void handleTimeout(rfb::Timer* t);
+    void handleTimeout(rfb::Timer* t) override;
     void longpressTimeout();
     void twoTouchTimeout();
 
     void pushEvent(GestureEventType t);
-    GestureEventGesture stateToGesture(unsigned char state);
+    static GestureEventGesture stateToGesture(unsigned char state);
 
     void getPosition(double *firstX, double *firstY,
                      double *lastX, double *lastY);
diff --git a/vncviewer/MonitorIndicesParameter.cxx b/vncviewer/MonitorIndicesParameter.cxx
index dcc762a34..957ade06c 100644
--- a/vncviewer/MonitorIndicesParameter.cxx
+++ b/vncviewer/MonitorIndicesParameter.cxx
@@ -71,24 +71,22 @@ std::set<int> MonitorIndicesParameter::getParam()
     return indices;
 }
 
-bool MonitorIndicesParameter::setParam(const char* value)
+bool MonitorIndicesParameter::setParam(const char* v)
 {
-    int index;
     std::set<int> indices;
 
-    if (!parseIndices(value, &indices, true)) {
+    if (!parseIndices(v, &indices, true)) {
         vlog.error(_("Invalid configuration specified for %s"), name);
         return false;
     }
 
-    for (std::set<int>::iterator it = indices.begin(); it != indices.end(); it++) {
-        index = *it + 1;
-
+    for (int index : indices) {
+        index += 1;
         if (index <= 0 || index > Fl::screen_count())
             vlog.error(_("Monitor index %d does not exist"), index);
     }
 
-    return StringParameter::setParam(value);
+    return StringParameter::setParam(v);
 }
 
 bool MonitorIndicesParameter::setParam(std::set<int> indices)
@@ -111,16 +109,14 @@ bool MonitorIndicesParameter::setParam(std::set<int> indices)
     int bytesWritten = 0;
     char const * separator = "";
 
-    for (std::set<int>::iterator index = configIndices.begin();
-         index != configIndices.end();
-         index++)
+    for (int configIndex : configIndices)
     {
         bytesWritten += snprintf(
             buf+bytesWritten,
             BUF_MAX_LEN-bytesWritten,
             "%s%u",
             separator,
-            (*index)+1
+            configIndex+1
         );
 
         separator = ",";
@@ -134,7 +130,7 @@ static bool parseNumber(std::string number, std::set<int> *indices)
     if (number.size() <= 0)
         return false;
 
-    int v = strtol(number.c_str(), NULL, 0);
+    int v = strtol(number.c_str(), nullptr, 0);
 
     if (v <= 0)
         return false;
diff --git a/vncviewer/MonitorIndicesParameter.h b/vncviewer/MonitorIndicesParameter.h
index 58e55e438..d91c84fe5 100644
--- a/vncviewer/MonitorIndicesParameter.h
+++ b/vncviewer/MonitorIndicesParameter.h
@@ -29,15 +29,15 @@ class MonitorIndicesParameter: public rfb::StringParameter {
     MonitorIndicesParameter(const char* name_, const char* desc_, const char* v);
     std::set<int> getParam();
     bool setParam(std::set<int> indices);
-    bool setParam(const char* value);
+    bool setParam(const char* v) override;
 private:
     typedef struct {
         int x, y, w, h;
         int fltkIndex;
     } Monitor;
 
-    bool parseIndices(const char* value, std::set<int> *indices,
-                      bool complain=false);
+    static bool parseIndices(const char* value, std::set<int> *indices,
+                             bool complain=false);
     std::vector<MonitorIndicesParameter::Monitor> fetchMonitors();
     static int compare(const void*, const void*);
 };
diff --git a/vncviewer/OptionsDialog.cxx b/vncviewer/OptionsDialog.cxx
index 3c293face..e04065ece 100644
--- a/vncviewer/OptionsDialog.cxx
+++ b/vncviewer/OptionsDialog.cxx
@@ -123,7 +123,7 @@ OptionsDialog::~OptionsDialog()
 
 void OptionsDialog::showDialog(void)
 {
-  static OptionsDialog *dialog = NULL;
+  static OptionsDialog *dialog = nullptr;
 
   if (!dialog)
     dialog = new OptionsDialog();
@@ -218,10 +218,8 @@ void OptionsDialog::loadOptions(void)
   Security security(SecurityClient::secTypes);
 
   list<uint8_t> secTypes;
-  list<uint8_t>::iterator iter;
 
    list<uint32_t> secTypesExt;
-   list<uint32_t>::iterator iterExt;
 
   encNoneCheckbox->value(false);
 #ifdef HAVE_GNUTLS
@@ -237,8 +235,8 @@ void OptionsDialog::loadOptions(void)
   authPlainCheckbox->value(false);
 
   secTypes = security.GetEnabledSecTypes();
-  for (iter = secTypes.begin(); iter != secTypes.end(); ++iter) {
-    switch (*iter) {
+  for (uint8_t type : secTypes) {
+    switch (type) {
     case secTypeNone:
       encNoneCheckbox->value(true);
       authNoneCheckbox->value(true);
@@ -251,8 +249,8 @@ void OptionsDialog::loadOptions(void)
   }
 
   secTypesExt = security.GetEnabledExtSecTypes();
-  for (iterExt = secTypesExt.begin(); iterExt != secTypesExt.end(); ++iterExt) {
-    switch (*iterExt) {
+  for (uint32_t type : secTypesExt) {
+    switch (type) {
     case secTypePlain:
       encNoneCheckbox->value(true);
       authPlainCheckbox->value(true);
@@ -330,9 +328,9 @@ void OptionsDialog::loadOptions(void)
   menuKeyChoice->value(0);
 
   menuKeyBuf = menuKey;
-  for (int i = 0; i < getMenuKeySymbolCount(); i++)
-    if (!strcmp(getMenuKeySymbols()[i].name, menuKeyBuf))
-      menuKeyChoice->value(i + 1);
+  for (int idx = 0; idx < getMenuKeySymbolCount(); idx++)
+    if (!strcmp(getMenuKeySymbols()[idx].name, menuKeyBuf))
+      menuKeyChoice->value(idx + 1);
 
   /* Display */
   if (!fullScreen) {
@@ -577,7 +575,7 @@ void OptionsDialog::createCompressionPage(int tx, int ty, int tw, int th)
 
   encodingGroup->end();
   /* Needed for resize to work sanely */
-  encodingGroup->resizable(NULL);
+  encodingGroup->resizable(nullptr);
   encodingGroup->size(encodingGroup->w(), ty - encodingGroup->y());
   col1_ty = ty;
 
@@ -629,7 +627,7 @@ void OptionsDialog::createCompressionPage(int tx, int ty, int tw, int th)
 
   colorlevelGroup->end();
   /* Needed for resize to work sanely */
-  colorlevelGroup->resizable(NULL);
+  colorlevelGroup->resizable(nullptr);
   colorlevelGroup->size(colorlevelGroup->w(),
                         ty - colorlevelGroup->y());
   col2_ty = ty;
@@ -745,7 +743,7 @@ void OptionsDialog::createSecurityPage(int tx, int ty, int tw, int th)
 
   encryptionGroup->end();
   /* Needed for resize to work sanely */
-  encryptionGroup->resizable(NULL);
+  encryptionGroup->resizable(nullptr);
   encryptionGroup->size(encryptionGroup->w(),
                         ty - encryptionGroup->y());
 
@@ -787,7 +785,7 @@ void OptionsDialog::createSecurityPage(int tx, int ty, int tw, int th)
 
   authenticationGroup->end();
   /* Needed for resize to work sanely */
-  authenticationGroup->resizable(NULL);
+  authenticationGroup->resizable(nullptr);
   authenticationGroup->size(authenticationGroup->w(),
                             ty - authenticationGroup->y());
 
@@ -847,7 +845,7 @@ void OptionsDialog::createInputPage(int tx, int ty, int tw, int th)
 
   mouseGroup->end();
   /* Needed for resize to work sanely */
-  mouseGroup->resizable(NULL);
+  mouseGroup->resizable(nullptr);
   mouseGroup->size(mouseGroup->w(), ty - mouseGroup->y());
 
   /* Back to normal */
@@ -873,9 +871,9 @@ void OptionsDialog::createInputPage(int tx, int ty, int tw, int th)
 
     menuKeyChoice = new Fl_Choice(LBLLEFT(tx, ty, 150, CHOICE_HEIGHT, _("Menu key")));
 
-    fltk_menu_add(menuKeyChoice, _("None"), 0, NULL, (void*)0, FL_MENU_DIVIDER);
-    for (int i = 0; i < getMenuKeySymbolCount(); i++)
-      fltk_menu_add(menuKeyChoice, getMenuKeySymbols()[i].name, 0, NULL, 0, 0);
+    fltk_menu_add(menuKeyChoice, _("None"), 0, nullptr, nullptr, FL_MENU_DIVIDER);
+    for (int idx = 0; idx < getMenuKeySymbolCount(); idx++)
+      fltk_menu_add(menuKeyChoice, getMenuKeySymbols()[idx].name, 0, nullptr, nullptr, 0);
 
     ty += CHOICE_HEIGHT + TIGHT_MARGIN;
   }
@@ -883,7 +881,7 @@ void OptionsDialog::createInputPage(int tx, int ty, int tw, int th)
 
   keyboardGroup->end();
   /* Needed for resize to work sanely */
-  keyboardGroup->resizable(NULL);
+  keyboardGroup->resizable(nullptr);
   keyboardGroup->size(keyboardGroup->w(), ty - keyboardGroup->y());
 
   /* Back to normal */
@@ -935,7 +933,7 @@ void OptionsDialog::createInputPage(int tx, int ty, int tw, int th)
 
   clipboardGroup->end();
   /* Needed for resize to work sanely */
-  clipboardGroup->resizable(NULL);
+  clipboardGroup->resizable(nullptr);
   clipboardGroup->size(clipboardGroup->w(), ty - clipboardGroup->y());
 
   /* Back to normal */
@@ -1013,7 +1011,7 @@ void OptionsDialog::createDisplayPage(int tx, int ty, int tw, int th)
 
   displayModeGroup->end();
   /* Needed for resize to work sanely */
-  displayModeGroup->resizable(NULL);
+  displayModeGroup->resizable(nullptr);
   displayModeGroup->size(displayModeGroup->w(),
                          ty - displayModeGroup->y());
 
diff --git a/vncviewer/OptionsDialog.h b/vncviewer/OptionsDialog.h
index be08620dc..f6ca89b1b 100644
--- a/vncviewer/OptionsDialog.h
+++ b/vncviewer/OptionsDialog.h
@@ -42,10 +42,10 @@ class OptionsDialog : public Fl_Window {
 public:
   static void showDialog(void);
 
-  static void addCallback(OptionsCallback *cb, void *data = NULL);
+  static void addCallback(OptionsCallback *cb, void *data = nullptr);
   static void removeCallback(OptionsCallback *cb);
 
-  void show(void);
+  void show(void) override;
 
 protected:
   void loadOptions(void);
diff --git a/vncviewer/PlatformPixelBuffer.cxx b/vncviewer/PlatformPixelBuffer.cxx
index 2c91c7045..bcb4cb231 100644
--- a/vncviewer/PlatformPixelBuffer.cxx
+++ b/vncviewer/PlatformPixelBuffer.cxx
@@ -41,16 +41,16 @@ static rfb::LogWriter vlog("PlatformPixelBuffer");
 PlatformPixelBuffer::PlatformPixelBuffer(int width, int height) :
   FullFramePixelBuffer(rfb::PixelFormat(32, 24, false, true,
                                         255, 255, 255, 16, 8, 0),
-                       0, 0, NULL, 0),
+                       0, 0, nullptr, 0),
   Surface(width, height)
 #if !defined(WIN32) && !defined(__APPLE__)
-  , shminfo(NULL), xim(NULL)
+  , shminfo(nullptr), xim(nullptr)
 #endif
 {
 #if !defined(WIN32) && !defined(__APPLE__)
   if (!setupShm(width, height)) {
-    xim = XCreateImage(fl_display, CopyFromParent, 32,
-                       ZPixmap, 0, 0, width, height, 32, 0);
+    xim = XCreateImage(fl_display, (Visual*)CopyFromParent, 32,
+                       ZPixmap, 0, nullptr, width, height, 32, 0);
     if (!xim)
       throw rdr::Exception("XCreateImage");
 
@@ -78,15 +78,15 @@ PlatformPixelBuffer::~PlatformPixelBuffer()
     vlog.debug("Freeing shared memory XImage");
     XShmDetach(fl_display, shminfo);
     shmdt(shminfo->shmaddr);
-    shmctl(shminfo->shmid, IPC_RMID, 0);
+    shmctl(shminfo->shmid, IPC_RMID, nullptr);
     delete shminfo;
-    shminfo = NULL;
+    shminfo = nullptr;
   }
 
   // XDestroyImage() will free(xim->data) if appropriate
   if (xim)
     XDestroyImage(xim);
-  xim = NULL;
+  xim = nullptr;
 #endif
 }
 
@@ -113,7 +113,7 @@ rfb::Rect PlatformPixelBuffer::getDamage(void)
 
   GC gc;
 
-  gc = XCreateGC(fl_display, pixmap, 0, NULL);
+  gc = XCreateGC(fl_display, pixmap, 0, nullptr);
   if (shminfo) {
     XShmPutImage(fl_display, pixmap, gc, xim,
                  r.tl.x, r.tl.y, r.tl.x, r.tl.y,
@@ -147,7 +147,7 @@ bool PlatformPixelBuffer::setupShm(int width, int height)
   int major, minor;
   Bool pixmaps;
   XErrorHandler old_handler;
-  const char *display_name = XDisplayName (NULL);
+  const char *display_name = XDisplayName(nullptr);
 
   /* Don't use MIT-SHM on remote displays */
   if (*display_name && *display_name != ':')
@@ -158,8 +158,8 @@ bool PlatformPixelBuffer::setupShm(int width, int height)
 
   shminfo = new XShmSegmentInfo;
 
-  xim = XShmCreateImage(fl_display, CopyFromParent, 32,
-                        ZPixmap, 0, shminfo, width, height);
+  xim = XShmCreateImage(fl_display, (Visual*)CopyFromParent, 32,
+                        ZPixmap, nullptr, shminfo, width, height);
   if (!xim)
     goto free_shminfo;
 
@@ -169,8 +169,8 @@ bool PlatformPixelBuffer::setupShm(int width, int height)
   if (shminfo->shmid == -1)
     goto free_xim;
 
-  shminfo->shmaddr = xim->data = (char*)shmat(shminfo->shmid, 0, 0);
-  shmctl(shminfo->shmid, IPC_RMID, 0); // to avoid memory leakage
+  shminfo->shmaddr = xim->data = (char*)shmat(shminfo->shmid, nullptr, 0);
+  shmctl(shminfo->shmid, IPC_RMID, nullptr); // to avoid memory leakage
   if (shminfo->shmaddr == (char *)-1)
     goto free_xim;
 
@@ -202,11 +202,11 @@ bool PlatformPixelBuffer::setupShm(int width, int height)
 
 free_xim:
   XDestroyImage(xim);
-  xim = NULL;
+  xim = nullptr;
 
 free_shminfo:
   delete shminfo;
-  shminfo = NULL;
+  shminfo = nullptr;
 
   return 0;
 }
diff --git a/vncviewer/PlatformPixelBuffer.h b/vncviewer/PlatformPixelBuffer.h
index ec439f64f..24763d466 100644
--- a/vncviewer/PlatformPixelBuffer.h
+++ b/vncviewer/PlatformPixelBuffer.h
@@ -40,7 +40,7 @@ class PlatformPixelBuffer: public rfb::FullFramePixelBuffer, public Surface {
   PlatformPixelBuffer(int width, int height);
   ~PlatformPixelBuffer();
 
-  virtual void commitBufferRW(const rfb::Rect& r);
+  void commitBufferRW(const rfb::Rect& r) override;
 
   rfb::Rect getDamage(void);
 
diff --git a/vncviewer/ServerDialog.cxx b/vncviewer/ServerDialog.cxx
index 4d57b5fbb..3bce2b510 100644
--- a/vncviewer/ServerDialog.cxx
+++ b/vncviewer/ServerDialog.cxx
@@ -110,7 +110,7 @@ ServerDialog::ServerDialog()
   y += BUTTON_HEIGHT + INNER_MARGIN;
 
   /* Needed for resize to work sanely */
-  resizable(NULL);
+  resizable(nullptr);
   h(y-INNER_MARGIN+OUTER_MARGIN);
 
   callback(this->handleCancel, this);
@@ -146,7 +146,7 @@ void ServerDialog::run(const char* servername, char *newservername)
 
   while (dialog.shown()) Fl::wait();
 
-  if (dialog.serverName->value() == NULL) {
+  if (dialog.serverName->value() == nullptr) {
     newservername[0] = '\0';
     return;
   }
@@ -180,7 +180,7 @@ void ServerDialog::handleLoad(Fl_Widget* /*widget*/, void* data)
     Fl::wait();
   
   // Did the user hit cancel?
-  if (file_chooser->value() == NULL) {
+  if (file_chooser->value() == nullptr) {
     delete(file_chooser);
     return;
   }
@@ -223,7 +223,7 @@ void ServerDialog::handleSaveAs(Fl_Widget* /*widget*/, void* data)
       Fl::wait();
     
     // Did the user hit cancel?
-    if (file_chooser->value() == NULL) {
+    if (file_chooser->value() == nullptr) {
       delete(file_chooser);
       return;
     }
@@ -237,7 +237,7 @@ void ServerDialog::handleSaveAs(Fl_Widget* /*widget*/, void* data)
       // The file already exists.
       fclose(f);
       int overwrite_choice = fl_choice(_("%s already exists. Do you want to overwrite?"), 
-                                       _("Overwrite"), _("No"), NULL, filename);
+                                       _("Overwrite"), _("No"), nullptr, filename);
       if (overwrite_choice == 1) {
 
         // If the user doesn't want to overwrite:
@@ -284,7 +284,7 @@ void ServerDialog::handleConnect(Fl_Widget* /*widget*/, void *data)
   dialog->hide();
 
   try {
-    saveViewerParameters(NULL, servername);
+    saveViewerParameters(nullptr, servername);
   } catch (Exception& e) {
     vlog.error("%s", e.str());
     fl_alert(_("Unable to save the default configuration:\n\n%s"),
@@ -316,7 +316,7 @@ void ServerDialog::loadServerHistory()
 #endif
 
   const char* stateDir = os::getvncstatedir();
-  if (stateDir == NULL)
+  if (stateDir == nullptr)
     throw Exception(_("Could not obtain the state directory path"));
 
   char filepath[PATH_MAX];
@@ -382,7 +382,7 @@ void ServerDialog::saveServerHistory()
 #endif
 
   const char* stateDir = os::getvncstatedir();
-  if (stateDir == NULL)
+  if (stateDir == nullptr)
     throw Exception(_("Could not obtain the state directory path"));
 
   char filepath[PATH_MAX];
@@ -395,8 +395,8 @@ void ServerDialog::saveServerHistory()
                     filepath, strerror(errno));
 
   // Save the last X elements to the config file.
-  for(size_t i=0; i < serverHistory.size() && i <= SERVER_HISTORY_SIZE; i++)
-    fprintf(f, "%s\n", serverHistory[i].c_str());
+  for(size_t idx=0; idx < serverHistory.size() && idx <= SERVER_HISTORY_SIZE; idx++)
+    fprintf(f, "%s\n", serverHistory[idx].c_str());
 
   fclose(f);
 }
diff --git a/vncviewer/Surface.h b/vncviewer/Surface.h
index 1cb87f502..60e452b16 100644
--- a/vncviewer/Surface.h
+++ b/vncviewer/Surface.h
@@ -41,11 +41,15 @@ class Surface {
 
   void clear(unsigned char r, unsigned char g, unsigned char b, unsigned char a=255);
 
-  void draw(int src_x, int src_y, int x, int y, int w, int h);
-  void draw(Surface* dst, int src_x, int src_y, int x, int y, int w, int h);
+  void draw(int src_x, int src_y, int dst_x, int dst_y,
+            int dst_w, int dst_h);
+  void draw(Surface* dst, int src_x, int src_y, int dst_x, int dst_y,
+            int dst_w, int dst_h);
 
-  void blend(int src_x, int src_y, int x, int y, int w, int h, int a=255);
-  void blend(Surface* dst, int src_x, int src_y, int x, int y, int w, int h, int a=255);
+  void blend(int src_x, int src_y, int dst_x, int dst_y,
+             int dst_w, int dst_h, int a=255);
+  void blend(Surface* dst, int src_x, int src_y, int dst_x, int dst_y,
+             int dst_w, int dst_h, int a=255);
 
 protected:
   void alloc();
diff --git a/vncviewer/Surface_OSX.cxx b/vncviewer/Surface_OSX.cxx
index 445c9e6cb..673f37e99 100644
--- a/vncviewer/Surface_OSX.cxx
+++ b/vncviewer/Surface_OSX.cxx
@@ -44,8 +44,8 @@ static CGImageRef create_image(CGColorSpaceRef lut,
 
   CGImageRef image;
 
-  provider = CGDataProviderCreateWithData(NULL, data,
-                                          w * h * 4, NULL);
+  provider = CGDataProviderCreateWithData(nullptr, data,
+                                          w * h * 4, nullptr);
   if (!provider)
     throw rdr::Exception("CGDataProviderCreateWithData");
 
@@ -58,7 +58,8 @@ static CGImageRef create_image(CGColorSpaceRef lut,
 
   image = CGImageCreate(w, h, 8, 32, w * 4, lut,
                         alpha | kCGBitmapByteOrder32Little,
-                        provider, NULL, false, kCGRenderingIntentDefault);
+                        provider, nullptr, false,
+                        kCGRenderingIntentDefault);
   CGDataProviderRelease(provider);
   if (!image)
     throw rdr::Exception("CGImageCreate");
@@ -136,7 +137,8 @@ void Surface::clear(unsigned char r, unsigned char g, unsigned char b, unsigned
   }
 }
 
-void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(int src_x, int src_y, int dst_x, int dst_y,
+                   int dst_w, int dst_h)
 {
   CGColorSpaceRef lut;
 
@@ -147,32 +149,34 @@ void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
   CGContextConcatCTM(fl_gc, CGAffineTransformInvert(CGContextGetCTM(fl_gc)));
 
   // macOS Coordinates are from bottom left, not top left
-  y = Fl_Window::current()->h() - (y + h);
+  dst_y = Fl_Window::current()->h() - (dst_y + dst_h);
 
   lut = cocoa_win_color_space(Fl_Window::current());
   render(fl_gc, lut, data, kCGBlendModeCopy, 1.0,
-         src_x, src_y, width(), height(), x, y, w, h);
+         src_x, src_y, width(), height(), dst_x, dst_y, dst_w, dst_h);
   CGColorSpaceRelease(lut);
 
   CGContextRestoreGState(fl_gc);
 }
 
-void Surface::draw(Surface* dst, int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(Surface* dst, int src_x, int src_y,
+                   int dst_x, int dst_y, int dst_w, int dst_h)
 {
   CGContextRef bitmap;
 
   bitmap = make_bitmap(dst->width(), dst->height(), dst->data);
 
   // macOS Coordinates are from bottom left, not top left
-  y = dst->height() - (y + h);
+  dst_y = dst->height() - (dst_y + dst_h);
 
   render(bitmap, srgb, data, kCGBlendModeCopy, 1.0,
-         src_x, src_y, width(), height(), x, y, w, h);
+         src_x, src_y, width(), height(), dst_x, dst_y, dst_w, dst_h);
 
   CGContextRelease(bitmap);
 }
 
-void Surface::blend(int src_x, int src_y, int x, int y, int w, int h, int a)
+void Surface::blend(int src_x, int src_y, int dst_x, int dst_y,
+                    int dst_w, int dst_h, int a)
 {
   CGColorSpaceRef lut;
 
@@ -183,27 +187,28 @@ void Surface::blend(int src_x, int src_y, int x, int y, int w, int h, int a)
   CGContextConcatCTM(fl_gc, CGAffineTransformInvert(CGContextGetCTM(fl_gc)));
 
   // macOS Coordinates are from bottom left, not top left
-  y = Fl_Window::current()->h() - (y + h);
+  dst_y = Fl_Window::current()->h() - (dst_y + dst_h);
 
   lut = cocoa_win_color_space(Fl_Window::current());
   render(fl_gc, lut, data, kCGBlendModeNormal, (CGFloat)a/255.0,
-         src_x, src_y, width(), height(), x, y, w, h);
+         src_x, src_y, width(), height(), dst_x, dst_y, dst_w, dst_h);
   CGColorSpaceRelease(lut);
 
   CGContextRestoreGState(fl_gc);
 }
 
-void Surface::blend(Surface* dst, int src_x, int src_y, int x, int y, int w, int h, int a)
+void Surface::blend(Surface* dst, int src_x, int src_y,
+                    int dst_x, int dst_y, int dst_w, int dst_h, int a)
 {
   CGContextRef bitmap;
 
   bitmap = make_bitmap(dst->width(), dst->height(), dst->data);
 
   // macOS Coordinates are from bottom left, not top left
-  y = dst->height() - (y + h);
+  dst_y = dst->height() - (dst_y + dst_h);
 
   render(bitmap, srgb, data, kCGBlendModeNormal, (CGFloat)a/255.0,
-         src_x, src_y, width(), height(), x, y, w, h);
+         src_x, src_y, width(), height(), dst_x, dst_y, dst_w, dst_h);
 
   CGContextRelease(bitmap);
 }
diff --git a/vncviewer/Surface_Win32.cxx b/vncviewer/Surface_Win32.cxx
index d438fa12a..46a2b0551 100644
--- a/vncviewer/Surface_Win32.cxx
+++ b/vncviewer/Surface_Win32.cxx
@@ -50,7 +50,8 @@ void Surface::clear(unsigned char r, unsigned char g, unsigned char b, unsigned
   }
 }
 
-void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(int src_x, int src_y, int dst_x, int dst_y,
+                   int dst_w, int dst_h)
 {
   HDC dc;
 
@@ -61,7 +62,8 @@ void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
   if (!SelectObject(dc, bitmap))
     throw rdr::SystemException("SelectObject", GetLastError());
 
-  if (!BitBlt(fl_gc, x, y, w, h, dc, src_x, src_y, SRCCOPY)) {
+  if (!BitBlt(fl_gc, dst_x, dst_y, dst_w, dst_h,
+              dc, src_x, src_y, SRCCOPY)) {
     // If the desktop we're rendering to is inactive (like when the screen
     // is locked or the UAC is active), then GDI calls will randomly fail.
     // This is completely undocumented so we have no idea how best to deal
@@ -74,11 +76,12 @@ void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
   DeleteDC(dc);
 }
 
-void Surface::draw(Surface* dst, int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(Surface* dst, int src_x, int src_y,
+                   int dst_x, int dst_y, int dst_w, int dst_h)
 {
   HDC origdc, dstdc;
 
-  dstdc = CreateCompatibleDC(NULL);
+  dstdc = CreateCompatibleDC(nullptr);
   if (!dstdc)
     throw rdr::SystemException("CreateCompatibleDC", GetLastError());
 
@@ -87,29 +90,31 @@ void Surface::draw(Surface* dst, int src_x, int src_y, int x, int y, int w, int
 
   origdc = fl_gc;
   fl_gc = dstdc;
-  draw(src_x, src_y, x, y, w, h);
+  draw(src_x, src_y, dst_x, dst_y, dst_w, dst_h);
   fl_gc = origdc;
 
   DeleteDC(dstdc);
 }
 
 void Surface::blend(int /*src_x*/, int /*src_y*/,
-                    int /*x*/, int /*y*/, int /*w*/, int /*h*/,
+                    int /*dst_x*/, int /*dst_y*/,
+                    int /*dst_w*/, int /*dst_h*/,
                     int /*a*/)
 {
   // Compositing doesn't work properly for window DC:s
   assert(false);
 }
 
-void Surface::blend(Surface* dst, int src_x, int src_y, int x, int y, int w, int h, int a)
+void Surface::blend(Surface* dst, int src_x, int src_y,
+                    int dst_x, int dst_y, int dst_w, int dst_h, int a)
 {
   HDC dstdc, srcdc;
   BLENDFUNCTION blend;
 
-  dstdc = CreateCompatibleDC(NULL);
+  dstdc = CreateCompatibleDC(nullptr);
   if (!dstdc)
     throw rdr::SystemException("CreateCompatibleDC", GetLastError());
-  srcdc = CreateCompatibleDC(NULL);
+  srcdc = CreateCompatibleDC(nullptr);
   if (!srcdc)
     throw rdr::SystemException("CreateCompatibleDC", GetLastError());
 
@@ -123,7 +128,8 @@ void Surface::blend(Surface* dst, int src_x, int src_y, int x, int y, int w, int
   blend.SourceConstantAlpha = a;
   blend.AlphaFormat = AC_SRC_ALPHA;
 
-  if (!AlphaBlend(dstdc, x, y, w, h, srcdc, src_x, src_y, w, h, blend)) {
+  if (!AlphaBlend(dstdc, dst_x, dst_y, dst_w, dst_h,
+                  srcdc, src_x, src_y, dst_w, dst_h, blend)) {
     // If the desktop we're rendering to is inactive (like when the screen
     // is locked or the UAC is active), then GDI calls will randomly fail.
     // This is completely undocumented so we have no idea how best to deal
@@ -152,8 +158,8 @@ void Surface::alloc()
   bih.biHeight       = -height(); // Negative to get top-down
   bih.biCompression  = BI_RGB;
 
-  bitmap = CreateDIBSection(NULL, (BITMAPINFO*)&bih,
-                            DIB_RGB_COLORS, (void**)&data, NULL, 0);
+  bitmap = CreateDIBSection(nullptr, (BITMAPINFO*)&bih,
+                            DIB_RGB_COLORS, (void**)&data, nullptr, 0);
   if (!bitmap)
     throw rdr::SystemException("CreateDIBSection", GetLastError());
 }
diff --git a/vncviewer/Surface_X11.cxx b/vncviewer/Surface_X11.cxx
index 7725cb5b8..d27fcd262 100644
--- a/vncviewer/Surface_X11.cxx
+++ b/vncviewer/Surface_X11.cxx
@@ -43,20 +43,22 @@ void Surface::clear(unsigned char r, unsigned char g, unsigned char b, unsigned
                        0, 0, width(), height());
 }
 
-void Surface::draw(int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(int src_x, int src_y, int dst_x, int dst_y,
+                   int dst_w, int dst_h)
 {
   Picture winPict;
 
-  winPict = XRenderCreatePicture(fl_display, fl_window, visFormat, 0, NULL);
+  winPict = XRenderCreatePicture(fl_display, fl_window, visFormat, 0, nullptr);
   XRenderComposite(fl_display, PictOpSrc, picture, None, winPict,
-                   src_x, src_y, 0, 0, x, y, w, h);
+                   src_x, src_y, 0, 0, dst_x, dst_y, dst_w, dst_h);
   XRenderFreePicture(fl_display, winPict);
 }
 
-void Surface::draw(Surface* dst, int src_x, int src_y, int x, int y, int w, int h)
+void Surface::draw(Surface* dst, int src_x, int src_y,
+                   int dst_x, int dst_y, int dst_w, int dst_h)
 {
   XRenderComposite(fl_display, PictOpSrc, picture, None, dst->picture,
-                   src_x, src_y, 0, 0, x, y, w, h);
+                   src_x, src_y, 0, 0, dst_x, dst_y, dst_w, dst_h);
 }
 
 static Picture alpha_mask(int a)
@@ -86,27 +88,29 @@ static Picture alpha_mask(int a)
   return pict;
 }
 
-void Surface::blend(int src_x, int src_y, int x, int y, int w, int h, int a)
+void Surface::blend(int src_x, int src_y, int dst_x, int dst_y,
+                    int dst_w, int dst_h, int a)
 {
   Picture winPict, alpha;
 
-  winPict = XRenderCreatePicture(fl_display, fl_window, visFormat, 0, NULL);
+  winPict = XRenderCreatePicture(fl_display, fl_window, visFormat, 0, nullptr);
   alpha = alpha_mask(a);
   XRenderComposite(fl_display, PictOpOver, picture, alpha, winPict,
-                   src_x, src_y, 0, 0, x, y, w, h);
+                   src_x, src_y, 0, 0, dst_x, dst_y, dst_w, dst_h);
   XRenderFreePicture(fl_display, winPict);
 
   if (alpha != None)
     XRenderFreePicture(fl_display, alpha);
 }
 
-void Surface::blend(Surface* dst, int src_x, int src_y, int x, int y, int w, int h, int a)
+void Surface::blend(Surface* dst, int src_x, int src_y,
+                    int dst_x, int dst_y, int dst_w, int dst_h, int a)
 {
   Picture alpha;
 
   alpha = alpha_mask(a);
   XRenderComposite(fl_display, PictOpOver, picture, alpha, dst->picture,
-                   src_x, src_y, 0, 0, x, y, w, h);
+                   src_x, src_y, 0, 0, dst_x, dst_y, dst_w, dst_h);
   if (alpha != None)
     XRenderFreePicture(fl_display, alpha);
 }
@@ -154,7 +158,7 @@ void Surface::alloc()
   if (!format)
     throw rdr::Exception("XRenderFindFormat");
 
-  picture = XRenderCreatePicture(fl_display, pixmap, format, 0, NULL);
+  picture = XRenderCreatePicture(fl_display, pixmap, format, 0, nullptr);
 
   visFormat = XRenderFindVisualFormat(fl_display, fl_visual->visual);
 }
@@ -177,8 +181,8 @@ void Surface::update(const Fl_RGB_Image* image)
   assert(image->w() == width());
   assert(image->h() == height());
 
-  img = XCreateImage(fl_display, CopyFromParent, 32,
-                     ZPixmap, 0, NULL, width(), height(),
+  img = XCreateImage(fl_display, (Visual*)CopyFromParent, 32,
+                     ZPixmap, 0, nullptr, width(), height(),
                      32, 0);
   if (!img)
     throw rdr::Exception("XCreateImage");
@@ -224,7 +228,7 @@ void Surface::update(const Fl_RGB_Image* image)
       in += image->ld() - image->w() * image->d();
   }
 
-  gc = XCreateGC(fl_display, pixmap, 0, NULL);
+  gc = XCreateGC(fl_display, pixmap, 0, nullptr);
   XPutImage(fl_display, pixmap, gc, img,
             0, 0, 0, 0, img->width, img->height);
   XFreeGC(fl_display, gc);
diff --git a/vncviewer/UserDialog.cxx b/vncviewer/UserDialog.cxx
index 7f8b3c8e6..958b9d66d 100644
--- a/vncviewer/UserDialog.cxx
+++ b/vncviewer/UserDialog.cxx
@@ -55,10 +55,10 @@ using namespace rfb;
 static Fl_Pixmap secure_icon(secure);
 static Fl_Pixmap insecure_icon(insecure);
 
-static int ret_val = 0;
+static long ret_val = 0;
 
-static void button_cb(Fl_Widget *widget, void *val) {
-  ret_val = (fl_intptr_t)val;
+static void button_cb(Fl_Widget *widget, long val) {
+  ret_val = val;
   widget->window()->hide();
 }
 
@@ -70,7 +70,7 @@ UserDialog::~UserDialog()
 {
 }
 
-void UserDialog::getUserPasswd(bool secure, std::string* user,
+void UserDialog::getUserPasswd(bool secure_, std::string* user,
                                std::string* password)
 {
   const char *passwordFileName(passwordFile);
@@ -116,12 +116,12 @@ void UserDialog::getUserPasswd(bool secure, std::string* user,
   int x, y;
 
   win = new Fl_Window(410, 0, _("VNC authentication"));
-  win->callback(button_cb,(void *)0);
+  win->callback(button_cb, 0);
 
   banner = new Fl_Box(0, 0, win->w(), 20);
   banner->align(FL_ALIGN_CENTER|FL_ALIGN_INSIDE|FL_ALIGN_IMAGE_NEXT_TO_TEXT);
   banner->box(FL_FLAT_BOX);
-  if (secure) {
+  if (secure_) {
     banner->label(_("This connection is secure"));
     banner->color(FL_GREEN);
     banner->image(secure_icon);
@@ -156,7 +156,7 @@ void UserDialog::getUserPasswd(bool secure, std::string* user,
      * Compiler is not bright enough to understand that
      * username won't be used further down...
      */
-    username = NULL;
+    username = nullptr;
   }
 
   y += INPUT_LABEL_OFFSET;
@@ -171,12 +171,12 @@ void UserDialog::getUserPasswd(bool secure, std::string* user,
   x -= BUTTON_WIDTH;
   button = new Fl_Return_Button(x, y, BUTTON_WIDTH,
                                 BUTTON_HEIGHT, fl_ok);
-  button->callback(button_cb, (void*)0);
+  button->callback(button_cb, 0);
   x -= INNER_MARGIN;
 
   x -= BUTTON_WIDTH;
   button = new Fl_Button(x, y, BUTTON_WIDTH, BUTTON_HEIGHT, fl_cancel);
-  button->callback(button_cb, (void*)1);
+  button->callback(button_cb, 1);
   button->shortcut(FL_Escape);
   x -= INNER_MARGIN;
 
@@ -221,9 +221,9 @@ bool UserDialog::showMsgBox(int flags, const char* title, const char* text)
 
   switch (flags & 0xf) {
   case M_OKCANCEL:
-    return fl_choice("%s", NULL, fl_ok, fl_cancel, buffer) == 1;
+    return fl_choice("%s", nullptr, fl_ok, fl_cancel, buffer) == 1;
   case M_YESNO:
-    return fl_choice("%s", NULL, fl_yes, fl_no, buffer) == 1;
+    return fl_choice("%s", nullptr, fl_yes, fl_no, buffer) == 1;
   case M_OK:
   default:
     if (((flags & 0xf0) == M_ICONERROR) ||
diff --git a/vncviewer/UserDialog.h b/vncviewer/UserDialog.h
index 913af8418..db4e7c45a 100644
--- a/vncviewer/UserDialog.h
+++ b/vncviewer/UserDialog.h
@@ -32,11 +32,11 @@ class UserDialog : public rfb::UserPasswdGetter,
   // UserPasswdGetter callbacks
 
   void getUserPasswd(bool secure, std::string* user,
-                     std::string* password);
+                     std::string* password) override;
 
   // UserMsgBox callbacks
 
-  bool showMsgBox(int flags, const char* title, const char* text);
+  bool showMsgBox(int flags, const char* title, const char* text) override;
 };
 
 #endif
diff --git a/vncviewer/Viewport.cxx b/vncviewer/Viewport.cxx
index 5dd5f7efc..032fd3221 100644
--- a/vncviewer/Viewport.cxx
+++ b/vncviewer/Viewport.cxx
@@ -116,13 +116,13 @@ static const WORD SCAN_FAKE = 0xaa;
 #endif
 
 Viewport::Viewport(int w, int h, const rfb::PixelFormat& /*serverPF*/, CConn* cc_)
-  : Fl_Widget(0, 0, w, h), cc(cc_), frameBuffer(NULL),
+  : Fl_Widget(0, 0, w, h), cc(cc_), frameBuffer(nullptr),
     lastPointerPos(0, 0), lastButtonMask(0),
 #ifdef WIN32
     altGrArmed(false),
 #endif
     firstLEDState(true), pendingClientClipboard(false),
-    menuCtrlKey(false), menuAltKey(false), cursor(NULL)
+    menuCtrlKey(false), menuAltKey(false), cursor(nullptr)
 {
 #if !defined(WIN32) && !defined(__APPLE__)
   XkbDescPtr xkb;
@@ -188,7 +188,7 @@ Viewport::Viewport(int w, int h, const rfb::PixelFormat& /*serverPF*/, CConn* cc
   OptionsDialog::addCallback(handleOptions, this);
 
   // Make sure we have an initial blank cursor set
-  setCursor(0, 0, rfb::Point(0, 0), NULL);
+  setCursor(0, 0, rfb::Point(0, 0), nullptr);
 }
 
 
@@ -329,9 +329,9 @@ void Viewport::handleClipboardData(const char* data)
   Fl::copy(data, len, 1);
 }
 
-void Viewport::setLEDState(unsigned int state)
+void Viewport::setLEDState(unsigned int ledState)
 {
-  vlog.debug("Got server LED state: 0x%08x", state);
+  vlog.debug("Got server LED state: 0x%08x", ledState);
 
   // The first message is just considered to be the server announcing
   // support for this extension. We will push our state to sync up the
@@ -355,7 +355,7 @@ void Viewport::setLEDState(unsigned int state)
   memset(input, 0, sizeof(input));
   count = 0;
 
-  if (!!(state & ledCapsLock) != !!(GetKeyState(VK_CAPITAL) & 0x1)) {
+  if (!!(ledState & ledCapsLock) != !!(GetKeyState(VK_CAPITAL) & 0x1)) {
     input[count].type = input[count+1].type = INPUT_KEYBOARD;
     input[count].ki.wVk = input[count+1].ki.wVk = VK_CAPITAL;
     input[count].ki.wScan = input[count+1].ki.wScan = SCAN_FAKE;
@@ -364,7 +364,7 @@ void Viewport::setLEDState(unsigned int state)
     count += 2;
   }
 
-  if (!!(state & ledNumLock) != !!(GetKeyState(VK_NUMLOCK) & 0x1)) {
+  if (!!(ledState & ledNumLock) != !!(GetKeyState(VK_NUMLOCK) & 0x1)) {
     input[count].type = input[count+1].type = INPUT_KEYBOARD;
     input[count].ki.wVk = input[count+1].ki.wVk = VK_NUMLOCK;
     input[count].ki.wScan = input[count+1].ki.wScan = SCAN_FAKE;
@@ -373,7 +373,7 @@ void Viewport::setLEDState(unsigned int state)
     count += 2;
   }
 
-  if (!!(state & ledScrollLock) != !!(GetKeyState(VK_SCROLL) & 0x1)) {
+  if (!!(ledState & ledScrollLock) != !!(GetKeyState(VK_SCROLL) & 0x1)) {
     input[count].type = input[count+1].type = INPUT_KEYBOARD;
     input[count].ki.wVk = input[count+1].ki.wVk = VK_SCROLL;
     input[count].ki.wScan = input[count+1].ki.wScan = SCAN_FAKE;
@@ -391,13 +391,13 @@ void Viewport::setLEDState(unsigned int state)
 #elif defined(__APPLE__)
   int ret;
 
-  ret = cocoa_set_caps_lock_state(state & ledCapsLock);
+  ret = cocoa_set_caps_lock_state(ledState & ledCapsLock);
   if (ret != 0) {
     vlog.error(_("Failed to update keyboard LED state: %d"), ret);
     return;
   }
 
-  ret = cocoa_set_num_lock_state(state & ledNumLock);
+  ret = cocoa_set_num_lock_state(ledState & ledNumLock);
   if (ret != 0) {
     vlog.error(_("Failed to update keyboard LED state: %d"), ret);
     return;
@@ -414,17 +414,17 @@ void Viewport::setLEDState(unsigned int state)
   affect = values = 0;
 
   affect |= LockMask;
-  if (state & ledCapsLock)
+  if (ledState & ledCapsLock)
     values |= LockMask;
 
   mask = getModifierMask(XK_Num_Lock);
   affect |= mask;
-  if (state & ledNumLock)
+  if (ledState & ledNumLock)
     values |= mask;
 
   mask = getModifierMask(XK_Scroll_Lock);
   affect |= mask;
-  if (state & ledScrollLock)
+  if (ledState & ledScrollLock)
     values |= mask;
 
   ret = XkbLockModifiers(fl_display, XkbUseCoreKbd, affect, values);
@@ -435,21 +435,21 @@ void Viewport::setLEDState(unsigned int state)
 
 void Viewport::pushLEDState()
 {
-  unsigned int state;
+  unsigned int ledState;
 
   // Server support?
   if (cc->server.ledState() == ledUnknown)
     return;
 
-  state = 0;
+  ledState = 0;
 
 #if defined(WIN32)
   if (GetKeyState(VK_CAPITAL) & 0x1)
-    state |= ledCapsLock;
+    ledState |= ledCapsLock;
   if (GetKeyState(VK_NUMLOCK) & 0x1)
-    state |= ledNumLock;
+    ledState |= ledNumLock;
   if (GetKeyState(VK_SCROLL) & 0x1)
-    state |= ledScrollLock;
+    ledState |= ledScrollLock;
 #elif defined(__APPLE__)
   int ret;
   bool on;
@@ -460,7 +460,7 @@ void Viewport::pushLEDState()
     return;
   }
   if (on)
-    state |= ledCapsLock;
+    ledState |= ledCapsLock;
 
   ret = cocoa_get_num_lock_state(&on);
   if (ret != 0) {
@@ -468,10 +468,10 @@ void Viewport::pushLEDState()
     return;
   }
   if (on)
-    state |= ledNumLock;
+    ledState |= ledNumLock;
 
   // No support for Scroll Lock //
-  state |= (cc->server.ledState() & ledScrollLock);
+  ledState |= (cc->server.ledState() & ledScrollLock);
 
 #else
   unsigned int mask;
@@ -486,28 +486,28 @@ void Viewport::pushLEDState()
   }
 
   if (xkbState.locked_mods & LockMask)
-    state |= ledCapsLock;
+    ledState |= ledCapsLock;
 
   mask = getModifierMask(XK_Num_Lock);
   if (xkbState.locked_mods & mask)
-    state |= ledNumLock;
+    ledState |= ledNumLock;
 
   mask = getModifierMask(XK_Scroll_Lock);
   if (xkbState.locked_mods & mask)
-    state |= ledScrollLock;
+    ledState |= ledScrollLock;
 #endif
 
-  if ((state & ledCapsLock) != (cc->server.ledState() & ledCapsLock)) {
+  if ((ledState & ledCapsLock) != (cc->server.ledState() & ledCapsLock)) {
     vlog.debug("Inserting fake CapsLock to get in sync with server");
     handleKeyPress(0x3a, XK_Caps_Lock);
     handleKeyRelease(0x3a);
   }
-  if ((state & ledNumLock) != (cc->server.ledState() & ledNumLock)) {
+  if ((ledState & ledNumLock) != (cc->server.ledState() & ledNumLock)) {
     vlog.debug("Inserting fake NumLock to get in sync with server");
     handleKeyPress(0x45, XK_Num_Lock);
     handleKeyRelease(0x45);
   }
-  if ((state & ledScrollLock) != (cc->server.ledState() & ledScrollLock)) {
+  if ((ledState & ledScrollLock) != (cc->server.ledState() & ledScrollLock)) {
     vlog.debug("Inserting fake ScrollLock to get in sync with server");
     handleKeyPress(0x46, XK_Scroll_Lock);
     handleKeyRelease(0x46);
@@ -702,7 +702,7 @@ unsigned int Viewport::getModifierMask(unsigned int keysym)
   mask = 0;
 
   xkb = XkbGetMap(fl_display, XkbAllComponentsMask, XkbUseCoreKbd);
-  if (xkb == NULL)
+  if (xkb == nullptr)
     return 0;
 
   for (keycode = xkb->min_key_code; keycode <= xkb->max_key_code; keycode++) {
@@ -722,7 +722,7 @@ unsigned int Viewport::getModifierMask(unsigned int keysym)
     goto out;
 
   act = XkbKeyAction(xkb, keycode, 0);
-  if (act == NULL)
+  if (act == nullptr)
     goto out;
   if (act->type != XkbSA_LockMods)
     goto out;
@@ -1164,7 +1164,7 @@ int Viewport::handleSystemEvent(void *event, void *data)
     if (keycode == 0)
         keycode = 0x100 | xevent->xkey.keycode;
 
-    XLookupString(&xevent->xkey, &str, 1, &keysym, NULL);
+    XLookupString(&xevent->xkey, &str, 1, &keysym, nullptr);
     if (keysym == NoSymbol) {
       vlog.error(_("No symbol for key code %d (in the current state)"),
                  (int)xevent->xkey.keycode);
@@ -1222,52 +1222,56 @@ void Viewport::resolveAltGrDetection(bool isAltGrSequence)
 }
 #endif
 
+// FIXME: gcc confuses ID_DISCONNECT with NULL
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wzero-as-null-pointer-constant"
 void Viewport::initContextMenu()
 {
   contextMenu->clear();
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "Disconn&ect"),
-                0, NULL, (void*)ID_DISCONNECT, FL_MENU_DIVIDER);
+                0, nullptr, (void*)ID_DISCONNECT, FL_MENU_DIVIDER);
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "&Full screen"),
-                0, NULL, (void*)ID_FULLSCREEN,
+                0, nullptr, (void*)ID_FULLSCREEN,
                 FL_MENU_TOGGLE | (window()->fullscreen_active()?FL_MENU_VALUE:0));
   fltk_menu_add(contextMenu, p_("ContextMenu|", "Minimi&ze"),
-                0, NULL, (void*)ID_MINIMIZE, 0);
+                0, nullptr, (void*)ID_MINIMIZE, 0);
   fltk_menu_add(contextMenu, p_("ContextMenu|", "Resize &window to session"),
-                0, NULL, (void*)ID_RESIZE,
+                0, nullptr, (void*)ID_RESIZE,
                 (window()->fullscreen_active()?FL_MENU_INACTIVE:0) |
                 FL_MENU_DIVIDER);
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "&Ctrl"),
-                0, NULL, (void*)ID_CTRL,
+                0, nullptr, (void*)ID_CTRL,
                 FL_MENU_TOGGLE | (menuCtrlKey?FL_MENU_VALUE:0));
   fltk_menu_add(contextMenu, p_("ContextMenu|", "&Alt"),
-                0, NULL, (void*)ID_ALT,
+                0, nullptr, (void*)ID_ALT,
                 FL_MENU_TOGGLE | (menuAltKey?FL_MENU_VALUE:0));
 
   if (menuKeySym) {
     char sendMenuKey[64];
     snprintf(sendMenuKey, 64, p_("ContextMenu|", "Send %s"), (const char *)menuKey);
-    fltk_menu_add(contextMenu, sendMenuKey, 0, NULL, (void*)ID_MENUKEY, 0);
-    fltk_menu_add(contextMenu, "Secret shortcut menu key", menuKeyFLTK, NULL,
+    fltk_menu_add(contextMenu, sendMenuKey, 0, nullptr, (void*)ID_MENUKEY, 0);
+    fltk_menu_add(contextMenu, "Secret shortcut menu key",
+                  menuKeyFLTK, nullptr,
                   (void*)ID_MENUKEY, FL_MENU_INVISIBLE);
   }
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "Send Ctrl-Alt-&Del"),
-                0, NULL, (void*)ID_CTRLALTDEL, FL_MENU_DIVIDER);
+                0, nullptr, (void*)ID_CTRLALTDEL, FL_MENU_DIVIDER);
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "&Refresh screen"),
-                0, NULL, (void*)ID_REFRESH, FL_MENU_DIVIDER);
+                0, nullptr, (void*)ID_REFRESH, FL_MENU_DIVIDER);
 
   fltk_menu_add(contextMenu, p_("ContextMenu|", "&Options..."),
-                0, NULL, (void*)ID_OPTIONS, 0);
+                0, nullptr, (void*)ID_OPTIONS, 0);
   fltk_menu_add(contextMenu, p_("ContextMenu|", "Connection &info..."),
-                0, NULL, (void*)ID_INFO, 0);
+                0, nullptr, (void*)ID_INFO, 0);
   fltk_menu_add(contextMenu, p_("ContextMenu|", "About &TigerVNC viewer..."),
-                0, NULL, (void*)ID_ABOUT, 0);
+                0, nullptr, (void*)ID_ABOUT, 0);
 }
-
+#pragma GCC diagnostic pop
 
 void Viewport::popupContextMenu()
 {
@@ -1297,7 +1301,7 @@ void Viewport::popupContextMenu()
   if (Fl::belowmouse())
     window()->cursor(cursor, cursorHotspot.x, cursorHotspot.y);
 
-  if (m == NULL)
+  if (m == nullptr)
     return;
 
   switch (m->argument()) {
diff --git a/vncviewer/Viewport.h b/vncviewer/Viewport.h
index 4b674aa1f..d936c7089 100644
--- a/vncviewer/Viewport.h
+++ b/vncviewer/Viewport.h
@@ -63,14 +63,14 @@ class Viewport : public Fl_Widget, public EmulateMB {
 
   // Fl_Widget callback methods
 
-  void draw();
+  void draw() override;
 
-  void resize(int x, int y, int w, int h);
+  void resize(int x, int y, int w, int h) override;
 
-  int handle(int event);
+  int handle(int event) override;
 
 protected:
-  virtual void sendPointerEvent(const rfb::Point& pos, int buttonMask);
+  void sendPointerEvent(const rfb::Point& pos, int buttonMask) override;
 
 private:
   bool hasFocus();
diff --git a/vncviewer/Win32TouchHandler.cxx b/vncviewer/Win32TouchHandler.cxx
index d6dc7aa42..e21768f92 100644
--- a/vncviewer/Win32TouchHandler.cxx
+++ b/vncviewer/Win32TouchHandler.cxx
@@ -37,13 +37,13 @@ static const DWORD MOUSEMOVE_FLAGS = MOUSEEVENTF_MOVE | MOUSEEVENTF_ABSOLUTE |
 
 static const unsigned SINGLE_PAN_THRESHOLD = 50;
 
-Win32TouchHandler::Win32TouchHandler(HWND hWnd) :
-  hWnd(hWnd), gesturesConfigured(false), gestureActive(false),
+Win32TouchHandler::Win32TouchHandler(HWND hWnd_) :
+  hWnd(hWnd_), gesturesConfigured(false), gestureActive(false),
   ignoringGesture(false), fakeButtonMask(0)
 {
   // If window is registered as touch we can not receive gestures,
   // this should not happen
-  if (IsTouchWindow(hWnd, NULL))
+  if (IsTouchWindow(hWnd, nullptr))
     throw rfb::Exception(_("Window is registered for touch instead of gestures"));
 
   // We will not receive any touch/gesture events if this service
diff --git a/vncviewer/Win32TouchHandler.h b/vncviewer/Win32TouchHandler.h
index 05039c884..a0554ccda 100644
--- a/vncviewer/Win32TouchHandler.h
+++ b/vncviewer/Win32TouchHandler.h
@@ -35,11 +35,11 @@ class Win32TouchHandler: public BaseTouchHandler {
     bool isSinglePan(GESTUREINFO gi);
 
   protected:
-    virtual void fakeMotionEvent(const GestureEvent origEvent);
-    virtual void fakeButtonEvent(bool press, int button,
-                                 const GestureEvent origEvent);
-    virtual void fakeKeyEvent(bool press, int keycode,
-                              const GestureEvent origEvent);
+    void fakeMotionEvent(const GestureEvent origEvent) override;
+    void fakeButtonEvent(bool press, int button,
+                         const GestureEvent origEvent) override;
+    void fakeKeyEvent(bool press, int keycode,
+                      const GestureEvent origEvent) override;
   private:
     void pushFakeEvent(UINT Msg, WPARAM wParam, LPARAM lParam);
 
diff --git a/vncviewer/XInputTouchHandler.cxx b/vncviewer/XInputTouchHandler.cxx
index 6203bda58..2b2e02c6a 100644
--- a/vncviewer/XInputTouchHandler.cxx
+++ b/vncviewer/XInputTouchHandler.cxx
@@ -43,8 +43,8 @@ static rfb::LogWriter vlog("XInputTouchHandler");
 
 static bool grabbed = false;
 
-XInputTouchHandler::XInputTouchHandler(Window wnd)
-  : wnd(wnd), fakeStateMask(0)
+XInputTouchHandler::XInputTouchHandler(Window wnd_)
+  : wnd(wnd_), fakeStateMask(0)
 {
   XIEventMask eventmask;
   unsigned char flags[XIMaskLen(XI_LASTEVENT)] = { 0 };
@@ -97,7 +97,7 @@ bool XInputTouchHandler::grabPointer()
 
   // We grab for the same events as the window is currently interested in
   curmasks = XIGetSelectedEvents(fl_display, wnd, &num_masks);
-  if (curmasks == NULL) {
+  if (curmasks == nullptr) {
     if (num_masks == -1)
       vlog.error(_("Unable to get X Input 2 event mask for window 0x%08lx"), wnd);
     else
@@ -314,7 +314,7 @@ void XInputTouchHandler::preparePointerEvent(XEvent* dst, const GestureEvent src
 {
   Window root, child;
   int rootX, rootY;
-  XkbStateRec state;
+  XkbStateRec xkbState;
 
   // We don't have a real event to steal things from, so we'll have
   // to fake these events based on the current state of things
@@ -324,7 +324,7 @@ void XInputTouchHandler::preparePointerEvent(XEvent* dst, const GestureEvent src
                         src.eventX,
                         src.eventY,
                         &rootX, &rootY, &child);
-  XkbGetState(fl_display, XkbUseCoreKbd, &state);
+  XkbGetState(fl_display, XkbUseCoreKbd, &xkbState);
 
   // XButtonEvent and XMotionEvent are almost identical, so we
   // don't have to care which it is for these fields
@@ -338,8 +338,8 @@ void XInputTouchHandler::preparePointerEvent(XEvent* dst, const GestureEvent src
   dst->xbutton.y = src.eventY;
   dst->xbutton.x_root = rootX;
   dst->xbutton.y_root = rootY;
-  dst->xbutton.state = state.mods;
-  dst->xbutton.state |= ((state.ptr_buttons >> 1) & 0x1f) << 8;
+  dst->xbutton.state = xkbState.mods;
+  dst->xbutton.state |= ((xkbState.ptr_buttons >> 1) & 0x1f) << 8;
   dst->xbutton.same_screen = True;
 }
 
@@ -390,7 +390,7 @@ void XInputTouchHandler::fakeKeyEvent(bool press, int keysym,
 
   Window root, child;
   int rootX, rootY;
-  XkbStateRec state;
+  XkbStateRec xkbState;
 
   int modmask;
 
@@ -399,7 +399,7 @@ void XInputTouchHandler::fakeKeyEvent(bool press, int keysym,
                         origEvent.eventX,
                         origEvent.eventY,
                         &rootX, &rootY, &child);
-  XkbGetState(fl_display, XkbUseCoreKbd, &state);
+  XkbGetState(fl_display, XkbUseCoreKbd, &xkbState);
 
   KeyCode kc = XKeysymToKeycode(fl_display, keysym);
 
@@ -418,8 +418,8 @@ void XInputTouchHandler::fakeKeyEvent(bool press, int keysym,
   fakeEvent.xkey.y = origEvent.eventY;
   fakeEvent.xkey.x_root = rootX;
   fakeEvent.xkey.y_root = rootY;
-  fakeEvent.xkey.state = state.mods;
-  fakeEvent.xkey.state |= ((state.ptr_buttons >> 1) & 0x1f) << 8;
+  fakeEvent.xkey.state = xkbState.mods;
+  fakeEvent.xkey.state |= ((xkbState.ptr_buttons >> 1) & 0x1f) << 8;
   fakeEvent.xkey.same_screen = True;
 
   // Apply our fake mask
diff --git a/vncviewer/XInputTouchHandler.h b/vncviewer/XInputTouchHandler.h
index 6360b974a..897c55ae2 100644
--- a/vncviewer/XInputTouchHandler.h
+++ b/vncviewer/XInputTouchHandler.h
@@ -39,13 +39,13 @@ class XInputTouchHandler: public BaseTouchHandler, GestureHandler {
                          const XIDeviceEvent* origEvent);
 
     void preparePointerEvent(XEvent* dst, const GestureEvent src);
-    virtual void fakeMotionEvent(const GestureEvent origEvent);
-    virtual void fakeButtonEvent(bool press, int button,
-                                 const GestureEvent origEvent);
-    virtual void fakeKeyEvent(bool press, int keycode,
-                              const GestureEvent origEvent);
+    void fakeMotionEvent(const GestureEvent origEvent) override;
+    void fakeButtonEvent(bool press, int button,
+                         const GestureEvent origEvent) override;
+    void fakeKeyEvent(bool press, int keycode,
+                      const GestureEvent origEvent) override;
 
-    virtual void handleGestureEvent(const GestureEvent& event);
+    void handleGestureEvent(const GestureEvent& event) override;
 
   private:
     void pushFakeEvent(XEvent* event);
diff --git a/vncviewer/cocoa.mm b/vncviewer/cocoa.mm
index d801a106e..a355b4843 100644
--- a/vncviewer/cocoa.mm
+++ b/vncviewer/cocoa.mm
@@ -301,7 +301,7 @@ int cocoa_event_keycode(const void *event)
   const UCKeyboardLayout *layout;
   OSStatus err;
 
-  layout = NULL;
+  layout = nullptr;
 
   TISInputSourceRef keyboard;
   CFDataRef uchr;
@@ -309,11 +309,11 @@ int cocoa_event_keycode(const void *event)
   keyboard = TISCopyCurrentKeyboardLayoutInputSource();
   uchr = (CFDataRef)TISGetInputSourceProperty(keyboard,
                                               kTISPropertyUnicodeKeyLayoutData);
-  if (uchr == NULL)
+  if (uchr == nullptr)
     return nil;
 
   layout = (const UCKeyboardLayout*)CFDataGetBytePtr(uchr);
-  if (layout == NULL)
+  if (layout == nullptr)
     return nil;
 
   UInt32 dead_state;
diff --git a/vncviewer/fltk/Fl_Monitor_Arrangement.cxx b/vncviewer/fltk/Fl_Monitor_Arrangement.cxx
index 7c72ff68f..02011e1fc 100644
--- a/vncviewer/fltk/Fl_Monitor_Arrangement.cxx
+++ b/vncviewer/fltk/Fl_Monitor_Arrangement.cxx
@@ -379,7 +379,7 @@ std::string Fl_Monitor_Arrangement::get_monitor_name(int m)
 
   Fl::screen_xywh(x, y, w, h, m);
 
-  EnumDisplayMonitors(NULL, NULL, EnumDisplayMonitorsCallback,
+  EnumDisplayMonitors(nullptr, nullptr, EnumDisplayMonitorsCallback,
                       (LPARAM)&sys_monitors);
 
   for (iter = sys_monitors.begin(); iter != sys_monitors.end(); ++iter) {
@@ -441,11 +441,11 @@ std::string Fl_Monitor_Arrangement::get_monitor_name(int m)
 
   info = IODisplayCreateInfoDictionary(CGDisplayIOServicePort(displayID),
                                        kIODisplayOnlyPreferredName);
-  if (info == NULL)
+  if (info == nullptr)
     return "";
 
   dict = (CFDictionaryRef) CFDictionaryGetValue(info, CFSTR(kDisplayProductName));
-  if (dict == NULL) {
+  if (dict == nullptr) {
     CFRelease(info);
     return "";
   }
@@ -454,7 +454,7 @@ std::string Fl_Monitor_Arrangement::get_monitor_name(int m)
 
   if (dict_len > 0) {
     CFTypeRef * names = new CFTypeRef[dict_len];
-    CFDictionaryGetKeysAndValues(dict, NULL, (const void **) names);
+    CFDictionaryGetKeysAndValues(dict, nullptr, (const void **) names);
 
     if (names[0]) {
 
@@ -496,7 +496,7 @@ std::string Fl_Monitor_Arrangement::get_monitor_name(int m)
   std::string name;
 
   fl_open_display();
-  assert(fl_display != NULL);
+  assert(fl_display != nullptr);
   Fl::screen_xywh(x, y, w, h, m);
 
   if (!XQueryExtension(fl_display, "RANDR", &xi_major, &ev, &err))
diff --git a/vncviewer/fltk/Fl_Monitor_Arrangement.h b/vncviewer/fltk/Fl_Monitor_Arrangement.h
index c71dd199d..d8bf582b7 100644
--- a/vncviewer/fltk/Fl_Monitor_Arrangement.h
+++ b/vncviewer/fltk/Fl_Monitor_Arrangement.h
@@ -45,7 +45,7 @@ class Fl_Monitor_Arrangement: public Fl_Group {
   int value(std::set<int> indices);
 
 protected:
-  virtual void draw();
+  void draw() override;
 
 private:
   const Fl_Color AVAILABLE_COLOR;
diff --git a/vncviewer/fltk/Fl_Navigation.cxx b/vncviewer/fltk/Fl_Navigation.cxx
index 603c69ce8..d3117aae3 100644
--- a/vncviewer/fltk/Fl_Navigation.cxx
+++ b/vncviewer/fltk/Fl_Navigation.cxx
@@ -72,7 +72,7 @@ Fl_Widget *Fl_Navigation::value()
       return pages->child(i);
   }
 
-  return NULL;
+  return nullptr;
 }
 
 int Fl_Navigation::value(Fl_Widget *newpage)
@@ -145,7 +145,7 @@ void Fl_Navigation::update_labels()
   int i, offset;
 
   labels->clear();
-  labels->resizable(NULL);
+  labels->resizable(nullptr);
 
   if (!pages->children())
     return;
diff --git a/vncviewer/fltk/Fl_Navigation.h b/vncviewer/fltk/Fl_Navigation.h
index 7f5e44acf..44515691f 100644
--- a/vncviewer/fltk/Fl_Navigation.h
+++ b/vncviewer/fltk/Fl_Navigation.h
@@ -38,7 +38,7 @@ class Fl_Navigation: private Fl_Group {
 
   void client_area(int &rx, int &ry, int &rw, int &rh, int lw);
 
-  virtual void draw();
+  void draw() override;
 
   // Delegation to underlying widget
   void begin();
diff --git a/vncviewer/fltk/theme.cxx b/vncviewer/fltk/theme.cxx
index 22e04dc66..2b37fb6ef 100644
--- a/vncviewer/fltk/theme.cxx
+++ b/vncviewer/fltk/theme.cxx
@@ -313,10 +313,10 @@ void init_theme()
   CTFontRef font;
   CFStringRef name;
 
-  font = CTFontCreateUIFontForLanguage(kCTFontSystemFontType, 0.0, NULL);
-  if (font != NULL) {
+  font = CTFontCreateUIFontForLanguage(kCTFontSystemFontType, 0.0, nullptr);
+  if (font != nullptr) {
     name = CTFontCopyFullName(font);
-    if (name != NULL) {
+    if (name != nullptr) {
       CFStringGetCString(name, font_name, sizeof(font_name),
                          kCFStringEncodingUTF8);
 
diff --git a/vncviewer/fltk/util.h b/vncviewer/fltk/util.h
index 877653964..9ce3c7aa4 100644
--- a/vncviewer/fltk/util.h
+++ b/vncviewer/fltk/util.h
@@ -97,7 +97,7 @@ static inline size_t fltk_menu_escape(const char *in, char *out, size_t maxlen)
 /* Helper to add menu entries safely */
 static inline void fltk_menu_add(Fl_Menu_ *menu, const char *text,
                                  int shortcut, Fl_Callback *cb,
-                                 void *data = 0, int flags = 0)
+                                 void *data=nullptr, int flags=0)
 {
     char buffer[1024];
 
diff --git a/vncviewer/gettext.h b/vncviewer/gettext.h
index 768a69952..09473d976 100644
--- a/vncviewer/gettext.h
+++ b/vncviewer/gettext.h
@@ -120,7 +120,7 @@
    pgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
 #else
 # define pgettext(Msgctxt, Msgid) \
-   pgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
+   pgettext_aux (nullptr, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
 #endif
 #define dpgettext(Domainname, Msgctxt, Msgid) \
   pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
@@ -131,7 +131,7 @@
    npgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
 #else
 # define npgettext(Msgctxt, Msgid, MsgidPlural, N) \
-   npgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
+   npgettext_aux (nullptr, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
 #endif
 #define dnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N) \
   npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
@@ -197,7 +197,7 @@ npgettext_aux (const char *domain,
 #endif
 
 #define pgettext_expr(Msgctxt, Msgid) \
-  dcpgettext_expr (NULL, Msgctxt, Msgid, LC_MESSAGES)
+  dcpgettext_expr (nullptr, Msgctxt, Msgid, LC_MESSAGES)
 #define dpgettext_expr(Domainname, Msgctxt, Msgid) \
   dcpgettext_expr (Domainname, Msgctxt, Msgid, LC_MESSAGES)
 
@@ -224,7 +224,7 @@ dcpgettext_expr (const char *domain,
     (msgctxt_len + msgid_len <= sizeof (buf)
      ? buf
      : (char *) malloc (msgctxt_len + msgid_len));
-  if (msg_ctxt_id != NULL)
+  if (msg_ctxt_id != nullptr)
 #endif
     {
       int found_translation;
@@ -244,7 +244,7 @@ dcpgettext_expr (const char *domain,
 }
 
 #define npgettext_expr(Msgctxt, Msgid, MsgidPlural, N) \
-  dcnpgettext_expr (NULL, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES)
+  dcnpgettext_expr (nullptr, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES)
 #define dnpgettext_expr(Domainname, Msgctxt, Msgid, MsgidPlural, N) \
   dcnpgettext_expr (Domainname, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES)
 
@@ -272,7 +272,7 @@ dcnpgettext_expr (const char *domain,
     (msgctxt_len + msgid_len <= sizeof (buf)
      ? buf
      : (char *) malloc (msgctxt_len + msgid_len));
-  if (msg_ctxt_id != NULL)
+  if (msg_ctxt_id != nullptr)
 #endif
     {
       int found_translation;
diff --git a/vncviewer/parameters.cxx b/vncviewer/parameters.cxx
index 15ea4ee80..a03623db7 100644
--- a/vncviewer/parameters.cxx
+++ b/vncviewer/parameters.cxx
@@ -214,7 +214,7 @@ static VoidParameter* readOnlyParameterArray[] = {
 };
 
 // Encoding Table
-static struct {
+static const struct EscapeMap {
   const char first;
   const char second;
 } replaceMap[] = { { '\n', 'n' },
@@ -230,15 +230,15 @@ static bool encodeValue(const char* val, char* dest, size_t destSize) {
     
     // Check for sequences which will need encoding
     normalCharacter = true;
-    for (size_t j = 0; j < sizeof(replaceMap)/sizeof(replaceMap[0]); j++) {
+    for (EscapeMap esc : replaceMap) {
 
-      if (val[i] == replaceMap[j].first) {
+      if (val[i] == esc.first) {
         dest[pos] = '\\';
         pos++;
         if (pos >= destSize)
           return false;
 
-        dest[pos] = replaceMap[j].second;
+        dest[pos] = esc.second;
         normalCharacter = false;
         break;
       }
@@ -269,9 +269,9 @@ static bool decodeValue(const char* val, char* dest, size_t destSize) {
       bool escapedCharacter;
       
       escapedCharacter = false;
-      for (size_t j = 0; j < sizeof(replaceMap)/sizeof(replaceMap[0]); j++) {
-        if (val[i+1] == replaceMap[j].second) {
-          dest[pos] = replaceMap[j].first;
+      for (EscapeMap esc : replaceMap) {
+        if (val[i+1] == esc.second) {
+          dest[pos] = esc.first;
           escapedCharacter = true;
           i++;
           break;
@@ -350,7 +350,7 @@ static bool getKeyString(const char* _name, char* dest, size_t destSize, HKEY* h
 
   value = new WCHAR[destSize];
   valuesize = destSize;
-  LONG res = RegQueryValueExW(*hKey, name, 0, NULL, (LPBYTE)value, &valuesize);
+  LONG res = RegQueryValueExW(*hKey, name, nullptr, nullptr, (LPBYTE)value, &valuesize);
   if (res != ERROR_SUCCESS){
     delete [] value;
     if (res != ERROR_FILE_NOT_FOUND)
@@ -388,7 +388,7 @@ static bool getKeyInt(const char* _name, int* dest, HKEY* hKey) {
   if (size >= buffersize)
     throw Exception(_("The name of the parameter is too large"));
 
-  LONG res = RegQueryValueExW(*hKey, name, 0, NULL, (LPBYTE)&value, &dwordsize);
+  LONG res = RegQueryValueExW(*hKey, name, nullptr, nullptr, (LPBYTE)&value, &dwordsize);
   if (res != ERROR_SUCCESS){
     if (res != ERROR_FILE_NOT_FOUND)
       throw rdr::SystemException("RegQueryValueExW", res);
@@ -420,9 +420,9 @@ static void removeValue(const char* _name, HKEY* hKey) {
 void saveHistoryToRegKey(const vector<string>& serverHistory) {
   HKEY hKey;
   LONG res = RegCreateKeyExW(HKEY_CURRENT_USER,
-                             L"Software\\TigerVNC\\vncviewer\\history", 0, NULL,
-                             REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL,
-                             &hKey, NULL);
+                             L"Software\\TigerVNC\\vncviewer\\history", 0, nullptr,
+                             REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, nullptr,
+                             &hKey, nullptr);
 
   if (res != ERROR_SUCCESS)
     throw rdr::SystemException(_("Failed to create registry key"), res);
@@ -452,9 +452,9 @@ static void saveToReg(const char* servername) {
   HKEY hKey;
     
   LONG res = RegCreateKeyExW(HKEY_CURRENT_USER,
-                             L"Software\\TigerVNC\\vncviewer", 0, NULL,
-                             REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL,
-                             &hKey, NULL);
+                             L"Software\\TigerVNC\\vncviewer", 0, nullptr,
+                             REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, nullptr,
+                             &hKey, nullptr);
   if (res != ERROR_SUCCESS)
     throw rdr::SystemException(_("Failed to create registry key"), res);
 
@@ -468,11 +468,11 @@ static void saveToReg(const char* servername) {
 
   for (size_t i = 0; i < sizeof(parameterArray)/sizeof(VoidParameter*); i++) {
     try {
-      if (dynamic_cast<StringParameter*>(parameterArray[i]) != NULL) {
+      if (dynamic_cast<StringParameter*>(parameterArray[i]) != nullptr) {
         setKeyString(parameterArray[i]->getName(), *(StringParameter*)parameterArray[i], &hKey);
-      } else if (dynamic_cast<IntParameter*>(parameterArray[i]) != NULL) {
+      } else if (dynamic_cast<IntParameter*>(parameterArray[i]) != nullptr) {
         setKeyInt(parameterArray[i]->getName(), (int)*(IntParameter*)parameterArray[i], &hKey);
-      } else if (dynamic_cast<BoolParameter*>(parameterArray[i]) != NULL) {
+      } else if (dynamic_cast<BoolParameter*>(parameterArray[i]) != nullptr) {
         setKeyInt(parameterArray[i]->getName(), (int)*(BoolParameter*)parameterArray[i], &hKey);
       } else {
         throw Exception(_("Unknown parameter type"));
@@ -553,13 +553,13 @@ static void getParametersFromReg(VoidParameter* parameters[],
 
   for (size_t i = 0; i < parameters_len/sizeof(VoidParameter*); i++) {
     try {
-      if (dynamic_cast<StringParameter*>(parameters[i]) != NULL) {
+      if (dynamic_cast<StringParameter*>(parameters[i]) != nullptr) {
         if (getKeyString(parameters[i]->getName(), stringValue, buffersize, hKey))
           parameters[i]->setParam(stringValue);
-      } else if (dynamic_cast<IntParameter*>(parameters[i]) != NULL) {
+      } else if (dynamic_cast<IntParameter*>(parameters[i]) != nullptr) {
         if (getKeyInt(parameters[i]->getName(), &intValue, hKey))
           ((IntParameter*)parameters[i])->setParam(intValue);
-      } else if (dynamic_cast<BoolParameter*>(parameters[i]) != NULL) {
+      } else if (dynamic_cast<BoolParameter*>(parameters[i]) != nullptr) {
         if (getKeyInt(parameters[i]->getName(), &intValue, hKey))
           ((BoolParameter*)parameters[i])->setParam(intValue);
       } else {
@@ -583,7 +583,7 @@ static char* loadFromReg() {
   if (res != ERROR_SUCCESS) {
     if (res == ERROR_FILE_NOT_FOUND) {
       // The key does not exist, defaults will be used.
-      return NULL;
+      return nullptr;
     }
 
     throw rdr::SystemException(_("Failed to open registry key"), res);
@@ -622,7 +622,7 @@ void saveViewerParameters(const char *filename, const char *servername) {
   char encodingBuffer[buffersize];
 
   // Write to the registry or a predefined file if no filename was specified.
-  if(filename == NULL) {
+  if(filename == nullptr) {
 
 #ifdef _WIN32
     saveToReg(servername);
@@ -630,7 +630,7 @@ void saveViewerParameters(const char *filename, const char *servername) {
 #endif
     
     const char* configDir = os::getvncconfigdir();
-    if (configDir == NULL)
+    if (configDir == nullptr)
       throw Exception(_("Could not obtain the config directory path"));
 
     snprintf(filepath, sizeof(filepath), "%s/default.tigervnc", configDir);
@@ -654,24 +654,24 @@ void saveViewerParameters(const char *filename, const char *servername) {
   }
   fprintf(f, "ServerName=%s\n", encodingBuffer);
 
-  for (size_t i = 0; i < sizeof(parameterArray)/sizeof(VoidParameter*); i++) {
-    if (dynamic_cast<StringParameter*>(parameterArray[i]) != NULL) {
-      if (!encodeValue(*(StringParameter*)parameterArray[i],
+  for (VoidParameter* param : parameterArray) {
+    if (dynamic_cast<StringParameter*>(param) != nullptr) {
+      if (!encodeValue(*(StringParameter*)param,
           encodingBuffer, buffersize)) {
         fclose(f);
         throw Exception(_("Failed to save \"%s\": %s"),
-                        parameterArray[i]->getName(),
+                        param->getName(),
                         _("Could not encode parameter"));
       }
-      fprintf(f, "%s=%s\n", ((StringParameter*)parameterArray[i])->getName(), encodingBuffer);
-    } else if (dynamic_cast<IntParameter*>(parameterArray[i]) != NULL) {
-      fprintf(f, "%s=%d\n", ((IntParameter*)parameterArray[i])->getName(), (int)*(IntParameter*)parameterArray[i]);
-    } else if (dynamic_cast<BoolParameter*>(parameterArray[i]) != NULL) {
-      fprintf(f, "%s=%d\n", ((BoolParameter*)parameterArray[i])->getName(), (int)*(BoolParameter*)parameterArray[i]);
+      fprintf(f, "%s=%s\n", ((StringParameter*)param)->getName(), encodingBuffer);
+    } else if (dynamic_cast<IntParameter*>(param) != nullptr) {
+      fprintf(f, "%s=%d\n", ((IntParameter*)param)->getName(), (int)*(IntParameter*)param);
+    } else if (dynamic_cast<BoolParameter*>(param) != nullptr) {
+      fprintf(f, "%s=%d\n", ((BoolParameter*)param)->getName(), (int)*(BoolParameter*)param);
     } else {      
       fclose(f);
       throw Exception(_("Failed to save \"%s\": %s"),
-                      parameterArray[i]->getName(),
+                      param->getName(),
                       _("Unknown parameter type"));
     }
   }
@@ -688,7 +688,7 @@ static bool findAndSetViewerParameterFromValue(
   // Find and set the correct parameter
   for (size_t i = 0; i < parameters_len/sizeof(VoidParameter*); i++) {
 
-    if (dynamic_cast<StringParameter*>(parameters[i]) != NULL) {
+    if (dynamic_cast<StringParameter*>(parameters[i]) != nullptr) {
       if (strcasecmp(line, ((StringParameter*)parameters[i])->getName()) == 0) {
         if(!decodeValue(value, decodingBuffer, sizeof(decodingBuffer)))
           throw Exception(_("Invalid format or too large value"));
@@ -696,13 +696,13 @@ static bool findAndSetViewerParameterFromValue(
         return false;
       }
 
-    } else if (dynamic_cast<IntParameter*>(parameters[i]) != NULL) {
+    } else if (dynamic_cast<IntParameter*>(parameters[i]) != nullptr) {
       if (strcasecmp(line, ((IntParameter*)parameters[i])->getName()) == 0) {
         ((IntParameter*)parameters[i])->setParam(atoi(value));
         return false;
       }
 
-    } else if (dynamic_cast<BoolParameter*>(parameters[i]) != NULL) {
+    } else if (dynamic_cast<BoolParameter*>(parameters[i]) != nullptr) {
       if (strcasecmp(line, ((BoolParameter*)parameters[i])->getName()) == 0) {
         ((BoolParameter*)parameters[i])->setParam(atoi(value));
         return false;
@@ -727,14 +727,14 @@ char* loadViewerParameters(const char *filename) {
   memset(servername, '\0', sizeof(servername));
 
   // Load from the registry or a predefined file if no filename was specified.
-  if(filename == NULL) {
+  if(filename == nullptr) {
 
 #ifdef _WIN32
     return loadFromReg();
 #endif
 
     const char* configDir = os::getvncconfigdir();
-    if (configDir == NULL)
+    if (configDir == nullptr)
       throw Exception(_("Could not obtain the config directory path"));
 
     snprintf(filepath, sizeof(filepath), "%s/default.tigervnc", configDir);
@@ -746,7 +746,7 @@ char* loadViewerParameters(const char *filename) {
   FILE* f = fopen(filepath, "r");
   if (!f) {
     if (!filename)
-      return NULL; // Use defaults.
+      return nullptr; // Use defaults.
     throw Exception(_("Could not open \"%s\": %s"),
                     filepath, strerror(errno));
   }
@@ -797,7 +797,7 @@ char* loadViewerParameters(const char *filename) {
 
     // Find the parameter value
     char *value = strchr(line, '=');
-    if (value == NULL) {
+    if (value == nullptr) {
       vlog.error(_("Failed to read line %d in file %s: %s"),
                  lineNr, filepath, _("Invalid format"));
       continue;
@@ -836,7 +836,8 @@ char* loadViewerParameters(const char *filename) {
       vlog.error(_("Failed to read line %d in file %s: %s"),
                  lineNr, filepath, _("Unknown parameter"));
   }
-  fclose(f); f=0;
-  
+  fclose(f);
+  f = nullptr;
+
   return servername;
 }
diff --git a/vncviewer/parameters.h b/vncviewer/parameters.h
index 1dd9aca2e..df7bc4205 100644
--- a/vncviewer/parameters.h
+++ b/vncviewer/parameters.h
@@ -80,7 +80,7 @@ extern rfb::BoolParameter reconnectOnError;
 extern rfb::StringParameter via;
 #endif
 
-void saveViewerParameters(const char *filename, const char *servername=NULL);
+void saveViewerParameters(const char *filename, const char *servername=nullptr);
 char* loadViewerParameters(const char *filename);
 
 #ifdef _WIN32
diff --git a/vncviewer/touch.cxx b/vncviewer/touch.cxx
index d4f4098af..1efd3e460 100644
--- a/vncviewer/touch.cxx
+++ b/vncviewer/touch.cxx
@@ -103,7 +103,7 @@ static void x11_change_touch_ownership(bool enable)
 
   for (iter = handlers.begin(); iter != handlers.end(); ++iter) {
     curmasks = XIGetSelectedEvents(fl_display, iter->first, &num_masks);
-    if (curmasks == NULL) {
+    if (curmasks == nullptr) {
       if (num_masks == -1)
         vlog.error(_("Unable to get X Input 2 event mask for window 0x%08lx"), iter->first);
       continue;
@@ -267,7 +267,7 @@ void enable_touch()
     vlog.error(_("X Input 2.2 (or newer) is not available. Touch gestures will not be supported."));
 #endif
 
-  Fl::add_system_handler(handleTouchEvent, NULL);
+  Fl::add_system_handler(handleTouchEvent, nullptr);
 }
 
 void disable_touch()
diff --git a/vncviewer/vncviewer.cxx b/vncviewer/vncviewer.cxx
index 366327faf..6ddff9470 100644
--- a/vncviewer/vncviewer.cxx
+++ b/vncviewer/vncviewer.cxx
@@ -86,11 +86,11 @@ using namespace rfb;
 
 char vncServerName[VNCSERVERNAMELEN] = { '\0' };
 
-static const char *argv0 = NULL;
+static const char *argv0 = nullptr;
 
 static bool inMainloop = false;
 static bool exitMainloop = false;
-static char *exitError = NULL;
+static char *exitError = nullptr;
 static bool fatalError = false;
 
 static const char *about_text()
@@ -117,7 +117,7 @@ void abort_vncviewer(const char *error, ...)
 
   // Prioritise the first error we get as that is probably the most
   // relevant one.
-  if (exitError == NULL) {
+  if (exitError == nullptr) {
     va_list ap;
 
     va_start(ap, error);
@@ -130,7 +130,7 @@ void abort_vncviewer(const char *error, ...)
     exitMainloop = true;
   else {
     // We're early in the startup. Assume we can just exit().
-    if (alertOnFatalError && (exitError != NULL))
+    if (alertOnFatalError && (exitError != nullptr))
       fl_alert("%s", exitError);
     exit(EXIT_FAILURE);
   }
@@ -142,7 +142,7 @@ void abort_connection(const char *error, ...)
 
   // Prioritise the first error we get as that is probably the most
   // relevant one.
-  if (exitError == NULL) {
+  if (exitError == nullptr) {
     va_list ap;
 
     va_start(ap, error);
@@ -200,22 +200,22 @@ static void mainloop(const char* vncserver, network::Socket* sock)
     delete cc;
 
     if (fatalError) {
-      assert(exitError != NULL);
+      assert(exitError != nullptr);
       if (alertOnFatalError)
         fl_alert("%s", exitError);
       break;
     }
 
-    if (exitError == NULL)
+    if (exitError == nullptr)
       break;
 
-    if(reconnectOnError && (sock == NULL)) {
+    if(reconnectOnError && (sock == nullptr)) {
       int ret;
       ret = fl_choice(_("%s\n\n"
                         "Attempt to reconnect?"),
-                      NULL, fl_yes, fl_no, exitError);
+                      nullptr, fl_yes, fl_no, exitError);
       free(exitError);
-      exitError = NULL;
+      exitError = nullptr;
       if (ret == 1)
         continue;
       else
@@ -250,7 +250,7 @@ static void new_connection_cb(Fl_Widget* /*widget*/, void* /*data*/)
     return;
 
   argv[0] = argv0;
-  argv[1] = NULL;
+  argv[1] = nullptr;
 
   execvp(argv[0], (char * const *)argv);
 
@@ -273,16 +273,16 @@ static const char* getlocaledir()
   static char localebuf[PATH_MAX];
   char *slash;
 
-  GetModuleFileName(NULL, localebuf, sizeof(localebuf));
+  GetModuleFileName(nullptr, localebuf, sizeof(localebuf));
 
   slash = strrchr(localebuf, '\\');
-  if (slash == NULL)
-    return NULL;
+  if (slash == nullptr)
+    return nullptr;
 
   *slash = '\0';
 
   if ((strlen(localebuf) + strlen("\\locale")) >= sizeof(localebuf))
-    return NULL;
+    return nullptr;
 
   strcat(localebuf, "\\locale");
 
@@ -296,13 +296,13 @@ static const char* getlocaledir()
   static char localebuf[PATH_MAX];
 
   bundle = CFBundleGetMainBundle();
-  if (bundle == NULL)
-    return NULL;
+  if (bundle == nullptr)
+    return nullptr;
 
   localeurl = CFBundleCopyResourceURL(bundle, CFSTR("locale"),
-                                      NULL, NULL);
-  if (localeurl == NULL)
-    return NULL;
+                                      nullptr, nullptr);
+  if (localeurl == nullptr)
+    return nullptr;
 
   localestr = CFURLCopyFileSystemPath(localeurl, kCFURLPOSIXPathStyle);
 
@@ -311,7 +311,7 @@ static const char* getlocaledir()
   ret = CFStringGetCString(localestr, localebuf, sizeof(localebuf),
                            kCFStringEncodingUTF8);
   if (!ret)
-    return NULL;
+    return nullptr;
 
   return localebuf;
 #else
@@ -331,11 +331,13 @@ static void init_fltk()
 #ifdef WIN32
   HICON lg, sm;
 
-  lg = (HICON)LoadImage(GetModuleHandle(NULL), MAKEINTRESOURCE(IDI_ICON),
+  lg = (HICON)LoadImage(GetModuleHandle(nullptr),
+                        MAKEINTRESOURCE(IDI_ICON),
                         IMAGE_ICON, GetSystemMetrics(SM_CXICON),
                         GetSystemMetrics(SM_CYICON),
                         LR_DEFAULTCOLOR | LR_SHARED);
-  sm = (HICON)LoadImage(GetModuleHandle(NULL), MAKEINTRESOURCE(IDI_ICON),
+  sm = (HICON)LoadImage(GetModuleHandle(nullptr),
+                        MAKEINTRESOURCE(IDI_ICON),
                         IMAGE_ICON, GetSystemMetrics(SM_CXSMICON),
                         GetSystemMetrics(SM_CYSMICON),
                         LR_DEFAULTCOLOR | LR_SHARED);
@@ -350,12 +352,12 @@ static void init_fltk()
   count = 0;
 
   // FIXME: Follow icon theme specification
-  for (size_t i = 0;i < sizeof(icon_sizes)/sizeof(icon_sizes[0]);i++) {
+  for (int icon_size : icon_sizes) {
       char icon_path[PATH_MAX];
       bool exists;
 
       sprintf(icon_path, "%s/icons/hicolor/%dx%d/apps/tigervnc.png",
-              CMAKE_INSTALL_FULL_DATADIR, icon_sizes[i], icon_sizes[i]);
+              CMAKE_INSTALL_FULL_DATADIR, icon_size, icon_size);
 
       struct stat st;
       if (stat(icon_path, &st) != 0)
@@ -412,7 +414,7 @@ static void init_fltk()
   Fl_Mac_App_Menu::hide_others = _("Hide Others");
   Fl_Mac_App_Menu::show = _("Show All");
 
-  fl_mac_set_about(about_callback, NULL);
+  fl_mac_set_about(about_callback, nullptr);
 
   Fl_Sys_Menu_Bar *menubar;
   char buffer[1024];
@@ -421,7 +423,7 @@ static void init_fltk()
   // which means we cannot use our generic Fl_Menu_ helpers.
   if (fltk_menu_escape(p_("SysMenu|", "&File"),
                        buffer, sizeof(buffer)) < sizeof(buffer))
-      menubar->add(buffer, 0, 0, 0, FL_SUBMENU);
+      menubar->add(buffer, 0, nullptr, nullptr, FL_SUBMENU);
   if (fltk_menu_escape(p_("SysMenu|File|", "&New Connection"),
                        buffer, sizeof(buffer)) < sizeof(buffer))
       menubar->insert(1, buffer, FL_COMMAND | 'n', new_connection_cb);
@@ -432,7 +434,7 @@ static void usage(const char *programName)
 {
 #ifdef WIN32
   // If we don't have a console then we need to create one for output
-  if (GetConsoleWindow() == NULL) {
+  if (GetConsoleWindow() == nullptr) {
     HANDLE handle;
     int fd;
 
@@ -485,17 +487,17 @@ static void usage(const char *programName)
 }
 
 static void
-potentiallyLoadConfigurationFile(char *vncServerName)
+potentiallyLoadConfigurationFile(const char *filename)
 {
-  const bool hasPathSeparator = (strchr(vncServerName, '/') != NULL ||
-                                 (strchr(vncServerName, '\\')) != NULL);
+  const bool hasPathSeparator = (strchr(filename, '/') != nullptr ||
+                                 (strchr(filename, '\\')) != nullptr);
 
   if (hasPathSeparator) {
 #ifndef WIN32
     struct stat sb;
 
     // This might be a UNIX socket, we need to check
-    if (stat(vncServerName, &sb) == -1) {
+    if (stat(filename, &sb) == -1) {
       // Some access problem; let loadViewerParameters() deal with it...
     } else {
       if ((sb.st_mode & S_IFMT) == S_IFSOCK)
@@ -505,7 +507,7 @@ potentiallyLoadConfigurationFile(char *vncServerName)
 
     try {
       const char* newServerName;
-      newServerName = loadViewerParameters(vncServerName);
+      newServerName = loadViewerParameters(filename);
       // This might be empty, but we still need to clear it so we
       // don't try to connect to the filename
       strncpy(vncServerName, newServerName, VNCSERVERNAMELEN-1);
@@ -534,7 +536,7 @@ interpretViaParam(char *remoteHost, int *remotePort, int localPort)
 {
   const int SERVER_PORT_OFFSET = 5900;
   char *pos = strchr(vncServerName, ':');
-  if (pos == NULL)
+  if (pos == nullptr)
     *remotePort = SERVER_PORT_OFFSET;
   else {
     int portOffset = SERVER_PORT_OFFSET;
@@ -580,7 +582,7 @@ createTunnel(const char *gatewayHost, const char *remoteHost,
     cmd = "/usr/bin/ssh -f -L \"$L\":\"$H\":\"$R\" \"$G\" sleep 20";
   /* Compatibility with TigerVNC's method. */
   cmd2 = strdup(cmd);
-  while ((percent = strchr(cmd2, '%')) != NULL)
+  while ((percent = strchr(cmd2, '%')) != nullptr)
     *percent = '$';
   system(cmd2);
   free(cmd2);
@@ -612,7 +614,7 @@ int main(int argc, char** argv)
   setlocale(LC_ALL, "");
 
   localedir = getlocaledir();
-  if (localedir == NULL)
+  if (localedir == nullptr)
     fprintf(stderr, "Failed to determine locale directory\n");
   else
     bindtextdomain(PACKAGE_NAME, localedir);
@@ -647,8 +649,8 @@ int main(int argc, char** argv)
   char defaultServerName[VNCSERVERNAMELEN] = "";
   try {
     const char* configServerName;
-    configServerName = loadViewerParameters(NULL);
-    if (configServerName != NULL) {
+    configServerName = loadViewerParameters(nullptr);
+    if (configServerName != nullptr) {
       strncpy(defaultServerName, configServerName, VNCSERVERNAMELEN-1);
       defaultServerName[VNCSERVERNAMELEN-1] = '\0';
     }
@@ -662,8 +664,8 @@ int main(int argc, char** argv)
         VoidParameter *param;
 
         param = Configuration::getParam(&argv[i][1]);
-        if ((param != NULL) &&
-            (dynamic_cast<BoolParameter*>(param) != NULL)) {
+        if ((param != nullptr) &&
+            (dynamic_cast<BoolParameter*>(param) != nullptr)) {
           if ((strcasecmp(argv[i+1], "0") == 0) ||
               (strcasecmp(argv[i+1], "1") == 0) ||
               (strcasecmp(argv[i+1], "true") == 0) ||
@@ -703,7 +705,7 @@ int main(int argc, char** argv)
     Fl::display(display);
   }
   fl_open_display();
-  XkbSetDetectableAutoRepeat(fl_display, True, NULL);
+  XkbSetDetectableAutoRepeat(fl_display, True, nullptr);
 #endif
 
   init_fltk();
@@ -717,11 +719,11 @@ int main(int argc, char** argv)
   char *confdir = strdup(os::getvncconfigdir());
 #ifndef WIN32
   char *dotdir = strrchr(confdir, '.');
-  if (dotdir != NULL && strcmp(dotdir, ".vnc") == 0)
+  if (dotdir != nullptr && strcmp(dotdir, ".vnc") == 0)
     vlog.info(_("~/.vnc is deprecated, please consult 'man vncviewer' for paths to migrate to."));
 #else
   char *vncdir = strrchr(confdir, '\\');
-  if (vncdir != NULL && strcmp(vncdir, "vnc") == 0)
+  if (vncdir != nullptr && strcmp(vncdir, "vnc") == 0)
     vlog.info(_("%%APPDATA%%\\vnc is deprecated, please switch to the %%APPDATA%%\\TigerVNC location."));
 #endif
 
@@ -745,7 +747,7 @@ int main(int argc, char** argv)
   CSecurity::msg = &dlg;
 #endif
 
-  Socket *sock = NULL;
+  Socket *sock = nullptr;
 
 #ifndef WIN32
   /* Specifying -via and -listen together is nonsense */
@@ -765,22 +767,20 @@ int main(int argc, char** argv)
       if (isdigit(vncServerName[0]))
         port = atoi(vncServerName);
 
-      createTcpListeners(&listeners, 0, port);
+      createTcpListeners(&listeners, nullptr, port);
       if (listeners.empty())
         throw Exception(_("Unable to listen for incoming connections"));
 
       vlog.info(_("Listening on port %d"), port);
 
       /* Wait for a connection */
-      while (sock == NULL) {
+      while (sock == nullptr) {
         fd_set rfds;
         FD_ZERO(&rfds);
-        for (std::list<SocketListener*>::iterator i = listeners.begin();
-             i != listeners.end();
-             i++)
-          FD_SET((*i)->getFd(), &rfds);
+        for (SocketListener* listener : listeners)
+          FD_SET(listener->getFd(), &rfds);
 
-        int n = select(FD_SETSIZE, &rfds, 0, 0, 0);
+        int n = select(FD_SETSIZE, &rfds, nullptr, nullptr, nullptr);
         if (n < 0) {
           if (errno == EINTR) {
             vlog.debug("Interrupted select() system call");
@@ -790,11 +790,9 @@ int main(int argc, char** argv)
           }
         }
 
-        for (std::list<SocketListener*>::iterator i = listeners.begin ();
-             i != listeners.end();
-             i++)
-          if (FD_ISSET((*i)->getFd(), &rfds)) {
-            sock = (*i)->accept();
+        for (SocketListener* listener : listeners)
+          if (FD_ISSET(listener->getFd(), &rfds)) {
+            sock = listener->accept();
             if (sock)
               /* Got a connection */
               break;
diff --git a/win/rfb_win32/AboutDialog.cxx b/win/rfb_win32/AboutDialog.cxx
index a48a1ea7a..a41ceefd7 100644
--- a/win/rfb_win32/AboutDialog.cxx
+++ b/win/rfb_win32/AboutDialog.cxx
@@ -32,7 +32,7 @@ static LogWriter vlog("AboutDialog");
 AboutDialog AboutDialog::instance;
 
 
-AboutDialog::AboutDialog() : Dialog(GetModuleHandle(0)) {
+AboutDialog::AboutDialog() : Dialog(GetModuleHandle(nullptr)) {
 }
 
 bool AboutDialog::showDialog() {
diff --git a/win/rfb_win32/AboutDialog.h b/win/rfb_win32/AboutDialog.h
index 705d6b3c4..00cf0d423 100644
--- a/win/rfb_win32/AboutDialog.h
+++ b/win/rfb_win32/AboutDialog.h
@@ -33,7 +33,7 @@ namespace rfb {
     public:
       AboutDialog();
       virtual bool showDialog();
-      virtual void initDialog();
+      void initDialog() override;
 
       static AboutDialog instance;
 
diff --git a/win/rfb_win32/CleanDesktop.cxx b/win/rfb_win32/CleanDesktop.cxx
index e69acd7f4..d2d6d2d1c 100644
--- a/win/rfb_win32/CleanDesktop.cxx
+++ b/win/rfb_win32/CleanDesktop.cxx
@@ -40,9 +40,9 @@ static LogWriter vlog("CleanDesktop");
 
 
 struct ActiveDesktop {
-  ActiveDesktop() : handle(0) {
+  ActiveDesktop() : handle(nullptr) {
     // - Contact Active Desktop
-    HRESULT result = CoCreateInstance(CLSID_ActiveDesktop, NULL, CLSCTX_INPROC_SERVER,
+    HRESULT result = CoCreateInstance(CLSID_ActiveDesktop, nullptr, CLSCTX_INPROC_SERVER,
                                       IID_IActiveDesktop, (PVOID*)&handle);
     if (result != S_OK)
       throw rdr::SystemException("failed to contact Active Desktop", result);
@@ -153,7 +153,7 @@ DWORD SysParamsInfo(UINT action, UINT param, PVOID ptr, UINT ini) {
 CleanDesktop::CleanDesktop() : restoreActiveDesktop(false),
                                restoreWallpaper(false),
                                restoreEffects(false) {
-  CoInitialize(0);
+  CoInitialize(nullptr);
 }
 
 CleanDesktop::~CleanDesktop() {
@@ -207,7 +207,7 @@ void CleanDesktop::enableWallpaper() {
       vlog.debug("restore desktop wallpaper");
 
       // -=- Then restore the standard wallpaper if required
-	    SysParamsInfo(SPI_SETDESKWALLPAPER, 0, NULL, SPIF_SENDCHANGE);
+	    SysParamsInfo(SPI_SETDESKWALLPAPER, 0, nullptr, SPIF_SENDCHANGE);
       restoreWallpaper = false;
     }
 
@@ -223,20 +223,20 @@ void CleanDesktop::disableEffects() {
 
     vlog.debug("disable desktop effects");
 
-    SysParamsInfo(SPI_SETFONTSMOOTHING, FALSE, 0, SPIF_SENDCHANGE);
+    SysParamsInfo(SPI_SETFONTSMOOTHING, FALSE, nullptr, SPIF_SENDCHANGE);
     if (SysParamsInfo(SPI_GETUIEFFECTS, 0, &uiEffects, 0) == ERROR_CALL_NOT_IMPLEMENTED) {
       SysParamsInfo(SPI_GETCOMBOBOXANIMATION, 0, &comboBoxAnim, 0);
       SysParamsInfo(SPI_GETGRADIENTCAPTIONS, 0, &gradientCaptions, 0);
       SysParamsInfo(SPI_GETHOTTRACKING, 0, &hotTracking, 0);
       SysParamsInfo(SPI_GETLISTBOXSMOOTHSCROLLING, 0, &listBoxSmoothScroll, 0);
       SysParamsInfo(SPI_GETMENUANIMATION, 0, &menuAnim, 0);
-      SysParamsInfo(SPI_SETCOMBOBOXANIMATION, 0, FALSE, SPIF_SENDCHANGE);
-      SysParamsInfo(SPI_SETGRADIENTCAPTIONS, 0, FALSE, SPIF_SENDCHANGE);
-      SysParamsInfo(SPI_SETHOTTRACKING, 0, FALSE, SPIF_SENDCHANGE);
-      SysParamsInfo(SPI_SETLISTBOXSMOOTHSCROLLING, 0, FALSE, SPIF_SENDCHANGE);
-      SysParamsInfo(SPI_SETMENUANIMATION, 0, FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETCOMBOBOXANIMATION, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETGRADIENTCAPTIONS, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETHOTTRACKING, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETLISTBOXSMOOTHSCROLLING, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETMENUANIMATION, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
     } else {
-      SysParamsInfo(SPI_SETUIEFFECTS, 0, FALSE, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETUIEFFECTS, 0, (PVOID)FALSE, SPIF_SENDCHANGE);
 
       // We *always* restore UI effects overall, since there is no Windows GUI to do it
       uiEffects = TRUE;
@@ -257,7 +257,7 @@ void CleanDesktop::enableEffects() {
 
       RegKey desktopCfg;
       desktopCfg.openKey(HKEY_CURRENT_USER, "Control Panel\\Desktop");
-      SysParamsInfo(SPI_SETFONTSMOOTHING, desktopCfg.getInt("FontSmoothing", 0) != 0, 0, SPIF_SENDCHANGE);
+      SysParamsInfo(SPI_SETFONTSMOOTHING, desktopCfg.getInt("FontSmoothing", 0) != 0, nullptr, SPIF_SENDCHANGE);
       if (SysParamsInfo(SPI_SETUIEFFECTS, 0, (void*)(intptr_t)uiEffects, SPIF_SENDCHANGE) == ERROR_CALL_NOT_IMPLEMENTED) {
         SysParamsInfo(SPI_SETCOMBOBOXANIMATION, 0, (void*)(intptr_t)comboBoxAnim, SPIF_SENDCHANGE);
         SysParamsInfo(SPI_SETGRADIENTCAPTIONS, 0, (void*)(intptr_t)gradientCaptions, SPIF_SENDCHANGE);
diff --git a/win/rfb_win32/Clipboard.cxx b/win/rfb_win32/Clipboard.cxx
index d90d0b7a3..79115893d 100644
--- a/win/rfb_win32/Clipboard.cxx
+++ b/win/rfb_win32/Clipboard.cxx
@@ -39,7 +39,7 @@ static LogWriter vlog("Clipboard");
 //
 
 Clipboard::Clipboard()
-  : MsgWindow("Clipboard"), notifier(0), next_window(0) {
+  : MsgWindow("Clipboard"), notifier(nullptr), next_window(nullptr) {
   next_window = SetClipboardViewer(getHandle());
   vlog.debug("registered clipboard handler");
 }
@@ -58,7 +58,7 @@ Clipboard::processMessage(UINT msg, WPARAM wParam, LPARAM lParam) {
                (long long)wParam, (long long)lParam);
     if ((HWND) wParam == next_window)
       next_window = (HWND) lParam;
-    else if (next_window != 0)
+    else if (next_window != nullptr)
       SendMessage(next_window, msg, wParam, lParam);
     else
       vlog.error("bad clipboard chain change!");
@@ -72,7 +72,7 @@ Clipboard::processMessage(UINT msg, WPARAM wParam, LPARAM lParam) {
       } else {
         vlog.debug("local clipboard changed by %p", owner);
 
-        if (notifier == NULL)
+        if (notifier == nullptr)
           vlog.debug("no clipboard notifier registered");
         else
           notifier->notifyClipboardChanged(IsClipboardFormatAvailable(CF_UNICODETEXT));
@@ -94,19 +94,19 @@ Clipboard::getClipText() {
 
   // Open the clipboard
   if (!OpenClipboard(getHandle()))
-    return NULL;
+    return nullptr;
 
   // Get the clipboard data
   cliphandle = GetClipboardData(CF_UNICODETEXT);
   if (!cliphandle) {
     CloseClipboard();
-    return NULL;
+    return nullptr;
   }
 
   clipdata = (wchar_t*) GlobalLock(cliphandle);
   if (!clipdata) {
     CloseClipboard();
-    return NULL;
+    return nullptr;
   }
 
   // Convert it to UTF-8
@@ -121,7 +121,7 @@ Clipboard::getClipText() {
 
 void
 Clipboard::setClipText(const char* text) {
-  HANDLE clip_handle = 0;
+  HANDLE clip_handle = nullptr;
 
   try {
 
@@ -147,7 +147,7 @@ Clipboard::setClipText(const char* text) {
     // - Set the new clipboard data
     if (!SetClipboardData(CF_UNICODETEXT, clip_handle))
       throw rdr::SystemException("unable to set Win32 clipboard", GetLastError());
-    clip_handle = 0;
+    clip_handle = nullptr;
 
     vlog.debug("set clipboard");
   } catch (rdr::Exception& e) {
diff --git a/win/rfb_win32/Clipboard.h b/win/rfb_win32/Clipboard.h
index 588f10862..b66aa5a4f 100644
--- a/win/rfb_win32/Clipboard.h
+++ b/win/rfb_win32/Clipboard.h
@@ -57,7 +57,7 @@ namespace rfb {
 
     protected:
       // - Internal MsgWindow callback
-      virtual LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam);
+      LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) override;
 
       Notifier* notifier;
       HWND next_window;
diff --git a/win/rfb_win32/DIBSectionBuffer.cxx b/win/rfb_win32/DIBSectionBuffer.cxx
index 632c0a4c2..aa03315cc 100644
--- a/win/rfb_win32/DIBSectionBuffer.cxx
+++ b/win/rfb_win32/DIBSectionBuffer.cxx
@@ -33,11 +33,11 @@ static LogWriter vlog("DIBSectionBuffer");
 
 
 DIBSectionBuffer::DIBSectionBuffer(HWND window_)
-  : bitmap(0), window(window_), device(0) {
+  : bitmap(nullptr), window(window_), device(nullptr) {
 }
 
 DIBSectionBuffer::DIBSectionBuffer(HDC device_)
-  : bitmap(0), window(0), device(device_) {
+  : bitmap(nullptr), window(nullptr), device(device_) {
 }
 
 DIBSectionBuffer::~DIBSectionBuffer() {
@@ -52,8 +52,8 @@ inline void initMaxAndShift(DWORD mask, int* max, int* shift) {
 }
 
 void DIBSectionBuffer::initBuffer(const PixelFormat& pf, int w, int h) {
-  HBITMAP new_bitmap = 0;
-  uint8_t* new_data = 0;
+  HBITMAP new_bitmap = nullptr;
+  uint8_t* new_data = nullptr;
 
   if (!pf.trueColour)
     throw rfb::Exception("palette format not supported");
@@ -78,10 +78,10 @@ void DIBSectionBuffer::initBuffer(const PixelFormat& pf, int w, int h) {
     // Create a DIBSection to draw into
     if (device)
       new_bitmap = ::CreateDIBSection(device, (BITMAPINFO*)&bi.bmiHeader, iUsage,
-                                      (void**)&new_data, NULL, 0);
+                                      (void**)&new_data, nullptr, 0);
     else
       new_bitmap = ::CreateDIBSection(WindowDC(window), (BITMAPINFO*)&bi.bmiHeader, iUsage,
-                                      (void**)&new_data, NULL, 0);
+                                      (void**)&new_data, nullptr, 0);
 
     if (!new_bitmap) {
       int err = GetLastError();
@@ -112,8 +112,8 @@ void DIBSectionBuffer::initBuffer(const PixelFormat& pf, int w, int h) {
   if (bitmap) {
     // Delete the old bitmap
     DeleteObject(bitmap);
-    bitmap = 0;
-    setBuffer(0, 0, NULL, 0);
+    bitmap = nullptr;
+    setBuffer(0, 0, nullptr, 0);
   }
 
   if (new_bitmap) {
diff --git a/win/rfb_win32/DeviceContext.cxx b/win/rfb_win32/DeviceContext.cxx
index e59672f5e..1efc3a599 100644
--- a/win/rfb_win32/DeviceContext.cxx
+++ b/win/rfb_win32/DeviceContext.cxx
@@ -50,10 +50,10 @@ PixelFormat DeviceContext::getPF(HDC dc) {
   memset(&bi, 0, sizeof(bi));
   bi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
   bi.bmiHeader.biBitCount = 0;
-  if (!::GetDIBits(dc, bitmap, 0, 1, NULL, (BITMAPINFO*)&bi, DIB_RGB_COLORS)) {
+  if (!::GetDIBits(dc, bitmap, 0, 1, nullptr, (BITMAPINFO*)&bi, DIB_RGB_COLORS)) {
     throw rdr::SystemException("unable to determine device pixel format", GetLastError());
   }
-  if (!::GetDIBits(dc, bitmap, 0, 1, NULL, (BITMAPINFO*)&bi, DIB_RGB_COLORS)) {
+  if (!::GetDIBits(dc, bitmap, 0, 1, nullptr, (BITMAPINFO*)&bi, DIB_RGB_COLORS)) {
     throw rdr::SystemException("unable to determine pixel shifts/palette", GetLastError());
   }
 
@@ -157,7 +157,7 @@ Rect DeviceContext::getClipBox(HDC dc) {
 
 
 DeviceDC::DeviceDC(const char* deviceName) {
-  dc = ::CreateDC("DISPLAY", deviceName, NULL, NULL);
+  dc = ::CreateDC("DISPLAY", deviceName, nullptr, nullptr);
   if (!dc)
     throw rdr::SystemException("failed to create DeviceDC", GetLastError());
 }
diff --git a/win/rfb_win32/DeviceContext.h b/win/rfb_win32/DeviceContext.h
index 0664684bf..7e89723c7 100644
--- a/win/rfb_win32/DeviceContext.h
+++ b/win/rfb_win32/DeviceContext.h
@@ -35,7 +35,7 @@ namespace rfb {
     // and the pixel format, and access to the HDC itself.
     class DeviceContext {
     public:
-      DeviceContext() : dc(0) {}
+      DeviceContext() : dc(nullptr) {}
       virtual ~DeviceContext() {}
       operator HDC() const {return dc;}
       PixelFormat getPF() const;
diff --git a/win/rfb_win32/DeviceFrameBuffer.cxx b/win/rfb_win32/DeviceFrameBuffer.cxx
index 5d866de81..bba1dbdb8 100644
--- a/win/rfb_win32/DeviceFrameBuffer.cxx
+++ b/win/rfb_win32/DeviceFrameBuffer.cxx
@@ -122,8 +122,8 @@ void DeviceFrameBuffer::setCursor(HCURSOR hCursor, VNCServer* server)
 {
   // - If hCursor is null then there is no cursor - clear the old one
 
-  if (hCursor == 0) {
-    server->setCursor(0, 0, Point(), NULL);
+  if (hCursor == nullptr) {
+    server->setCursor(0, 0, Point(), nullptr);
     return;
   }
 
@@ -223,19 +223,19 @@ void DeviceFrameBuffer::setCursor(HCURSOR hCursor, VNCServer* server)
       uint8_t* rwbuffer = buffer.data();
       for (int y = 0; y < height; y++) {
         for (int x = 0; x < width; x++) {
-          int byte = y * maskInfo.bmWidthBytes + x / 8;
+          int byte_ = y * maskInfo.bmWidthBytes + x / 8;
           int bit = 7 - x % 8;
 
-          if (!(andMask[byte] & (1 << bit))) {
+          if (!(andMask[byte_] & (1 << bit))) {
             // Valid pixel, so make it opaque
             rwbuffer[3] = 0xff;
 
             // Black or white?
-            if (xorMask[byte] & (1 << bit))
+            if (xorMask[byte_] & (1 << bit))
               rwbuffer[0] = rwbuffer[1] = rwbuffer[2] = 0xff;
             else
               rwbuffer[0] = rwbuffer[1] = rwbuffer[2] = 0;
-          } else if (xorMask[byte] & (1 << bit)) {
+          } else if (xorMask[byte_] & (1 << bit)) {
             // Replace any XORed pixels with black, because RFB doesn't support
             // XORing of cursors.  XORing is used for the I-beam cursor, which is most
             // often used over a white background, but also sometimes over a black
diff --git a/win/rfb_win32/DeviceFrameBuffer.h b/win/rfb_win32/DeviceFrameBuffer.h
index c8715724a..e9f06cb02 100644
--- a/win/rfb_win32/DeviceFrameBuffer.h
+++ b/win/rfb_win32/DeviceFrameBuffer.h
@@ -69,7 +69,7 @@ namespace rfb {
       // - FrameBuffer overrides
 
       virtual void grabRect(const Rect &rect);
-      virtual void grabRegion(const Region &region);
+      void grabRegion(const Region &region) override;
 
       // - DeviceFrameBuffer specific methods
 
diff --git a/win/rfb_win32/Dialog.cxx b/win/rfb_win32/Dialog.cxx
index 8e2c1ee86..432439ce8 100644
--- a/win/rfb_win32/Dialog.cxx
+++ b/win/rfb_win32/Dialog.cxx
@@ -48,7 +48,7 @@ static LogWriter plog("PropSheet");
 
 
 Dialog::Dialog(HINSTANCE inst_)
-: inst(inst_), handle(0), alreadyShowing(false)
+: inst(inst_), handle(nullptr), alreadyShowing(false)
 {
 }
 
@@ -60,7 +60,7 @@ Dialog::~Dialog()
 bool Dialog::showDialog(const char* resource, HWND owner)
 {
   if (alreadyShowing) return false;
-  handle = 0;
+  handle = nullptr;
   alreadyShowing = true;
   INT_PTR result = DialogBoxParam(inst, resource, owner,
                                   staticDialogProc, (LPARAM)this);
@@ -151,14 +151,14 @@ BOOL Dialog::dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
 }
 
 
-PropSheetPage::PropSheetPage(HINSTANCE inst, const char* id) : Dialog(inst), propSheet(0) {
+PropSheetPage::PropSheetPage(HINSTANCE inst_, const char* id) : Dialog(inst_), propSheet(nullptr) {
   page.dwSize = sizeof(page);
   page.dwFlags = 0; // PSP_USECALLBACK;
   page.hInstance = inst;
   page.pszTemplate = id;
   page.pfnDlgProc = staticPageProc;
   page.lParam = (LPARAM)this;
-  page.pfnCallback = 0; // staticPageProc;
+  page.pfnCallback = nullptr; // staticPageProc;
 }
 
 PropSheetPage::~PropSheetPage() {
@@ -207,7 +207,7 @@ BOOL PropSheetPage::dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam
 
 
 PropSheet::PropSheet(HINSTANCE inst_, const char* title_, std::list<PropSheetPage*> pages_, HICON icon_)
-: icon(icon_), pages(pages_), inst(inst_), title(title_), handle(0), alreadyShowing(0) {
+: icon(icon_), pages(pages_), inst(inst_), title(title_), handle(nullptr), alreadyShowing(0) {
 }
 
 PropSheet::~PropSheet() {
@@ -241,7 +241,7 @@ static int CALLBACK removeCtxtHelp(HWND /*hwnd*/, UINT message, LPARAM lParam) {
 }
 
 
-bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, bool capture) {
+bool PropSheet::showPropSheet(HWND owner_, bool showApply, bool showCtxtHelp, bool capture) {
   if (alreadyShowing) return false;
   alreadyShowing = true;
   int count = pages.size();
@@ -262,7 +262,7 @@ bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, boo
     header.dwSize = sizeof(PROPSHEETHEADER); // Requires comctl32.dll 4.71 or greater, ie IE 4 or later
     header.dwFlags = PSH_MODELESS | (showApply ? 0 : PSH_NOAPPLYNOW) | (showCtxtHelp ? 0 : PSH_USECALLBACK);
     header.pfnCallback = removeCtxtHelp;
-    header.hwndParent = owner;
+    header.hwndParent = owner_;
     header.hInstance = inst;
     header.pszCaption = title.c_str();
     header.nPages = count;
@@ -274,9 +274,9 @@ bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, boo
     }
 
     handle = (HWND)PropertySheet(&header);
-    if ((handle == 0) || (handle == (HWND)-1))
+    if ((handle == nullptr) || (handle == (HWND)-1))
       throw rdr::SystemException("PropertySheet failed", GetLastError());
-    centerWindow(handle, owner);
+    centerWindow(handle, owner_);
     plog.info("created %p", handle);
 
     (void)capture;
@@ -314,21 +314,21 @@ bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, boo
     } else {
 #endif
       try {
-        if (owner)
-          EnableWindow(owner, FALSE);
+        if (owner_)
+          EnableWindow(owner_, FALSE);
         // Run the PropertySheet
         MSG msg;
-        while (GetMessage(&msg, 0, 0, 0)) {
+        while (GetMessage(&msg, nullptr, 0, 0)) {
           if (!PropSheet_IsDialogMessage(handle, &msg))
             DispatchMessage(&msg);
           if (!PropSheet_GetCurrentPageHwnd(handle))
             break;
         }
-        if (owner)
-          EnableWindow(owner, TRUE);
+        if (owner_)
+          EnableWindow(owner_, TRUE);
       } catch (...) {
-        if (owner)
-          EnableWindow(owner, TRUE);
+        if (owner_)
+          EnableWindow(owner_, TRUE);
         throw;
       }
 #ifdef _DIALOG_CAPTURE
@@ -338,13 +338,13 @@ bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, boo
     plog.info("finished %p", handle);
 
     DestroyWindow(handle);
-    handle = 0;
+    handle = nullptr;
     alreadyShowing = false;
 
     // Clear up the pages' GDI objects
     for (pspi=pages.begin(); pspi!=pages.end(); pspi++)
-      (*pspi)->setPropSheet(0);
-    delete [] hpages; hpages = 0;
+      (*pspi)->setPropSheet(nullptr);
+    delete [] hpages; hpages = nullptr;
 
     return true;
   } catch (rdr::Exception&) {
@@ -352,8 +352,8 @@ bool PropSheet::showPropSheet(HWND owner, bool showApply, bool showCtxtHelp, boo
 
     std::list<PropSheetPage*>::iterator pspi;
     for (pspi=pages.begin(); pspi!=pages.end(); pspi++)
-      (*pspi)->setPropSheet(0);
-    delete [] hpages; hpages = 0;
+      (*pspi)->setPropSheet(nullptr);
+    delete [] hpages; hpages = nullptr;
 
     throw;
   }
diff --git a/win/rfb_win32/Dialog.h b/win/rfb_win32/Dialog.h
index d1a8e8312..69374bb15 100644
--- a/win/rfb_win32/Dialog.h
+++ b/win/rfb_win32/Dialog.h
@@ -52,7 +52,7 @@ namespace rfb {
       // expansion), and owner is an optional window handle - the corresponding
       // window is disabled while the dialog box is displayed.
 
-      bool showDialog(const char* resource, HWND owner=0);
+      bool showDialog(const char* resource, HWND owner=nullptr);
 
       // initDialog() is called upon receipt of the WM_INITDIALOG message.
 
@@ -106,7 +106,7 @@ namespace rfb {
 
     class PropSheet {
     public:
-      PropSheet(HINSTANCE inst, const char* title, std::list<PropSheetPage*> pages, HICON icon=0);
+      PropSheet(HINSTANCE inst, const char* title, std::list<PropSheetPage*> pages, HICON icon=nullptr);
       virtual ~PropSheet();
 
       // Display the PropertySheet
@@ -148,7 +148,7 @@ namespace rfb {
     protected:
       void setPropSheet(PropSheet* ps) {propSheet = ps;};
       static INT_PTR CALLBACK staticPageProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
-      virtual BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
+      BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam) override;
       PROPSHEETPAGE page;
       PropSheet* propSheet;
     };
diff --git a/win/rfb_win32/Handle.h b/win/rfb_win32/Handle.h
index d3baa5804..6b88a8f10 100644
--- a/win/rfb_win32/Handle.h
+++ b/win/rfb_win32/Handle.h
@@ -29,7 +29,7 @@ namespace rfb {
 
     class Handle {
     public:
-      Handle(HANDLE h_=0) : h(h_) {}
+      Handle(HANDLE h_=nullptr) : h(h_) {}
       ~Handle() {
         if (h) CloseHandle(h);
       }
diff --git a/win/rfb_win32/IntervalTimer.h b/win/rfb_win32/IntervalTimer.h
index deb2abc63..89cd93122 100644
--- a/win/rfb_win32/IntervalTimer.h
+++ b/win/rfb_win32/IntervalTimer.h
@@ -31,7 +31,7 @@ namespace rfb {
       IntervalTimer(HWND hwnd_, int id_)
         : hwnd(hwnd_), id(id_), active(false) {
       }
-      IntervalTimer() : hwnd(0), id(0), active(false) {
+      IntervalTimer() : hwnd(nullptr), id(0), active(false) {
       }
       ~IntervalTimer() {
         stop();
@@ -40,7 +40,7 @@ namespace rfb {
       void start(int interval_) {
         if (!active || interval_ != interval) {
           interval = interval_;
-          if (!SetTimer(hwnd, id, interval, 0))
+          if (!SetTimer(hwnd, id, interval, nullptr))
             throw rdr::SystemException("SetTimer", GetLastError());
           active = true;
         }
diff --git a/win/rfb_win32/LaunchProcess.cxx b/win/rfb_win32/LaunchProcess.cxx
index 5e702a009..92a682737 100644
--- a/win/rfb_win32/LaunchProcess.cxx
+++ b/win/rfb_win32/LaunchProcess.cxx
@@ -85,11 +85,15 @@ void LaunchProcess::start(HANDLE userToken, bool createConsole) {
   BOOL success;
   if (userToken != INVALID_HANDLE_VALUE)
     success = CreateProcessAsUser(userToken, exePath.c_str(),
-                                  (char*)cmdLine.c_str(), 0, 0, FALSE,
-                                  flags, 0, 0, &sinfo, &procInfo);
+                                  (char*)cmdLine.c_str(),
+                                  nullptr, nullptr, FALSE,
+                                  flags, nullptr, nullptr,
+                                  &sinfo, &procInfo);
   else
-    success = CreateProcess(exePath.c_str(), (char*)cmdLine.c_str(), 0,
-                            0, FALSE, flags, 0, 0, &sinfo, &procInfo);
+    success = CreateProcess(exePath.c_str(), (char*)cmdLine.c_str(),
+                            nullptr, nullptr, FALSE,
+                            flags, nullptr, nullptr,
+                            &sinfo, &procInfo);
   if (!success)
     throw rdr::SystemException("unable to launch process", GetLastError());
 
diff --git a/win/rfb_win32/LocalMem.h b/win/rfb_win32/LocalMem.h
index a99d32410..239e8c1f5 100644
--- a/win/rfb_win32/LocalMem.h
+++ b/win/rfb_win32/LocalMem.h
@@ -34,7 +34,7 @@ namespace rfb {
       ~LocalMem() {LocalFree(ptr);}
       operator void*() {return ptr;}
       void* takePtr() {
-        void* t = ptr; ptr = 0; return t;
+        void* t = ptr; ptr = nullptr; return t;
       }
       void* ptr;
     };
diff --git a/win/rfb_win32/ModuleFileName.h b/win/rfb_win32/ModuleFileName.h
index 9a06f50da..c95ad1f1a 100644
--- a/win/rfb_win32/ModuleFileName.h
+++ b/win/rfb_win32/ModuleFileName.h
@@ -25,9 +25,9 @@ namespace rfb {
   namespace win32 {
 
     struct ModuleFileName {
-      ModuleFileName(HMODULE module=0) {
+      ModuleFileName(HMODULE module=nullptr) {
         if (!module)
-          module = GetModuleHandle(0);
+          module = GetModuleHandle(nullptr);
         if (!GetModuleFileName(module, buf, MAX_PATH))
           buf[0] = 0;
       }
diff --git a/win/rfb_win32/MonitorInfo.cxx b/win/rfb_win32/MonitorInfo.cxx
index c7217c19c..fb4fb3a9b 100644
--- a/win/rfb_win32/MonitorInfo.cxx
+++ b/win/rfb_win32/MonitorInfo.cxx
@@ -96,7 +96,7 @@ MonitorInfo::MonitorInfo(const char* devName) {
   monitorByNameData data;
   data.info = this;
   data.monitorName = devName;
-  EnumDisplayMonitors(0, 0, &monitorByNameEnumProc, (LPARAM)&data);
+  EnumDisplayMonitors(nullptr, nullptr, &monitorByNameEnumProc, (LPARAM)&data);
 }
 
 void MonitorInfo::moveTo(HWND handle) {
@@ -134,7 +134,7 @@ void MonitorInfo::clipTo(HWND handle) {
   RECT r;
   GetWindowRect(handle, &r);
   clipTo(&r);
-  SetWindowPos(handle, 0, r.left, r.top, r.right-r.left, r.bottom-r.top,
+  SetWindowPos(handle, nullptr, r.left, r.top, r.right-r.left, r.bottom-r.top,
                SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOOWNERZORDER);
 }
 
diff --git a/win/rfb_win32/MsgBox.h b/win/rfb_win32/MsgBox.h
index 25d36383a..e831d745f 100644
--- a/win/rfb_win32/MsgBox.h
+++ b/win/rfb_win32/MsgBox.h
@@ -36,7 +36,7 @@ namespace rfb {
 
     // Wrapper around Win32 MessageBox()
     static int MsgBox(HWND parent, const char* msg, UINT flags) {
-      const char* msgType = 0;
+      const char* msgType = nullptr;
       UINT tflags = flags & 0x70;
       if (tflags == MB_ICONHAND)
         msgType = "Error";
diff --git a/win/rfb_win32/MsgWindow.cxx b/win/rfb_win32/MsgWindow.cxx
index 251b2762f..30c9373e9 100644
--- a/win/rfb_win32/MsgWindow.cxx
+++ b/win/rfb_win32/MsgWindow.cxx
@@ -74,11 +74,11 @@ MsgWindowClass::MsgWindowClass() : classAtom(0) {
   wndClass.lpfnWndProc = MsgWindowProc;
   wndClass.cbClsExtra = 0;
   wndClass.cbWndExtra = 0;
-  wndClass.hInstance = instance = GetModuleHandle(0);
-  wndClass.hIcon = 0;
-  wndClass.hCursor = 0;
-  wndClass.hbrBackground = 0;
-  wndClass.lpszMenuName = 0;
+  wndClass.hInstance = instance = GetModuleHandle(nullptr);
+  wndClass.hIcon = nullptr;
+  wndClass.hCursor = nullptr;
+  wndClass.hbrBackground = nullptr;
+  wndClass.lpszMenuName = nullptr;
   wndClass.lpszClassName = "rfb::win32::MsgWindowClass";
   classAtom = RegisterClass(&wndClass);
   if (!classAtom) {
@@ -98,11 +98,11 @@ static MsgWindowClass baseClass;
 // -=- MsgWindow
 //
 
-MsgWindow::MsgWindow(const char* name_) : name(name_), handle(0) {
+MsgWindow::MsgWindow(const char* name_) : name(name_), handle(nullptr) {
   vlog.debug("creating window \"%s\"", name.c_str());
   handle = CreateWindow((const char*)(intptr_t)baseClass.classAtom,
-                        name.c_str(), WS_OVERLAPPED, 0, 0, 10, 10, 0, 0,
-                        baseClass.instance, this);
+                        name.c_str(), WS_OVERLAPPED, 0, 0, 10, 10,
+                        nullptr, nullptr, baseClass.instance, this);
   if (!handle) {
     throw rdr::SystemException("unable to create WMNotifier window instance", GetLastError());
   }
diff --git a/win/rfb_win32/RegConfig.cxx b/win/rfb_win32/RegConfig.cxx
index 38ca52f96..770330ce0 100644
--- a/win/rfb_win32/RegConfig.cxx
+++ b/win/rfb_win32/RegConfig.cxx
@@ -35,7 +35,10 @@ using namespace rfb::win32;
 static LogWriter vlog("RegConfig");
 
 
-RegConfig::RegConfig(EventManager* em) : eventMgr(em), event(CreateEvent(0, TRUE, FALSE, 0)), callback(0) {
+RegConfig::RegConfig(EventManager* em)
+  : eventMgr(em), event(CreateEvent(nullptr, TRUE, FALSE, nullptr)),
+    callback(nullptr)
+{
   if (em->addEvent(event, this))
     eventMgr = em;
 }
@@ -110,7 +113,7 @@ void RegConfigThread::worker() {
   BOOL result = 0;
   MSG msg;
   thread_id = GetCurrentThreadId();
-  while ((result = eventMgr.getMessage(&msg, 0, 0, 0)) > 0) {}
+  while ((result = eventMgr.getMessage(&msg, nullptr, 0, 0)) > 0) {}
   if (result < 0)
     throw rdr::SystemException("RegConfigThread failed", GetLastError());
 }
diff --git a/win/rfb_win32/RegConfig.h b/win/rfb_win32/RegConfig.h
index ef8e45bd6..401cb1482 100644
--- a/win/rfb_win32/RegConfig.h
+++ b/win/rfb_win32/RegConfig.h
@@ -56,7 +56,7 @@ namespace rfb {
       static void loadRegistryConfig(RegKey& key);
     protected:
       // EventHandler interface and trigger event
-      virtual void processEvent(HANDLE event);
+      void processEvent(HANDLE event) override;
 
       EventManager* eventMgr;
       Handle event;
@@ -72,7 +72,7 @@ namespace rfb {
       // Start the thread, reading from the specified key
       bool start(const HKEY rootkey, const char* keyname);
     protected:
-      virtual void worker();
+      void worker() override;
       EventManager eventMgr;
       RegConfig config;
       DWORD thread_id;
diff --git a/win/rfb_win32/Registry.cxx b/win/rfb_win32/Registry.cxx
index d0db60e29..bcb98704e 100644
--- a/win/rfb_win32/Registry.cxx
+++ b/win/rfb_win32/Registry.cxx
@@ -49,18 +49,18 @@ using namespace rfb::win32;
 static LogWriter vlog("Registry");
 
 
-RegKey::RegKey() : key(0), freeKey(false), valueName(NULL), valueNameBufLen(0) {}
+RegKey::RegKey() : key(nullptr), freeKey(false), valueName(nullptr), valueNameBufLen(0) {}
 
-RegKey::RegKey(const HKEY k) : key(0), freeKey(false), valueName(NULL), valueNameBufLen(0) {
-  LONG result = RegOpenKeyEx(k, 0, 0, KEY_ALL_ACCESS, &key);
+RegKey::RegKey(const HKEY k) : key(nullptr), freeKey(false), valueName(nullptr), valueNameBufLen(0) {
+  LONG result = RegOpenKeyEx(k, nullptr, 0, KEY_ALL_ACCESS, &key);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegOpenKeyEx(HKEY)", result);
   vlog.debug("duplicated %p to %p", k, key);
   freeKey = true;
 }
 
-RegKey::RegKey(const RegKey& k) : key(0), freeKey(false), valueName(NULL), valueNameBufLen(0) {
-  LONG result = RegOpenKeyEx(k.key, 0, 0, KEY_ALL_ACCESS, &key);
+RegKey::RegKey(const RegKey& k) : key(nullptr), freeKey(false), valueName(nullptr), valueNameBufLen(0) {
+  LONG result = RegOpenKeyEx(k.key, nullptr, 0, KEY_ALL_ACCESS, &key);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegOpenKeyEx(RegKey&)", result);
   vlog.debug("duplicated %p to %p", k.key, key);
@@ -108,7 +108,7 @@ void RegKey::setDACL(const PACL acl, bool inherit) {
   if ((result = SetSecurityInfo(key, SE_REGISTRY_KEY,
     DACL_SECURITY_INFORMATION |
     (inherit ? UNPROTECTED_DACL_SECURITY_INFORMATION : PROTECTED_DACL_SECURITY_INFORMATION),
-    0, 0, acl, 0)) != ERROR_SUCCESS)
+    nullptr, nullptr, acl, nullptr)) != ERROR_SUCCESS)
     throw rdr::SystemException("RegKey::setDACL failed", result);
 }
 
@@ -116,7 +116,7 @@ void RegKey::close() {
   if (freeKey) {
     vlog.debug("RegCloseKey(%p)", key);
     RegCloseKey(key);
-    key = 0;
+    key = nullptr;
   }
 }
 
@@ -133,7 +133,7 @@ void RegKey::deleteValue(const char* name) const {
 }
 
 void RegKey::awaitChange(bool watchSubTree, DWORD filter, HANDLE event) const {
-  LONG result = RegNotifyChangeKeyValue(key, watchSubTree, filter, event, event != 0);
+  LONG result = RegNotifyChangeKeyValue(key, watchSubTree, filter, event, event != nullptr);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegNotifyChangeKeyValue", result);
 }
@@ -212,11 +212,11 @@ bool RegKey::getBool(const char* valname, bool def) const {
 
 std::string RegKey::getRepresentation(const char* valname) const {
   DWORD type, length;
-  LONG result = RegQueryValueEx(key, valname, 0, &type, 0, &length);
+  LONG result = RegQueryValueEx(key, valname, nullptr, &type, nullptr, &length);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("get registry value length", result);
   std::vector<uint8_t> data(length);
-  result = RegQueryValueEx(key, valname, 0, &type, (BYTE*)data.data(), &length);
+  result = RegQueryValueEx(key, valname, nullptr, &type, (BYTE*)data.data(), &length);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("get registry value", result);
 
@@ -241,14 +241,14 @@ std::string RegKey::getRepresentation(const char* valname) const {
     {
     if (length) {
       std::string str((char*)data.data(), length);
-      DWORD required = ExpandEnvironmentStrings(str.c_str(), 0, 0);
+      DWORD required = ExpandEnvironmentStrings(str.c_str(), nullptr, 0);
       if (required==0)
         throw rdr::SystemException("ExpandEnvironmentStrings", GetLastError());
-      std::vector<char> result(required);
-      length = ExpandEnvironmentStrings(str.c_str(), result.data(), required);
+      std::vector<char> expanded(required);
+      length = ExpandEnvironmentStrings(str.c_str(), expanded.data(), required);
       if (required<length)
         throw rdr::Exception("unable to expand environment strings");
-      return result.data();
+      return expanded.data();
     } else {
       return "";
     }
@@ -269,7 +269,7 @@ bool RegKey::isValue(const char* valname) const {
 
 const char* RegKey::getValueName(int i) {
   DWORD maxValueNameLen;
-  LONG result = RegQueryInfoKey(key, 0, 0, 0, 0, 0, 0, 0, &maxValueNameLen, 0, 0, 0);
+  LONG result = RegQueryInfoKey(key, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, &maxValueNameLen, nullptr, nullptr, nullptr);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegQueryInfoKey", result);
   if (valueNameBufLen < maxValueNameLen + 1) {
@@ -278,8 +278,8 @@ const char* RegKey::getValueName(int i) {
     valueName = new char[valueNameBufLen];
   }
   DWORD length = valueNameBufLen;
-  result = RegEnumValue(key, i, valueName, &length, NULL, 0, 0, 0);
-  if (result == ERROR_NO_MORE_ITEMS) return 0;
+  result = RegEnumValue(key, i, valueName, &length, nullptr, nullptr, nullptr, nullptr);
+  if (result == ERROR_NO_MORE_ITEMS) return nullptr;
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegEnumValue", result);
   return valueName;
@@ -287,7 +287,7 @@ const char* RegKey::getValueName(int i) {
 
 const char* RegKey::getKeyName(int i) {
   DWORD maxValueNameLen;
-  LONG result = RegQueryInfoKey(key, 0, 0, 0, 0, &maxValueNameLen, 0, 0, 0, 0, 0, 0);
+  LONG result = RegQueryInfoKey(key, nullptr, nullptr, nullptr, nullptr, &maxValueNameLen, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr);
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegQueryInfoKey", result);
   if (valueNameBufLen < maxValueNameLen + 1) {
@@ -296,8 +296,8 @@ const char* RegKey::getKeyName(int i) {
     valueName = new char[valueNameBufLen];
   }
   DWORD length = valueNameBufLen;
-  result = RegEnumKeyEx(key, i, valueName, &length, NULL, 0, 0, 0);
-  if (result == ERROR_NO_MORE_ITEMS) return 0;
+  result = RegEnumKeyEx(key, i, valueName, &length, nullptr, nullptr, nullptr, nullptr);
+  if (result == ERROR_NO_MORE_ITEMS) return nullptr;
   if (result != ERROR_SUCCESS)
     throw rdr::SystemException("RegEnumKey", result);
   return valueName;
diff --git a/win/rfb_win32/Registry.h b/win/rfb_win32/Registry.h
index b99c95bcd..10c9e099b 100644
--- a/win/rfb_win32/Registry.h
+++ b/win/rfb_win32/Registry.h
@@ -68,7 +68,7 @@ namespace rfb {
 
       // Block waiting for a registry change, OR return immediately and notify the
       // event when there is a change, if specified
-      void awaitChange(bool watchSubTree, DWORD filter, HANDLE event=0) const;
+      void awaitChange(bool watchSubTree, DWORD filter, HANDLE event=nullptr) const;
 
       void setExpandString(const char* valname, const char* s) const;
       void setString(const char* valname, const char* s) const;
diff --git a/win/rfb_win32/SDisplay.cxx b/win/rfb_win32/SDisplay.cxx
index dd1ac7da2..b1abf849f 100644
--- a/win/rfb_win32/SDisplay.cxx
+++ b/win/rfb_win32/SDisplay.cxx
@@ -70,13 +70,13 @@ BoolParameter rfb::win32::SDisplay::disableEffects("DisableEffects",
 // -=- Constructor/Destructor
 
 SDisplay::SDisplay()
-  : server(0), pb(0), device(0),
-    core(0), ptr(0), kbd(0), clipboard(0),
-    inputs(0), monitor(0), cleanDesktop(0), cursor(0),
-    statusLocation(0), queryConnectionHandler(0), ledState(0)
+  : server(nullptr), pb(nullptr), device(nullptr),
+    core(nullptr), ptr(nullptr), kbd(nullptr), clipboard(nullptr),
+    inputs(nullptr), monitor(nullptr), cleanDesktop(nullptr), cursor(nullptr),
+    statusLocation(nullptr), queryConnectionHandler(nullptr), ledState(0)
 {
-  updateEvent.h = CreateEvent(0, TRUE, FALSE, 0);
-  terminateEvent.h = CreateEvent(0, TRUE, FALSE, 0);
+  updateEvent.h = CreateEvent(nullptr, TRUE, FALSE, nullptr);
+  terminateEvent.h = CreateEvent(nullptr, TRUE, FALSE, nullptr);
 }
 
 SDisplay::~SDisplay()
@@ -89,7 +89,7 @@ SDisplay::~SDisplay()
   // the VNCServer ought not to exist and therefore we shouldn't invoke any
   // methods on it.  Setting server to zero here ensures that stop() doesn't
   // call setPixelBuffer(0) on the server.
-  server = 0;
+  server = nullptr;
   if (core) stop();
 }
 
@@ -139,7 +139,7 @@ void SDisplay::stop()
   }
 
   // Stop the SDisplayCore
-  server->setPixelBuffer(0);
+  server->setPixelBuffer(nullptr);
   stopCore();
 
   vlog.debug("stopped");
@@ -156,7 +156,7 @@ void SDisplay::terminate()
 void SDisplay::queryConnection(network::Socket* sock,
                                const char* userName)
 {
-  assert(server != NULL);
+  assert(server != nullptr);
 
   if (queryConnectionHandler) {
     queryConnectionHandler->queryConnection(sock, userName);
@@ -198,7 +198,7 @@ void SDisplay::startCore() {
         core = new SDisplayCorePolling(this, &updates);
       core->setScreenRect(screenRect);
     } catch (rdr::Exception& e) {
-      delete core; core = 0;
+      delete core; core = nullptr;
       if (tryMethod == 0)
         throw rdr::Exception("unable to access desktop");
       tryMethod--;
@@ -234,16 +234,16 @@ void SDisplay::startCore() {
 void SDisplay::stopCore() {
   if (core)
     vlog.info("Stopping %s", core->methodName());
-  delete core; core = 0;
-  delete pb; pb = 0;
-  delete device; device = 0;
-  delete monitor; monitor = 0;
-  delete clipboard; clipboard = 0;
-  delete inputs; inputs = 0;
-  delete ptr; ptr = 0;
-  delete kbd; kbd = 0;
-  delete cleanDesktop; cleanDesktop = 0;
-  delete cursor; cursor = 0;
+  delete core; core = nullptr;
+  delete pb; pb = nullptr;
+  delete device; device = nullptr;
+  delete monitor; monitor = nullptr;
+  delete clipboard; clipboard = nullptr;
+  delete inputs; inputs = nullptr;
+  delete ptr; ptr = nullptr;
+  delete kbd; kbd = nullptr;
+  delete cleanDesktop; cleanDesktop = nullptr;
+  delete cursor; cursor = nullptr;
   ResetEvent(updateEvent);
 }
 
@@ -416,7 +416,7 @@ SDisplay::processEvent(HANDLE event) {
 
         // Update the cursor shape
         if (set_cursor)
-          pb->setCursor(info.visible ? info.cursor : 0, server);
+          pb->setCursor(info.visible ? info.cursor : nullptr, server);
 
         // Update the cursor position
         // NB: First translate from Screen coordinates to Desktop
@@ -447,14 +447,14 @@ SDisplay::recreatePixelBuffer(bool force) {
   //   If no device is specified, open entire screen using GetDC().
   //   Opening the whole display with CreateDC doesn't work on multi-monitor
   //   systems for some reason.
-  DeviceContext* new_device = 0;
+  DeviceContext* new_device = nullptr;
   if (strlen(displayDevice) > 0) {
     vlog.info("Attaching to device %s", (const char*)displayDevice);
     new_device = new DeviceDC(displayDevice);
   }
   if (!new_device) {
     vlog.info("Attaching to virtual desktop");
-    new_device = new WindowDC(0);
+    new_device = new WindowDC(nullptr);
   }
 
   // Get the coordinates of the specified dispay device
diff --git a/win/rfb_win32/SDisplay.h b/win/rfb_win32/SDisplay.h
index 5b55cd66a..76780d9e0 100644
--- a/win/rfb_win32/SDisplay.h
+++ b/win/rfb_win32/SDisplay.h
@@ -71,31 +71,31 @@ namespace rfb {
 
       // -=- SDesktop interface
 
-      virtual void init(VNCServer* vs);
-      virtual void start();
-      virtual void stop();
-      virtual void terminate();
-      virtual void queryConnection(network::Socket* sock,
-                                   const char* userName);
-      virtual void handleClipboardRequest();
-      virtual void handleClipboardAnnounce(bool available);
-      virtual void handleClipboardData(const char* data);
-      virtual void pointerEvent(const Point& pos, int buttonmask);
-      virtual void keyEvent(uint32_t keysym, uint32_t keycode, bool down);
+      void init(VNCServer* vs) override;
+      void start() override;
+      void stop() override;
+      void terminate() override;
+      void queryConnection(network::Socket* sock,
+                           const char* userName) override;
+      void handleClipboardRequest() override;
+      void handleClipboardAnnounce(bool available) override;
+      void handleClipboardData(const char* data) override;
+      void pointerEvent(const Point& pos, int buttonmask) override;
+      void keyEvent(uint32_t keysym, uint32_t keycode, bool down) override;
 
       // -=- Clipboard events
       
-      virtual void notifyClipboardChanged(bool available);
+      void notifyClipboardChanged(bool available) override;
 
       // -=- Display events
       
-      virtual void notifyDisplayEvent(WMMonitor::Notifier::DisplayEventType evt);
+      void notifyDisplayEvent(WMMonitor::Notifier::DisplayEventType evt) override;
 
       // -=- EventHandler interface
 
       HANDLE getUpdateEvent() {return updateEvent;}
       HANDLE getTerminateEvent() {return terminateEvent;}
-      virtual void processEvent(HANDLE event);
+      void processEvent(HANDLE event) override;
 
       // -=- Notification of whether or not SDisplay is started
 
diff --git a/win/rfb_win32/SDisplayCorePolling.h b/win/rfb_win32/SDisplayCorePolling.h
index 9a8bc29bc..00de2d40f 100644
--- a/win/rfb_win32/SDisplayCorePolling.h
+++ b/win/rfb_win32/SDisplayCorePolling.h
@@ -40,17 +40,17 @@ namespace rfb {
       ~SDisplayCorePolling();
 
       // - Called by SDisplay to inform Core of the screen size
-      virtual void setScreenRect(const Rect& screenRect_);
+      void setScreenRect(const Rect& screenRect_) override;
 
       // - Called by SDisplay to flush updates to the specified tracker
-      virtual void flushUpdates();
+      void flushUpdates() override;
 
-      virtual const char* methodName() const { return "Polling"; }
+      const char* methodName() const override { return "Polling"; }
 
     protected:
       // - MsgWindow overrides
       //   processMessage is used to service the cursor & polling timers
-      virtual LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam);
+      LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) override;
 
       // - Hooking subcomponents used to track the desktop state
       WMCopyRect copyrect;
diff --git a/win/rfb_win32/SDisplayCoreWMHooks.h b/win/rfb_win32/SDisplayCoreWMHooks.h
index 82557f132..3358a1eeb 100644
--- a/win/rfb_win32/SDisplayCoreWMHooks.h
+++ b/win/rfb_win32/SDisplayCoreWMHooks.h
@@ -43,14 +43,14 @@ namespace rfb {
       ~SDisplayCoreWMHooks();
 
       // - Called by SDisplay to flush updates to the specified tracker
-      virtual void flushUpdates();
+      void flushUpdates() override;
 
-      virtual const char* methodName() const { return "VNC Hooks"; }
+      const char* methodName() const override { return "VNC Hooks"; }
 
     protected:
       // - MsgWindow overrides
       //   processMessage is used to service the cursor & polling timers
-      virtual LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam);
+      LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) override;
 
       // - Hooking subcomponents used to track the desktop state
       WMHooks hooks;
diff --git a/win/rfb_win32/Security.cxx b/win/rfb_win32/Security.cxx
index 8dfc5b8d2..e706ddb4e 100644
--- a/win/rfb_win32/Security.cxx
+++ b/win/rfb_win32/Security.cxx
@@ -38,7 +38,7 @@ static LogWriter vlog("SecurityWin32");
 Trustee::Trustee(const char* name,
                  TRUSTEE_FORM form,
                  TRUSTEE_TYPE type) {
-  pMultipleTrustee = 0;
+  pMultipleTrustee = nullptr;
   MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE;
   TrusteeForm = form;
   TrusteeType = type;
@@ -58,7 +58,7 @@ ExplicitAccess::ExplicitAccess(const char* name,
 }
 
 
-AccessEntries::AccessEntries() : entries(0), entry_count(0) {}
+AccessEntries::AccessEntries() : entries(nullptr), entry_count(0) {}
 
 AccessEntries::~AccessEntries() {
   delete [] entries;
@@ -115,19 +115,19 @@ void Sid::getUserNameAndDomain(char** name, char** domain) {
   DWORD nameLen = 0;
   DWORD domainLen = 0;
   SID_NAME_USE use;
-  LookupAccountSid(0, (PSID)*this, 0, &nameLen, 0, &domainLen, &use);
+  LookupAccountSid(nullptr, (PSID)*this, nullptr, &nameLen, nullptr, &domainLen, &use);
   if (GetLastError() != ERROR_INSUFFICIENT_BUFFER)
     throw rdr::SystemException("Unable to determine SID name lengths", GetLastError());
   vlog.info("nameLen=%lu, domainLen=%lu, use=%d", nameLen, domainLen, use);
   *name = new char[nameLen];
   *domain = new char[domainLen];
-  if (!LookupAccountSid(0, (PSID)*this, *name, &nameLen, *domain, &domainLen, &use))
+  if (!LookupAccountSid(nullptr, (PSID)*this, *name, &nameLen, *domain, &domainLen, &use))
     throw rdr::SystemException("Unable to lookup account SID", GetLastError());
 }
 
 
 Sid::Administrators::Administrators() {
-  PSID sid = 0;
+  PSID sid = nullptr;
   SID_IDENTIFIER_AUTHORITY ntAuth = { SECURITY_NT_AUTHORITY };
   if (!AllocateAndInitializeSid(&ntAuth, 2,
                                 SECURITY_BUILTIN_DOMAIN_RID,
@@ -139,7 +139,7 @@ Sid::Administrators::Administrators() {
 }
 
 Sid::SYSTEM::SYSTEM() {
-  PSID sid = 0;
+  PSID sid = nullptr;
   SID_IDENTIFIER_AUTHORITY ntAuth = { SECURITY_NT_AUTHORITY };
   if (!AllocateAndInitializeSid(&ntAuth, 1,
                                 SECURITY_LOCAL_SYSTEM_RID,
@@ -151,7 +151,7 @@ Sid::SYSTEM::SYSTEM() {
 
 Sid::FromToken::FromToken(HANDLE h) {
   DWORD required = 0;
-  GetTokenInformation(h, TokenUser, 0, 0, &required);
+  GetTokenInformation(h, TokenUser, nullptr, 0, &required);
   std::vector<uint8_t> tmp(required);
   if (!GetTokenInformation(h, TokenUser, tmp.data(), tmp.size(), &required))
     throw rdr::SystemException("GetTokenInformation", GetLastError());
diff --git a/win/rfb_win32/Security.h b/win/rfb_win32/Security.h
index a24c359f6..a4471f977 100644
--- a/win/rfb_win32/Security.h
+++ b/win/rfb_win32/Security.h
@@ -96,17 +96,17 @@ namespace rfb {
     // Helper class for handling & freeing ACLs
     struct AccessControlList : public LocalMem {
       AccessControlList(int size) : LocalMem(size) {}
-      AccessControlList(PACL acl_=0) : LocalMem(acl_) {}
+      AccessControlList(PACL acl_=nullptr) : LocalMem(acl_) {}
       operator PACL() {return (PACL)ptr;}
     };
 
     // Create a new ACL based on supplied entries and, if supplied, existing ACL 
-    PACL CreateACL(const AccessEntries& ae, PACL existing_acl=0);
+    PACL CreateACL(const AccessEntries& ae, PACL existing_acl=nullptr);
 
     // Helper class for memory-management of self-relative SecurityDescriptors
     struct SecurityDescriptorPtr : LocalMem {
       SecurityDescriptorPtr(int size) : LocalMem(size) {}
-      SecurityDescriptorPtr(PSECURITY_DESCRIPTOR sd_=0) : LocalMem(sd_) {}
+      SecurityDescriptorPtr(PSECURITY_DESCRIPTOR sd_=nullptr) : LocalMem(sd_) {}
       PSECURITY_DESCRIPTOR takeSD() {return (PSECURITY_DESCRIPTOR)takePtr();}
     };
 
diff --git a/win/rfb_win32/SecurityPage.cxx b/win/rfb_win32/SecurityPage.cxx
index 600a8a34b..a6f026cf2 100644
--- a/win/rfb_win32/SecurityPage.cxx
+++ b/win/rfb_win32/SecurityPage.cxx
@@ -40,7 +40,7 @@ static LogWriter vlog("AuthDialog");
 
 /* XXX: This class contains bunch of similar code to unix/vncviewer/CConn.cxx */
 SecurityPage::SecurityPage(Security *security_)
-  : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_SECURITY)),
+  : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_SECURITY)),
     security(security_) {
 }
 
@@ -48,7 +48,6 @@ void
 SecurityPage::initDialog()
 {
   list<uint8_t> secTypes;
-  list<uint8_t>::iterator i;
 
   if (isItemChecked(IDC_ENC_X509))
     enableX509Dialogs();
@@ -58,8 +57,8 @@ SecurityPage::initDialog()
   secTypes = security->GetEnabledSecTypes();
 
   /* Process non-VeNCrypt sectypes */
-  for (i = secTypes.begin(); i != secTypes.end(); i++) {
-    switch (*i) {
+  for (uint8_t type : secTypes) {
+    switch (type) {
     case secTypeNone:
       enableAuthMethod(IDC_ENC_NONE, IDC_AUTH_NONE);
       break;
@@ -70,13 +69,12 @@ SecurityPage::initDialog()
   }
 
   list<uint32_t> secTypesExt;
-  list<uint32_t>::iterator iext;
 
   secTypesExt = security->GetEnabledExtSecTypes();
 
   /* Process VeNCrypt subtypes */
-  for (iext = secTypesExt.begin(); iext != secTypesExt.end(); iext++) {
-    switch (*iext) {
+  for (uint32_t type : secTypesExt) {
+    switch (type) {
     case secTypePlain:
       enableAuthMethod(IDC_ENC_NONE, IDC_AUTH_PLAIN);
       break;
diff --git a/win/rfb_win32/SecurityPage.h b/win/rfb_win32/SecurityPage.h
index 258b58e0d..62c503882 100644
--- a/win/rfb_win32/SecurityPage.h
+++ b/win/rfb_win32/SecurityPage.h
@@ -39,9 +39,9 @@ class SecurityPage: public PropSheetPage
   virtual void disableX509Dialogs(void) = 0;
   virtual void loadVncPasswd(void) = 0;
 
-  virtual void initDialog();
-  virtual bool onCommand(int id, int cmd);
-  virtual bool onOk();
+  void initDialog() override;
+  bool onCommand(int id, int cmd) override;
+  bool onOk() override;
 
 protected:
   Security *security;
diff --git a/win/rfb_win32/Service.cxx b/win/rfb_win32/Service.cxx
index 62230b073..dafa38b59 100644
--- a/win/rfb_win32/Service.cxx
+++ b/win/rfb_win32/Service.cxx
@@ -42,7 +42,7 @@ static LogWriter vlog("Service");
 
 // - Internal service implementation functions
 
-Service* service = 0;
+Service* service = nullptr;
 bool runAsService = false;
 
 VOID WINAPI serviceHandler(DWORD control) {
@@ -93,7 +93,7 @@ VOID WINAPI serviceProc(DWORD dwArgc, LPTSTR* lpszArgv) {
 
 Service::Service(const char* name_) : name(name_) {
   vlog.debug("Service");
-  status_handle = 0;
+  status_handle = nullptr;
   status.dwControlsAccepted = SERVICE_CONTROL_INTERROGATE | SERVICE_ACCEPT_SHUTDOWN | SERVICE_ACCEPT_STOP;
   status.dwServiceType = SERVICE_WIN32_OWN_PROCESS | SERVICE_INTERACTIVE_PROCESS;
   status.dwWin32ExitCode = NO_ERROR;
@@ -108,8 +108,8 @@ Service::start() {
   SERVICE_TABLE_ENTRY entry[2];
   entry[0].lpServiceName = (char*)name;
   entry[0].lpServiceProc = serviceProc;
-  entry[1].lpServiceName = NULL;
-  entry[1].lpServiceProc = NULL;
+  entry[1].lpServiceName = nullptr;
+  entry[1].lpServiceProc = nullptr;
   vlog.debug("entering dispatcher");
   if (!SetProcessShutdownParameters(0x100, 0))
     vlog.error("unable to set shutdown parameters: %lu", GetLastError());
@@ -125,7 +125,7 @@ Service::setStatus() {
 
 void
 Service::setStatus(DWORD state) {
-  if (status_handle == 0) {
+  if (status_handle == nullptr) {
     vlog.debug("warning - cannot setStatus");
     return;
   }
@@ -141,7 +141,7 @@ Service::setStatus(DWORD state) {
 
 Service::~Service() {
   vlog.debug("~Service");
-  service = 0;
+  service = nullptr;
 }
 
 
@@ -254,7 +254,7 @@ rfb::win32::changeDesktop() {
 bool
 rfb::win32::emulateCtrlAltDel() {
   rfb::win32::Handle sessionEventCad = 
-    CreateEvent(0, FALSE, FALSE, "Global\\SessionEventTigerVNCCad");
+    CreateEvent(nullptr, FALSE, FALSE, "Global\\SessionEventTigerVNCCad");
   SetEvent(sessionEventCad);
   return true;
 }
@@ -265,7 +265,7 @@ rfb::win32::emulateCtrlAltDel() {
 class Logger_EventLog : public Logger {
 public:
   Logger_EventLog(const char* srcname) : Logger("EventLog") {
-    eventlog = RegisterEventSource(NULL, srcname);
+    eventlog = RegisterEventSource(nullptr, srcname);
     if (!eventlog)
       printf("Unable to open event log:%ld\n", GetLastError());
   }
@@ -274,12 +274,12 @@ class Logger_EventLog : public Logger {
       DeregisterEventSource(eventlog);
   }
 
-  virtual void write(int level, const char *logname, const char *message) {
+  void write(int level, const char *logname, const char *message) override {
     if (!eventlog) return;
     const char* strings[] = {logname, message};
     WORD type = EVENTLOG_INFORMATION_TYPE;
     if (level == 0) type = EVENTLOG_ERROR_TYPE;
-    if (!ReportEvent(eventlog, type, 0, VNC4LogMessage, NULL, 2, 0, strings, NULL)) {
+    if (!ReportEvent(eventlog, type, 0, VNC4LogMessage, nullptr, 2, 0, strings, nullptr)) {
       // *** It's not at all clear what is the correct behaviour if this fails...
       printf("ReportEvent failed:%ld\n", GetLastError());
     }
@@ -289,7 +289,7 @@ class Logger_EventLog : public Logger {
   HANDLE eventlog;
 };
 
-static Logger_EventLog* logger = 0;
+static Logger_EventLog* logger = nullptr;
 
 bool rfb::win32::initEventLogLogger(const char* srcname) {
   if (logger)
@@ -333,22 +333,22 @@ bool rfb::win32::registerService(const char* name,
   // - Register the service
 
   // - Open the SCM
-  ServiceHandle scm = OpenSCManager(NULL, NULL, SC_MANAGER_CREATE_SERVICE);
+  ServiceHandle scm = OpenSCManager(nullptr, nullptr, SC_MANAGER_CREATE_SERVICE);
   if (!scm)
     throw rdr::SystemException("unable to open Service Control Manager", GetLastError());
 
   // - Add the service
-  ServiceHandle service = CreateService(scm,
+  ServiceHandle handle = CreateService(scm,
     name, display, SC_MANAGER_ALL_ACCESS,
     SERVICE_WIN32_OWN_PROCESS | SERVICE_INTERACTIVE_PROCESS,
     SERVICE_AUTO_START, SERVICE_ERROR_IGNORE,
-    cmdline.c_str(), NULL, NULL, NULL, NULL, NULL);
-  if (!service)
+    cmdline.c_str(), nullptr, nullptr, nullptr, nullptr, nullptr);
+  if (!handle)
     throw rdr::SystemException("unable to create service", GetLastError());
 
   // - Set a description
   SERVICE_DESCRIPTION sdesc = {(LPTSTR)desc};
-  ChangeServiceConfig2(service, SERVICE_CONFIG_DESCRIPTION, &sdesc);
+  ChangeServiceConfig2(handle, SERVICE_CONFIG_DESCRIPTION, &sdesc);
 
   // - Register the event log source
   RegKey hk, hk2;
@@ -378,15 +378,15 @@ bool rfb::win32::registerService(const char* name,
 
 bool rfb::win32::unregisterService(const char* name) {
   // - Open the SCM
-  ServiceHandle scm = OpenSCManager(NULL, NULL, SC_MANAGER_CREATE_SERVICE);
+  ServiceHandle scm = OpenSCManager(nullptr, nullptr, SC_MANAGER_CREATE_SERVICE);
   if (!scm)
     throw rdr::SystemException("unable to open Service Control Manager", GetLastError());
 
   // - Create the service
-  ServiceHandle service = OpenService(scm, name, SC_MANAGER_ALL_ACCESS);
-  if (!service)
+  ServiceHandle handle = OpenService(scm, name, SC_MANAGER_ALL_ACCESS);
+  if (!handle)
     throw rdr::SystemException("unable to locate the service", GetLastError());
-  if (!DeleteService(service))
+  if (!DeleteService(handle))
     throw rdr::SystemException("unable to remove the service", GetLastError());
 
   // - Register the event log source
@@ -405,17 +405,17 @@ bool rfb::win32::unregisterService(const char* name) {
 bool rfb::win32::startService(const char* name) {
 
   // - Open the SCM
-  ServiceHandle scm = OpenSCManager(NULL, NULL, SC_MANAGER_CONNECT);
+  ServiceHandle scm = OpenSCManager(nullptr, nullptr, SC_MANAGER_CONNECT);
   if (!scm)
     throw rdr::SystemException("unable to open Service Control Manager", GetLastError());
 
   // - Locate the service
-  ServiceHandle service = OpenService(scm, name, SERVICE_START);
-  if (!service)
+  ServiceHandle handle = OpenService(scm, name, SERVICE_START);
+  if (!handle)
     throw rdr::SystemException("unable to open the service", GetLastError());
 
   // - Start the service
-  if (!StartService(service, 0, NULL))
+  if (!StartService(handle, 0, nullptr))
     throw rdr::SystemException("unable to start the service", GetLastError());
 
   Sleep(500);
@@ -425,18 +425,18 @@ bool rfb::win32::startService(const char* name) {
 
 bool rfb::win32::stopService(const char* name) {
   // - Open the SCM
-  ServiceHandle scm = OpenSCManager(NULL, NULL, SC_MANAGER_CONNECT);
+  ServiceHandle scm = OpenSCManager(nullptr, nullptr, SC_MANAGER_CONNECT);
   if (!scm)
     throw rdr::SystemException("unable to open Service Control Manager", GetLastError());
 
   // - Locate the service
-  ServiceHandle service = OpenService(scm, name, SERVICE_STOP);
-  if (!service)
+  ServiceHandle handle = OpenService(scm, name, SERVICE_STOP);
+  if (!handle)
     throw rdr::SystemException("unable to open the service", GetLastError());
 
   // - Start the service
   SERVICE_STATUS status;
-  if (!ControlService(service, SERVICE_CONTROL_STOP, &status))
+  if (!ControlService(handle, SERVICE_CONTROL_STOP, &status))
     throw rdr::SystemException("unable to stop the service", GetLastError());
 
   Sleep(500);
@@ -446,18 +446,18 @@ bool rfb::win32::stopService(const char* name) {
 
 DWORD rfb::win32::getServiceState(const char* name) {
   // - Open the SCM
-  ServiceHandle scm = OpenSCManager(NULL, NULL, SC_MANAGER_CONNECT);
+  ServiceHandle scm = OpenSCManager(nullptr, nullptr, SC_MANAGER_CONNECT);
   if (!scm)
     throw rdr::SystemException("unable to open Service Control Manager", GetLastError());
 
   // - Locate the service
-  ServiceHandle service = OpenService(scm, name, SERVICE_INTERROGATE);
-  if (!service)
+  ServiceHandle handle = OpenService(scm, name, SERVICE_INTERROGATE);
+  if (!handle)
     throw rdr::SystemException("unable to open the service", GetLastError());
 
   // - Get the service status
   SERVICE_STATUS status;
-  if (!ControlService(service, SERVICE_CONTROL_INTERROGATE, (SERVICE_STATUS*)&status))
+  if (!ControlService(handle, SERVICE_CONTROL_INTERROGATE, (SERVICE_STATUS*)&status))
     throw rdr::SystemException("unable to query the service", GetLastError());
 
   return status.dwCurrentState;
diff --git a/win/rfb_win32/SocketManager.cxx b/win/rfb_win32/SocketManager.cxx
index 015ba549f..57b65aefb 100644
--- a/win/rfb_win32/SocketManager.cxx
+++ b/win/rfb_win32/SocketManager.cxx
@@ -50,7 +50,7 @@ SocketManager::~SocketManager() {
 
 static void requestAddressChangeEvents(network::SocketListener* sock_) {
   DWORD dummy = 0;
-  if (WSAIoctl(sock_->getFd(), SIO_ADDRESS_LIST_CHANGE, 0, 0, 0, 0, &dummy, 0, 0) == SOCKET_ERROR) {
+  if (WSAIoctl(sock_->getFd(), SIO_ADDRESS_LIST_CHANGE, nullptr, 0, nullptr, 0, &dummy, nullptr, nullptr) == SOCKET_ERROR) {
     DWORD err = WSAGetLastError();
     if (err != WSAEWOULDBLOCK)
       vlog.error("Unable to track address changes: 0x%08x", (unsigned)err);
@@ -210,7 +210,7 @@ void SocketManager::processEvent(HANDLE event) {
       network::Socket* new_sock = li.sock->accept();
       if (new_sock && li.disable) {
         delete new_sock;
-        new_sock = 0;
+        new_sock = nullptr;
       }
       if (new_sock)
         addSocket(new_sock, li.server, false);
@@ -229,11 +229,11 @@ void SocketManager::processEvent(HANDLE event) {
     try {
       // Process data from an active connection
 
-      WSANETWORKEVENTS events;
+      WSANETWORKEVENTS network_events;
       long eventMask;
 
       // Fetch why this event notification triggered
-      if (WSAEnumNetworkEvents(ci.sock->getFd(), event, &events) == SOCKET_ERROR)
+      if (WSAEnumNetworkEvents(ci.sock->getFd(), event, &network_events) == SOCKET_ERROR)
         throw rdr::SystemException("unable to get WSAEnumNetworkEvents:%u", WSAGetLastError());
 
       // Cancel event notification for this socket
@@ -245,14 +245,14 @@ void SocketManager::processEvent(HANDLE event) {
 
 
       // Call the socket server to process the event
-      if (events.lNetworkEvents & FD_WRITE) {
+      if (network_events.lNetworkEvents & FD_WRITE) {
         ci.server->processSocketWriteEvent(ci.sock);
         if (ci.sock->isShutdown()) {
           remSocket(ci.sock);
           return;
         }
       }
-      if (events.lNetworkEvents & (FD_READ | FD_CLOSE)) {
+      if (network_events.lNetworkEvents & (FD_READ | FD_CLOSE)) {
         ci.server->processSocketReadEvent(ci.sock);
         if (ci.sock->isShutdown()) {
           remSocket(ci.sock);
diff --git a/win/rfb_win32/SocketManager.h b/win/rfb_win32/SocketManager.h
index 809c470ef..4302bbbe7 100644
--- a/win/rfb_win32/SocketManager.h
+++ b/win/rfb_win32/SocketManager.h
@@ -61,7 +61,7 @@ namespace rfb {
       // VNCServer.
       void addListener(network::SocketListener* sock_,
                        VNCServer* srvr,
-                       AddressChangeNotifier* acn = 0);
+                       AddressChangeNotifier* acn = nullptr);
 
       // Remove and delete a listening socket.
       void remListener(network::SocketListener* sock);
@@ -75,8 +75,8 @@ namespace rfb {
       void setDisable(VNCServer* srvr, bool disable);
 
     protected:
-      virtual int checkTimeouts();
-      virtual void processEvent(HANDLE event);
+      int checkTimeouts() override;
+      void processEvent(HANDLE event) override;
       virtual void remSocket(network::Socket* sock);
 
       struct ConnInfo {
diff --git a/win/rfb_win32/TrayIcon.h b/win/rfb_win32/TrayIcon.h
index c99203d15..61d2c9aca 100644
--- a/win/rfb_win32/TrayIcon.h
+++ b/win/rfb_win32/TrayIcon.h
@@ -43,7 +43,7 @@ namespace rfb {
 
         nid.hWnd = getHandle();
         nid.uID = 0;
-        nid.hIcon = 0;
+        nid.hIcon = nullptr;
         nid.uFlags = NIF_ICON | NIF_MESSAGE;
         nid.uCallbackMessage = WM_USER;
       }
@@ -54,13 +54,13 @@ namespace rfb {
         if (icon == 0) {
           return remove();
         } else {
-          nid.hIcon = (HICON)LoadImage(GetModuleHandle(0), MAKEINTRESOURCE(icon),
+          nid.hIcon = (HICON)LoadImage(GetModuleHandle(nullptr), MAKEINTRESOURCE(icon),
             IMAGE_ICON, 0, 0, LR_DEFAULTSIZE | LR_SHARED);
           return refresh();
         }
       }
       bool setToolTip(const char* text) {
-        if (text == 0) {
+        if (text == nullptr) {
           nid.uFlags &= ~NIF_TIP;
         } else {
           const int tipLen = sizeof(nid.szTip)/sizeof(char);
diff --git a/win/rfb_win32/WMCursor.cxx b/win/rfb_win32/WMCursor.cxx
index 32a899302..54e31cdc0 100644
--- a/win/rfb_win32/WMCursor.cxx
+++ b/win/rfb_win32/WMCursor.cxx
@@ -32,8 +32,8 @@ using namespace rfb::win32;
 
 static LogWriter vlog("WMCursor");
 
-WMCursor::WMCursor() : cursor(0) {
-  cursor = (HCURSOR)LoadImage(0, IDC_ARROW, IMAGE_CURSOR, 0, 0, LR_DEFAULTSIZE | LR_SHARED);
+WMCursor::WMCursor() : cursor(nullptr) {
+  cursor = (HCURSOR)LoadImage(nullptr, IDC_ARROW, IMAGE_CURSOR, 0, 0, LR_DEFAULTSIZE | LR_SHARED);
 }
 
 WMCursor::~WMCursor() {
diff --git a/win/rfb_win32/WMCursor.h b/win/rfb_win32/WMCursor.h
index f4366583d..465331dec 100644
--- a/win/rfb_win32/WMCursor.h
+++ b/win/rfb_win32/WMCursor.h
@@ -40,7 +40,7 @@ namespace rfb {
         HCURSOR cursor;
         Point position;
         bool visible;
-        Info() : cursor(0), visible(false) {}
+        Info() : cursor(nullptr), visible(false) {}
         bool operator!=(const Info& info) {
           return ((cursor != info.cursor) ||
             (position != info.position) ||
diff --git a/win/rfb_win32/WMHooks.cxx b/win/rfb_win32/WMHooks.cxx
index 017972ba2..cb2e0275b 100644
--- a/win/rfb_win32/WMHooks.cxx
+++ b/win/rfb_win32/WMHooks.cxx
@@ -65,52 +65,52 @@ static WM_Hooks_EnableRealInputs_proto WM_Hooks_EnableRealInputs;
 
 static void LoadHooks()
 {
-  if (hooksLibrary != NULL)
+  if (hooksLibrary != nullptr)
     return;
 
   hooksLibrary = LoadLibrary("wm_hooks.dll");
-  if (hooksLibrary == NULL)
+  if (hooksLibrary == nullptr)
     return;
 
   WM_Hooks_WindowChanged = (WM_Hooks_WMVAL_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_WindowChanged");
-  if (WM_Hooks_WindowChanged == NULL)
+  if (WM_Hooks_WindowChanged == nullptr)
     goto error;
   WM_Hooks_WindowBorderChanged = (WM_Hooks_WMVAL_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_WindowBorderChanged");
-  if (WM_Hooks_WindowBorderChanged == NULL)
+  if (WM_Hooks_WindowBorderChanged == nullptr)
     goto error;
   WM_Hooks_WindowClientAreaChanged = (WM_Hooks_WMVAL_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_WindowClientAreaChanged");
-  if (WM_Hooks_WindowClientAreaChanged == NULL)
+  if (WM_Hooks_WindowClientAreaChanged == nullptr)
     goto error;
   WM_Hooks_RectangleChanged = (WM_Hooks_WMVAL_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_RectangleChanged");
-  if (WM_Hooks_RectangleChanged == NULL)
+  if (WM_Hooks_RectangleChanged == nullptr)
     goto error;
 #ifdef _DEBUG
   WM_Hooks_Diagnostic = (WM_Hooks_WMVAL_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_Diagnostic");
-  if (WM_Hooks_Diagnostic == NULL)
+  if (WM_Hooks_Diagnostic == nullptr)
     goto error;
 #endif
 
   WM_Hooks_Install = (WM_Hooks_Install_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_Install");
-  if (WM_Hooks_Install == NULL)
+  if (WM_Hooks_Install == nullptr)
     goto error;
   WM_Hooks_Remove = (WM_Hooks_Remove_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_Remove");
-  if (WM_Hooks_Remove == NULL)
+  if (WM_Hooks_Remove == nullptr)
     goto error;
 #ifdef _DEBUG
   WM_Hooks_SetDiagnosticRange = (WM_Hooks_SetDiagnosticRange_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_SetDiagnosticRange");
-  if (WM_Hooks_SetDiagnosticRange == NULL)
+  if (WM_Hooks_SetDiagnosticRange == nullptr)
     goto error;
 #endif
 
   WM_Hooks_EnableRealInputs = (WM_Hooks_EnableRealInputs_proto)(void*)GetProcAddress(hooksLibrary, "WM_Hooks_EnableRealInputs");
-  if (WM_Hooks_EnableRealInputs == NULL)
+  if (WM_Hooks_EnableRealInputs == nullptr)
     goto error;
 
   return;
 
 error:
   FreeLibrary(hooksLibrary);
-  hooksLibrary = NULL;
+  hooksLibrary = nullptr;
 }
 
 
@@ -120,13 +120,13 @@ class WMHooksThread : public os::Thread {
   void stop();
   DWORD getThreadId() { return thread_id; }
 protected:
-  virtual void worker();
+  void worker() override;
 protected:
   bool active;
   DWORD thread_id;
 };
 
-static WMHooksThread* hook_mgr = 0;
+static WMHooksThread* hook_mgr = nullptr;
 static std::list<WMHooks*> hooks;
 static os::Mutex hook_mgr_lock;
 
@@ -134,7 +134,7 @@ static os::Mutex hook_mgr_lock;
 static bool StartHookThread() {
   if (hook_mgr)
     return true;
-  if (hooksLibrary == NULL)
+  if (hooksLibrary == nullptr)
     return false;
   vlog.debug("creating thread");
   hook_mgr = new WMHooksThread();
@@ -146,7 +146,7 @@ static bool StartHookThread() {
     vlog.error("failed to initialise hooks");
     hook_mgr->stop();
     delete hook_mgr;
-    hook_mgr = 0;
+    hook_mgr = nullptr;
     return false;
   }
   return true;
@@ -160,7 +160,7 @@ static void StopHookThread() {
   vlog.debug("closing thread");
   hook_mgr->stop();
   delete hook_mgr;
-  hook_mgr = 0;
+  hook_mgr = nullptr;
 }
 
 
@@ -220,7 +220,7 @@ WMHooksThread::worker() {
 
   thread_id = GetCurrentThreadId();
 
-  while (active && GetMessage(&msg, NULL, 0, 0)) {
+  while (active && GetMessage(&msg, nullptr, 0, 0)) {
     count++;
 
     if (msg.message == WM_TIMER) {
@@ -306,7 +306,7 @@ WMHooksThread::stop() {
 
 // -=- WMHooks class
 
-rfb::win32::WMHooks::WMHooks() : updateEvent(0) {
+rfb::win32::WMHooks::WMHooks() : updateEvent(nullptr) {
   LoadHooks();
 }
 
@@ -358,7 +358,7 @@ rfb::win32::WMBlockInput::~WMBlockInput() {
 static bool blocking = false;
 static bool blockRealInputs(bool block_) {
   // NB: Requires blockMutex to be held!
-  if (hooksLibrary == NULL)
+  if (hooksLibrary == nullptr)
     return false;
   if (block_) {
     if (blocking)
diff --git a/win/rfb_win32/WMNotifier.cxx b/win/rfb_win32/WMNotifier.cxx
index 81b4fa51f..894add1c6 100644
--- a/win/rfb_win32/WMNotifier.cxx
+++ b/win/rfb_win32/WMNotifier.cxx
@@ -34,7 +34,7 @@ using namespace rfb::win32;
 static LogWriter vlog("WMMonitor");
 
 
-WMMonitor::WMMonitor() : MsgWindow("WMMonitor"), notifier(0) {
+WMMonitor::WMMonitor() : MsgWindow("WMMonitor"), notifier(nullptr) {
 }
 
 WMMonitor::~WMMonitor() {
diff --git a/win/rfb_win32/WMNotifier.h b/win/rfb_win32/WMNotifier.h
index 3855430b1..937a655d5 100644
--- a/win/rfb_win32/WMNotifier.h
+++ b/win/rfb_win32/WMNotifier.h
@@ -55,7 +55,7 @@ namespace rfb {
 
     protected:
       // - Internal MsgWindow callback
-      virtual LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam);
+      LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) override;
 
       Notifier* notifier;
     };
diff --git a/win/rfb_win32/WMPoller.h b/win/rfb_win32/WMPoller.h
index 851b69f43..0783e4ff5 100644
--- a/win/rfb_win32/WMPoller.h
+++ b/win/rfb_win32/WMPoller.h
@@ -38,7 +38,7 @@ namespace rfb {
 
     class WMPoller {
     public:
-      WMPoller() : ut(0) {}
+      WMPoller() : ut(nullptr) {}
 
       bool processEvent();
       bool setUpdateTracker(UpdateTracker* ut);
diff --git a/win/rfb_win32/WMWindowCopyRect.cxx b/win/rfb_win32/WMWindowCopyRect.cxx
index 4d69d54bc..ec6e1fdcb 100644
--- a/win/rfb_win32/WMWindowCopyRect.cxx
+++ b/win/rfb_win32/WMWindowCopyRect.cxx
@@ -33,7 +33,7 @@ static LogWriter vlog("WMCopyRect");
 
 // -=- WMHooks class
 
-rfb::win32::WMCopyRect::WMCopyRect() : ut(0), fg_window(0) {
+rfb::win32::WMCopyRect::WMCopyRect() : ut(nullptr), fg_window(nullptr) {
 }
 
 bool
@@ -56,10 +56,10 @@ rfb::win32::WMCopyRect::processEvent() {
       fg_window = window;
       fg_window_rect = winrect;
     } else {
-      fg_window = 0;
+      fg_window = nullptr;
     }
   } else {
-    fg_window = 0;
+    fg_window = nullptr;
   }
   return false;
 }
diff --git a/win/rfb_win32/Win32Util.cxx b/win/rfb_win32/Win32Util.cxx
index ed6b70cbe..c3b7ad196 100644
--- a/win/rfb_win32/Win32Util.cxx
+++ b/win/rfb_win32/Win32Util.cxx
@@ -44,7 +44,7 @@ FileVersionInfo::FileVersionInfo(const char* filename) {
   // Attempt to open the file, to cause Access Denied, etc, errors
   // to be correctly reported, since the GetFileVersionInfoXXX calls lie...
   {
-    Handle file(CreateFile(filename, GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0));
+    Handle file(CreateFile(filename, GENERIC_READ, FILE_SHARE_READ, nullptr, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, nullptr));
 	  if (file.h == INVALID_HANDLE_VALUE)
       throw rdr::SystemException("Failed to open file", GetLastError());
   }
@@ -77,7 +77,7 @@ const char* FileVersionInfo::getVerString(const char* name, DWORD langId) {
   infoName = format("\\StringFileInfo\\%s\\%s", langIdStr.c_str(), name);
 
   // Locate the required version string within the version info
-  char* buffer = 0;
+  char* buffer = nullptr;
   UINT length = 0;
   if (!VerQueryValue(buf, infoName.c_str(), (void**)&buffer, &length)) {
     printf("unable to find %s version string", infoName.c_str());
@@ -104,13 +104,13 @@ void centerWindow(HWND handle, const RECT& r) {
   int x = (r.left + r.right - w)/2;
   int y = (r.top + r.bottom - h)/2;
   UINT flags = SWP_NOACTIVATE | SWP_NOOWNERZORDER | SWP_NOZORDER | SWP_NOSIZE;
-  SetWindowPos(handle, 0, x, y, 0, 0, flags);
+  SetWindowPos(handle, nullptr, x, y, 0, 0, flags);
 }
 
 void resizeWindow(HWND handle, int width, int height) {
   RECT r;
   GetWindowRect(handle, &r);
-  SetWindowPos(handle, 0, 0, 0, width, height, SWP_NOACTIVATE | SWP_NOOWNERZORDER | SWP_NOZORDER | SWP_NOMOVE);
+  SetWindowPos(handle, nullptr, 0, 0, width, height, SWP_NOACTIVATE | SWP_NOOWNERZORDER | SWP_NOZORDER | SWP_NOMOVE);
   centerWindow(handle, r);
 }
 
diff --git a/win/rfb_win32/Win32Util.h b/win/rfb_win32/Win32Util.h
index 24d5905d7..927ca1e2b 100644
--- a/win/rfb_win32/Win32Util.h
+++ b/win/rfb_win32/Win32Util.h
@@ -30,7 +30,7 @@ namespace rfb {
   namespace win32 {
 
     struct FileVersionInfo {
-      FileVersionInfo(const char* filename=0);
+      FileVersionInfo(const char* filename=nullptr);
       ~FileVersionInfo();
       const char* getVerString(const char* name, DWORD langId = 0x080904b0);
     private:
diff --git a/win/vncconfig/Authentication.h b/win/vncconfig/Authentication.h
index a69f75925..1123678fb 100644
--- a/win/vncconfig/Authentication.h
+++ b/win/vncconfig/Authentication.h
@@ -43,11 +43,11 @@ namespace rfb {
     class SecPage : public SecurityPage {
     public:
       SecPage(const RegKey& rk)
-        : SecurityPage(NULL), regKey(rk) {
+        : SecurityPage(nullptr), regKey(rk) {
         security = new SecurityServer();
       }
 
-      void initDialog() {
+      void initDialog() override {
         SecurityPage::initDialog();
 
         setItemChecked(IDC_QUERY_CONNECT, rfb::Server::queryConnect);
@@ -55,7 +55,7 @@ namespace rfb {
         onCommand(IDC_AUTH_NONE, 0);
       }
 
-      bool onCommand(int id, int cmd) {
+      bool onCommand(int id, int cmd) override {
         SecurityPage::onCommand(id, cmd);
 
         setChanged(true);
@@ -78,16 +78,16 @@ namespace rfb {
 
         return true;
       }
-      bool onOk() {
+      bool onOk() override {
         SecurityPage::onOk();
 
         if (isItemChecked(IDC_AUTH_VNC))
           verifyVncPassword(regKey);
         else if (haveVncPassword() && 
-            MsgBox(0, "The VNC authentication method is disabled, but a password is still stored for it.\n"
+            MsgBox(nullptr, "The VNC authentication method is disabled, but a password is still stored for it.\n"
                       "Do you want to remove the VNC authentication password from the registry?",
                       MB_ICONWARNING | MB_YESNO) == IDYES) {
-          regKey.setBinary("Password", 0, 0);
+          regKey.setBinary("Password", nullptr, 0);
         }
 
 #ifdef HAVE_GNUTLS
@@ -119,23 +119,23 @@ namespace rfb {
 
       static void verifyVncPassword(const RegKey& regKey) {
         if (!haveVncPassword()) {
-          MsgBox(0, "The VNC authentication method is enabled, but no password is specified.\n"
+          MsgBox(nullptr, "The VNC authentication method is enabled, but no password is specified.\n"
                     "The password dialog will now be shown.", MB_ICONINFORMATION | MB_OK);
           PasswordDialog passwd(regKey, registryInsecure);
           passwd.showDialog();
         }
       }
 
-      virtual void loadX509Certs(void) {}
-      virtual void enableX509Dialogs(void) {
+      void loadX509Certs(void) override {}
+      void enableX509Dialogs(void) override {
         enableItem(IDC_LOAD_CERT, true);
         enableItem(IDC_LOAD_CERTKEY, true);
       }
-      virtual void disableX509Dialogs(void) {
+      void disableX509Dialogs(void) override {
         enableItem(IDC_LOAD_CERT, false);
         enableItem(IDC_LOAD_CERTKEY, false);
       }
-      virtual void loadVncPasswd() {
+      void loadVncPasswd() override {
         enableItem(IDC_AUTH_VNC_PASSWD, isItemChecked(IDC_AUTH_VNC));
       }
 
@@ -165,10 +165,10 @@ namespace rfb {
         ofn.nMaxFile = sizeof(filename);
         ofn.lpstrFilter = (char*)filter;
         ofn.nFilterIndex = 1;
-        ofn.lpstrFileTitle = NULL;
+        ofn.lpstrFileTitle = nullptr;
         ofn.nMaxFileTitle = 0;
         ofn.lpstrTitle = (char*)title;
-        ofn.lpstrInitialDir = NULL;
+        ofn.lpstrInitialDir = nullptr;
         ofn.Flags = OFN_PATHMUSTEXIST | OFN_FILEMUSTEXIST;
 
         if (GetOpenFileName(&ofn)==TRUE) {
diff --git a/win/vncconfig/Connections.h b/win/vncconfig/Connections.h
index fcaae2034..a540bd760 100644
--- a/win/vncconfig/Connections.h
+++ b/win/vncconfig/Connections.h
@@ -41,12 +41,12 @@ namespace rfb {
 
     class ConnHostDialog : public Dialog {
     public:
-      ConnHostDialog() : Dialog(GetModuleHandle(0)) {}
+      ConnHostDialog() : Dialog(GetModuleHandle(nullptr)) {}
       bool showDialog(const char* pat) {
         pattern = pat;
         return Dialog::showDialog(MAKEINTRESOURCE(IDD_CONN_HOST));
       }
-      void initDialog() {
+      void initDialog() override {
         if (pattern.empty())
           pattern = "+";
 
@@ -60,7 +60,7 @@ namespace rfb {
         setItemString(IDC_HOST_PATTERN, &pattern.c_str()[1]);
         pattern.clear();
       }
-      bool onOk() {
+      bool onOk() override {
         std::string newPat;
         if (isItemChecked(IDC_ALLOW))
           newPat = '+';
@@ -74,7 +74,7 @@ namespace rfb {
           network::TcpFilter::Pattern pat(network::TcpFilter::parsePattern(newPat.c_str()));
           pattern = network::TcpFilter::patternToStr(pat);
         } catch(rdr::Exception& e) {
-          MsgBox(NULL, e.str(), MB_ICONEXCLAMATION | MB_OK);
+          MsgBox(nullptr, e.str(), MB_ICONEXCLAMATION | MB_OK);
           return false;
         }
         return true;
@@ -87,8 +87,8 @@ namespace rfb {
     class ConnectionsPage : public PropSheetPage {
     public:
       ConnectionsPage(const RegKey& rk)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_CONNECTIONS)), regKey(rk) {}
-      void initDialog() {
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_CONNECTIONS)), regKey(rk) {}
+      void initDialog() override {
         vlog.debug("set IDC_PORT %d", (int)port_number);
         setItemInt(IDC_PORT, port_number ? port_number : 5900);
         setItemChecked(IDC_RFB_ENABLE, port_number != 0);
@@ -108,7 +108,7 @@ namespace rfb {
 
         onCommand(IDC_RFB_ENABLE, EN_CHANGE);
       }
-      bool onCommand(int id, int cmd) {
+      bool onCommand(int id, int cmd) override {
         switch (id) {
         case IDC_HOSTS:
           {
@@ -221,7 +221,7 @@ namespace rfb {
         }
         return false;
       }
-      bool onOk() {
+      bool onOk() override {
         regKey.setInt("PortNumber", isItemChecked(IDC_RFB_ENABLE) ? getItemInt(IDC_PORT) : 0);
         regKey.setInt("IdleTimeout", getItemInt(IDC_IDLE_TIMEOUT));
         regKey.setInt("LocalHost", isItemChecked(IDC_LOCALHOST));
diff --git a/win/vncconfig/Desktop.h b/win/vncconfig/Desktop.h
index d7ed0bc8b..a50583894 100644
--- a/win/vncconfig/Desktop.h
+++ b/win/vncconfig/Desktop.h
@@ -29,8 +29,8 @@ namespace rfb {
     class DesktopPage : public PropSheetPage {
     public:
       DesktopPage(const RegKey& rk)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_DESKTOP)), regKey(rk) {}
-      void initDialog() {
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_DESKTOP)), regKey(rk) {}
+      void initDialog() override {
         const char *action(rfb::win32::SDisplay::disconnectAction);
         bool disconnectLock = stricmp(action, "Lock") == 0;
         bool disconnectLogoff = stricmp(action, "Logoff") == 0;
@@ -40,7 +40,7 @@ namespace rfb {
         setItemChecked(IDC_REMOVE_WALLPAPER, rfb::win32::SDisplay::removeWallpaper);
         setItemChecked(IDC_DISABLE_EFFECTS, rfb::win32::SDisplay::disableEffects);
       }
-      bool onCommand(int id, int /*cmd*/) {
+      bool onCommand(int id, int /*cmd*/) override {
         switch (id) {
         case IDC_DISCONNECT_LOGOFF:
         case IDC_DISCONNECT_LOCK:
@@ -58,7 +58,7 @@ namespace rfb {
         }
         return false;
       }
-      bool onOk() {
+      bool onOk() override {
         const char* action = "None";
         if (isItemChecked(IDC_DISCONNECT_LOGOFF))
           action = "Logoff";
diff --git a/win/vncconfig/Hooking.h b/win/vncconfig/Hooking.h
index e775f2902..9f84230dc 100644
--- a/win/vncconfig/Hooking.h
+++ b/win/vncconfig/Hooking.h
@@ -31,15 +31,15 @@ namespace rfb {
     class HookingPage : public PropSheetPage {
     public:
       HookingPage(const RegKey& rk)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_HOOKING)), regKey(rk) {}
-      void initDialog() {
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_HOOKING)), regKey(rk) {}
+      void initDialog() override {
         setItemChecked(IDC_USEPOLLING, rfb::win32::SDisplay::updateMethod == 0);
         setItemChecked(IDC_USEHOOKS, (rfb::win32::SDisplay::updateMethod == 1));
         setItemChecked(IDC_POLLCONSOLES, rfb::win32::WMPoller::poll_console_windows);
         setItemChecked(IDC_CAPTUREBLT, rfb::win32::DeviceFrameBuffer::useCaptureBlt);
         onCommand(IDC_USEHOOKS, 0);
       }
-      bool onCommand(int id, int /*cmd*/) {
+      bool onCommand(int id, int /*cmd*/) override {
         switch (id) {
         case IDC_USEPOLLING:
         case IDC_USEHOOKS:
@@ -54,7 +54,7 @@ namespace rfb {
         }
         return false;
       }
-      bool onOk() {
+      bool onOk() override {
         if (isItemChecked(IDC_USEPOLLING))
           regKey.setInt("UpdateMethod", 0);
         if (isItemChecked(IDC_USEHOOKS))
diff --git a/win/vncconfig/Inputs.h b/win/vncconfig/Inputs.h
index a2ac5a46d..2ffdda035 100644
--- a/win/vncconfig/Inputs.h
+++ b/win/vncconfig/Inputs.h
@@ -33,9 +33,9 @@ namespace rfb {
     class InputsPage : public PropSheetPage {
     public:
       InputsPage(const RegKey& rk)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_INPUTS)),
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_INPUTS)),
           regKey(rk), enableAffectSSaver(true) {}
-      void initDialog() {
+      void initDialog() override {
         setItemChecked(IDC_ACCEPT_KEYS, rfb::Server::acceptKeyEvents);
         setItemChecked(IDC_RAW_KEYBOARD, SKeyboard::rawKeyboard);
         setItemChecked(IDC_ACCEPT_PTR, rfb::Server::acceptPointerEvents);
@@ -49,7 +49,7 @@ namespace rfb {
           enableAffectSSaver = false;
         enableItem(IDC_AFFECT_SCREENSAVER, enableAffectSSaver);
       }
-      bool onCommand(int /*id*/, int /*cmd*/) {
+      bool onCommand(int /*id*/, int /*cmd*/) override {
         BOOL inputResetsBlocked;
         SystemParametersInfo(SPI_GETBLOCKSENDINPUTRESETS, 0, &inputResetsBlocked, 0);
         setChanged((rfb::Server::acceptKeyEvents != isItemChecked(IDC_ACCEPT_KEYS)) ||
@@ -61,7 +61,7 @@ namespace rfb {
           (enableAffectSSaver && (!inputResetsBlocked != isItemChecked(IDC_AFFECT_SCREENSAVER))));
         return false;
       }
-      bool onOk() {
+      bool onOk() override {
         regKey.setBool("AcceptKeyEvents", isItemChecked(IDC_ACCEPT_KEYS));
         regKey.setBool("RawKeyboard", isItemChecked(IDC_RAW_KEYBOARD));
         regKey.setBool("AcceptPointerEvents", isItemChecked(IDC_ACCEPT_PTR));
@@ -70,7 +70,7 @@ namespace rfb {
         regKey.setBool("DisableLocalInputs", isItemChecked(IDC_DISABLE_LOCAL_INPUTS));
         if (enableAffectSSaver) {
           BOOL blocked = !isItemChecked(IDC_AFFECT_SCREENSAVER);
-          SystemParametersInfo(SPI_SETBLOCKSENDINPUTRESETS, blocked, 0, SPIF_UPDATEINIFILE | SPIF_SENDCHANGE);
+          SystemParametersInfo(SPI_SETBLOCKSENDINPUTRESETS, blocked, nullptr, SPIF_UPDATEINIFILE | SPIF_SENDCHANGE);
         }
         return true;
       }
diff --git a/win/vncconfig/Legacy.cxx b/win/vncconfig/Legacy.cxx
index 3a22bb527..1ea867fb9 100644
--- a/win/vncconfig/Legacy.cxx
+++ b/win/vncconfig/Legacy.cxx
@@ -53,7 +53,7 @@ void LegacyPage::LoadPrefs()
         try {
           winvnc3.openKey(HKEY_LOCAL_MACHINE, "Software\\ORL\\WinVNC3");
           int debugMode = winvnc3.getInt("DebugMode", 0);
-          const char* debugTarget = 0; 
+          const char* debugTarget = nullptr;
           if (debugMode & 2) debugTarget = "file";
           if (debugMode & 4) debugTarget = "stderr";
           if (debugTarget) {
@@ -115,7 +115,7 @@ void LegacyPage::LoadPrefs()
               // Finally, save the Hosts value
               regKey.setString("Hosts", newHosts.c_str());
             } catch (rdr::Exception&) {
-              MsgBox(0, "Unable to convert AuthHosts setting to Hosts format.",
+              MsgBox(nullptr, "Unable to convert AuthHosts setting to Hosts format.",
                      MB_ICONWARNING | MB_OK);
             }
           } else {
@@ -181,7 +181,7 @@ void LegacyPage::LoadPrefs()
       {
         regKey.setInt("PortNumber", key.getBool("SocketConnect") ? key.getInt("PortNumber", 5900) : 0);
         if (key.getBool("AutoPortSelect", false)) {
-          MsgBox(0, "The AutoPortSelect setting is not supported by this release."
+          MsgBox(nullptr, "The AutoPortSelect setting is not supported by this release."
                     "The port number will default to 5900.",
                     MB_ICONWARNING | MB_OK);
           regKey.setInt("PortNumber", 5900);
@@ -193,7 +193,7 @@ void LegacyPage::LoadPrefs()
 
         if (key.getInt("QuerySetting", 2) != 2) {
           regKey.setBool("QueryConnect", key.getInt("QuerySetting") > 2);
-          MsgBox(0, "The QuerySetting option has been replaced by QueryConnect."
+          MsgBox(nullptr, "The QuerySetting option has been replaced by QueryConnect."
                  "Please see the documentation for details of the QueryConnect option.",
                  MB_ICONWARNING | MB_OK);
         }
@@ -222,9 +222,9 @@ void LegacyPage::LoadPrefs()
         regKey.setBool("UseHooks", !key.getBool("PollFullScreen", false));
 
         if (key.isValue("AllowShutdown"))
-          MsgBox(0, "The AllowShutdown option is not supported by this release.", MB_ICONWARNING | MB_OK);
+          MsgBox(nullptr, "The AllowShutdown option is not supported by this release.", MB_ICONWARNING | MB_OK);
         if (key.isValue("AllowEditClients"))
-          MsgBox(0, "The AllowEditClients option is not supported by this release.", MB_ICONWARNING | MB_OK);
+          MsgBox(nullptr, "The AllowEditClients option is not supported by this release.", MB_ICONWARNING | MB_OK);
 
         allowProperties = key.getBool("AllowProperties", allowProperties);
       }
diff --git a/win/vncconfig/Legacy.h b/win/vncconfig/Legacy.h
index 884a151a8..47bec7d6f 100644
--- a/win/vncconfig/Legacy.h
+++ b/win/vncconfig/Legacy.h
@@ -35,21 +35,21 @@ namespace rfb {
     class LegacyPage : public PropSheetPage {
     public:
       LegacyPage(const RegKey& rk, bool userSettings_)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_LEGACY)), regKey(rk), userSettings(userSettings_) {}
-      void initDialog() {
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_LEGACY)), regKey(rk), userSettings(userSettings_) {}
+      void initDialog() override {
         setItemChecked(IDC_PROTOCOL_3_3, rfb::Server::protocol3_3);
       }
-      bool onCommand(int id, int /*cmd*/) {
+      bool onCommand(int id, int /*cmd*/) override {
         switch (id) {
         case IDC_LEGACY_IMPORT:
           {
-            DWORD result = MsgBox(0,
+            DWORD result = MsgBox(nullptr,
               "Importing your legacy VNC 3.3 settings will overwrite your existing settings.\n"
               "Are you sure you wish to continue?",
               MB_ICONWARNING | MB_YESNO);
             if (result == IDYES) {
               LoadPrefs();
-              MsgBox(0, "Imported VNC 3.3 settings successfully.",
+              MsgBox(nullptr, "Imported VNC 3.3 settings successfully.",
                      MB_ICONINFORMATION | MB_OK);
 
               // Sleep to allow RegConfig thread to reload settings
@@ -64,7 +64,7 @@ namespace rfb {
         };
         return false;
       }
-      bool onOk() {
+      bool onOk() override {
         regKey.setBool("Protocol3.3", isItemChecked(IDC_PROTOCOL_3_3));
         return true;
       }
diff --git a/win/vncconfig/PasswordDialog.cxx b/win/vncconfig/PasswordDialog.cxx
index f35aeb54d..8a7103ca7 100644
--- a/win/vncconfig/PasswordDialog.cxx
+++ b/win/vncconfig/PasswordDialog.cxx
@@ -25,7 +25,7 @@ using namespace rfb;
 using namespace win32;
 
 PasswordDialog::PasswordDialog(const RegKey& rk, bool registryInsecure_)
-  : Dialog(GetModuleHandle(0)), regKey(rk), registryInsecure(registryInsecure_) {
+  : Dialog(GetModuleHandle(nullptr)), regKey(rk), registryInsecure(registryInsecure_) {
 }
 
 bool PasswordDialog::showDialog(HWND owner) {
@@ -36,12 +36,12 @@ bool PasswordDialog::onOk() {
   std::string password1(getItemString(IDC_PASSWORD1));
   std::string password2(getItemString(IDC_PASSWORD2));
   if (password1 != password2) {
-    MsgBox(0, "The supplied passwords do not match",
+    MsgBox(nullptr, "The supplied passwords do not match",
            MB_ICONEXCLAMATION | MB_OK);
     return false;
   }
   if (registryInsecure &&
-      (MsgBox(0, "Please note that your password cannot be stored securely on this system.  "
+      (MsgBox(nullptr, "Please note that your password cannot be stored securely on this system.  "
                  "Are you sure you wish to continue?",
               MB_YESNO | MB_ICONWARNING) == IDNO))
     return false;
diff --git a/win/vncconfig/PasswordDialog.h b/win/vncconfig/PasswordDialog.h
index dd23f8e30..06973bb90 100644
--- a/win/vncconfig/PasswordDialog.h
+++ b/win/vncconfig/PasswordDialog.h
@@ -27,8 +27,8 @@ namespace rfb {
     class PasswordDialog : public Dialog {
     public:
       PasswordDialog(const RegKey& rk, bool registryInsecure_);
-      bool showDialog(HWND owner=0);
-      bool onOk();
+      bool showDialog(HWND owner=nullptr);
+      bool onOk() override;
     protected:
       const RegKey& regKey;
       bool registryInsecure;
diff --git a/win/vncconfig/Sharing.h b/win/vncconfig/Sharing.h
index 0a2bbe40d..a6459e5f8 100644
--- a/win/vncconfig/Sharing.h
+++ b/win/vncconfig/Sharing.h
@@ -29,20 +29,20 @@ namespace rfb {
     class SharingPage : public PropSheetPage {
     public:
       SharingPage(const RegKey& rk)
-        : PropSheetPage(GetModuleHandle(0), MAKEINTRESOURCE(IDD_SHARING)), regKey(rk) {}
-      void initDialog() {
+        : PropSheetPage(GetModuleHandle(nullptr), MAKEINTRESOURCE(IDD_SHARING)), regKey(rk) {}
+      void initDialog() override {
         setItemChecked(IDC_DISCONNECT_CLIENTS, rfb::Server::disconnectClients);
         setItemChecked(IDC_SHARE_NEVER, rfb::Server::neverShared);
         setItemChecked(IDC_SHARE_ALWAYS, rfb::Server::alwaysShared);
         setItemChecked(IDC_SHARE_CLIENT, !(rfb::Server::neverShared || rfb::Server::alwaysShared));
       }
-      bool onCommand(int /*id*/, int /*cmd*/) {
+      bool onCommand(int /*id*/, int /*cmd*/) override {
         setChanged((isItemChecked(IDC_DISCONNECT_CLIENTS) != rfb::Server::disconnectClients) ||
           (isItemChecked(IDC_SHARE_NEVER) != rfb::Server::neverShared) ||
           (isItemChecked(IDC_SHARE_ALWAYS) != rfb::Server::alwaysShared));
         return true;
       }
-      bool onOk() {
+      bool onOk() override {
         regKey.setBool("DisconnectClients", isItemChecked(IDC_DISCONNECT_CLIENTS));
         regKey.setBool("AlwaysShared", isItemChecked(IDC_SHARE_ALWAYS));
         regKey.setBool("NeverShared", isItemChecked(IDC_SHARE_NEVER));
diff --git a/win/vncconfig/vncconfig.cxx b/win/vncconfig/vncconfig.cxx
index 2b7eaa1e9..b8cb5dc83 100644
--- a/win/vncconfig/vncconfig.cxx
+++ b/win/vncconfig/vncconfig.cxx
@@ -84,9 +84,8 @@ int WINAPI WinMain(HINSTANCE inst, HINSTANCE /*prev*/, char* /*cmdLine*/, int /*
   freopen("CONIN$","rb",stdin);
   freopen("CONOUT$","wb",stdout);
   freopen("CONOUT$","wb",stderr);
-  setbuf(stderr, 0);
+  setbuf(stderr, nullptr);
   initStdIOLoggers();
-  LogWriter vlog("main");
   logParams.setParam("*:stderr:100");
   vlog.info("Starting vncconfig applet");
 #endif
@@ -130,7 +129,7 @@ int WINAPI WinMain(HINSTANCE inst, HINSTANCE /*prev*/, char* /*cmdLine*/, int /*
         // Something weird happens on NT 4.0 SP5 but I can't reproduce it on other
         // NT 4.0 service pack revisions.
         if (e.err == ERROR_INVALID_PARAMETER) {
-          MsgBox(0, "Windows reported an error trying to secure the VNC Server settings for this user.  "
+          MsgBox(nullptr, "Windows reported an error trying to secure the VNC Server settings for this user.  "
                     "Your settings may not be secure!", MB_ICONWARNING | MB_OK);
         } else if (e.err != ERROR_CALL_NOT_IMPLEMENTED &&
                    e.err != ERROR_NOT_LOGGED_ON) {
@@ -166,14 +165,14 @@ int WINAPI WinMain(HINSTANCE inst, HINSTANCE /*prev*/, char* /*cmdLine*/, int /*
 
 #ifdef _DEBUG
       vlog.debug("capture dialogs=%s", captureDialogs ? "true" : "false");
-      sheet.showPropSheet(0, true, false, captureDialogs);
+      sheet.showPropSheet(nullptr, true, false, captureDialogs);
 #else
-      sheet.showPropSheet(0, true, false);
+      sheet.showPropSheet(nullptr, true, false);
 #endif
     } catch (rdr::SystemException& e) {
       switch (e.err) {
       case ERROR_ACCESS_DENIED:
-        MsgBox(0, "You do not have sufficient access rights to run the VNC Configuration applet",
+        MsgBox(nullptr, "You do not have sufficient access rights to run the VNC Configuration applet",
                MB_ICONSTOP | MB_OK);
         return 1;
       };
@@ -181,7 +180,7 @@ int WINAPI WinMain(HINSTANCE inst, HINSTANCE /*prev*/, char* /*cmdLine*/, int /*
     }
 
   } catch (rdr::Exception& e) {
-    MsgBox(NULL, e.str(), MB_ICONEXCLAMATION | MB_OK);
+    MsgBox(nullptr, e.str(), MB_ICONEXCLAMATION | MB_OK);
     return 1;
   }
 
diff --git a/win/winvnc/AddNewClientDialog.h b/win/winvnc/AddNewClientDialog.h
index 44e15e708..ad34ec239 100644
--- a/win/winvnc/AddNewClientDialog.h
+++ b/win/winvnc/AddNewClientDialog.h
@@ -28,7 +28,7 @@ namespace winvnc {
 
   class AddNewClientDialog : public rfb::win32::Dialog {
   public:
-    AddNewClientDialog() : Dialog(GetModuleHandle(0)) {}
+    AddNewClientDialog() : Dialog(GetModuleHandle(nullptr)) {}
     // - Show the dialog and return true if OK was clicked,
     //   false in case of error or Cancel
     virtual bool showDialog() {
@@ -38,11 +38,11 @@ namespace winvnc {
   protected:
 
     // Dialog methods (protected)
-    virtual void initDialog() {
+    void initDialog() override {
       if (!hostName.empty())
         setItemString(IDC_HOST, hostName.c_str());
     }
-    virtual bool onOk() {
+    bool onOk() override {
       hostName = getItemString(IDC_HOST);
       return true;
     }
diff --git a/win/winvnc/ControlPanel.cxx b/win/winvnc/ControlPanel.cxx
index 1b3c40eb9..6c593c45d 100644
--- a/win/winvnc/ControlPanel.cxx
+++ b/win/winvnc/ControlPanel.cxx
@@ -16,7 +16,7 @@ using namespace winvnc;
 
 bool ControlPanel::showDialog()
 {
-  return Dialog::showDialog(MAKEINTRESOURCE(IDD_CONTROL_PANEL), NULL);
+  return Dialog::showDialog(MAKEINTRESOURCE(IDD_CONTROL_PANEL), nullptr);
 }
 
 void ControlPanel::initDialog()
@@ -118,7 +118,7 @@ BOOL ControlPanel::dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM /*lPara
   case WM_COMMAND:
     switch (LOWORD(wParam)) {
     case IDCANCEL:
-      handle = NULL;
+      handle = nullptr;
       EndDialog(hwnd, 0);
       return TRUE;
     default:
@@ -145,7 +145,7 @@ void ControlPanel::SendCommand(DWORD command, int data)
   COPYDATASTRUCT copyData;
   copyData.dwData = command;
   copyData.cbData = 0;
-  copyData.lpData = 0;
+  copyData.lpData = nullptr;
   getSelConnInfo();
   if (data != -1) {
     ListConnStatus.Copy(&ListSelConn);
diff --git a/win/winvnc/ControlPanel.h b/win/winvnc/ControlPanel.h
index f64a60813..23aff0a57 100644
--- a/win/winvnc/ControlPanel.h
+++ b/win/winvnc/ControlPanel.h
@@ -20,12 +20,12 @@ namespace winvnc {
   
   class ControlPanel : rfb::win32::Dialog, rfb::win32::ListViewControl {
   public:
-    ControlPanel(HWND hSTIcon) : Dialog(GetModuleHandle(0)), ListViewControl(){
+    ControlPanel(HWND hSTIcon) : Dialog(GetModuleHandle(nullptr)), ListViewControl(){
       m_hSTIcon = hSTIcon;
       stop_updating = false;
     };
     virtual bool showDialog();
-    virtual void initDialog();
+    void initDialog() override;
     virtual bool onCommand(int cmd);
     void UpdateListView(ListConnInfo* LCInfo);
     HWND GetHandle() {return handle;};
@@ -33,7 +33,7 @@ namespace winvnc {
     ~ControlPanel();
     ListConnInfo ListConnStatus;
   protected: 
-    virtual BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
+    BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam) override;
     void getSelConnInfo();
     HWND m_hSTIcon;
     ListConnInfo ListConn;
diff --git a/win/winvnc/ManagedListener.cxx b/win/winvnc/ManagedListener.cxx
index 1a278678b..adc074cf5 100644
--- a/win/winvnc/ManagedListener.cxx
+++ b/win/winvnc/ManagedListener.cxx
@@ -31,7 +31,7 @@ static LogWriter vlog("ManagedListener");
 
 
 ManagedListener::ManagedListener(SocketManager* mgr)
-: filter(0), manager(mgr), addrChangeNotifier(0), server(0), port(0), localOnly(false) {
+: filter(nullptr), manager(mgr), addrChangeNotifier(nullptr), server(nullptr), port(0), localOnly(false) {
 }
 
 ManagedListener::~ManagedListener() {
@@ -98,7 +98,7 @@ void ManagedListener::refresh() {
       if (localOnly)
         network::createLocalTcpListeners(&sockets, port);
       else
-        network::createTcpListeners(&sockets, NULL, port);
+        network::createTcpListeners(&sockets, nullptr, port);
     }
   } catch (rdr::Exception& e) {
     vlog.error("%s", e.str());
diff --git a/win/winvnc/QueryConnectDialog.cxx b/win/winvnc/QueryConnectDialog.cxx
index 26bd93310..bedfe5a92 100644
--- a/win/winvnc/QueryConnectDialog.cxx
+++ b/win/winvnc/QueryConnectDialog.cxx
@@ -44,7 +44,7 @@ static IntParameter timeout("QueryConnectTimeout",
 QueryConnectDialog::QueryConnectDialog(network::Socket* sock_,
                                        const char* userName_,
                                        VNCServerWin32* s)
-: Dialog(GetModuleHandle(0)),
+: Dialog(GetModuleHandle(nullptr)),
   sock(sock_), peerIp(sock->getPeerAddress()), userName(userName_),
   approve(false), server(s) {
 }
@@ -73,7 +73,7 @@ void QueryConnectDialog::worker() {
 // - Dialog overrides
 
 void QueryConnectDialog::initDialog() {
-  if (!SetTimer(handle, 1, 1000, 0))
+  if (!SetTimer(handle, 1, 1000, nullptr))
     throw rdr::SystemException("SetTimer", GetLastError());
   setItemString(IDC_QUERY_HOST, peerIp.c_str());
   if (userName.empty())
diff --git a/win/winvnc/QueryConnectDialog.h b/win/winvnc/QueryConnectDialog.h
index 36e885f9d..332e7439a 100644
--- a/win/winvnc/QueryConnectDialog.h
+++ b/win/winvnc/QueryConnectDialog.h
@@ -39,11 +39,11 @@ namespace winvnc {
     bool isAccepted() const {return approve;}
   protected:
     // Thread methods
-    virtual void worker();
+    void worker() override;
 
     // Dialog methods (protected)
-    virtual void initDialog();
-    virtual BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
+    void initDialog() override;
+    BOOL dialogProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam) override;
 
     // Custom internal methods
     void setCountdownLabel();
diff --git a/win/winvnc/STrayIcon.cxx b/win/winvnc/STrayIcon.cxx
index e70329980..d703f47a0 100644
--- a/win/winvnc/STrayIcon.cxx
+++ b/win/winvnc/STrayIcon.cxx
@@ -80,13 +80,13 @@ class STrayIcon : public TrayIcon {
     SetWindowText(getHandle(), "winvnc::IPC_Interface");
     // ***
 
-    SetTimer(getHandle(), 1, 3000, 0);
+    SetTimer(getHandle(), 1, 3000, nullptr);
     PostMessage(getHandle(), WM_TIMER, 1, 0);
     PostMessage(getHandle(), WM_SET_TOOLTIP, 0, 0);
     CPanel = new ControlPanel(getHandle());
   }
 
-  virtual LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) {
+  LRESULT processMessage(UINT msg, WPARAM wParam, LPARAM lParam) override {
     switch(msg) {
 
     case WM_USER:
@@ -100,7 +100,7 @@ class STrayIcon : public TrayIcon {
           SendMessage(getHandle(), WM_COMMAND, ID_CONTR0L_PANEL, 0);
           break;
         case WM_RBUTTONUP:
-          HMENU menu = LoadMenu(GetModuleHandle(0), MAKEINTRESOURCE(thread.menu));
+          HMENU menu = LoadMenu(GetModuleHandle(nullptr), MAKEINTRESOURCE(thread.menu));
           HMENU trayMenu = GetSubMenu(menu, 0);
 
 
@@ -123,7 +123,7 @@ class STrayIcon : public TrayIcon {
           // Display the menu
           POINT pos;
           GetCursorPos(&pos);
-          TrackPopupMenu(trayMenu, 0, pos.x, pos.y, 0, getHandle(), 0);
+          TrackPopupMenu(trayMenu, 0, pos.x, pos.y, 0, getHandle(), nullptr);
 
           break;
 		} 
@@ -154,13 +154,13 @@ class STrayIcon : public TrayIcon {
         thread.server.disconnectClients("tray menu disconnect");
         break;
       case ID_CLOSE:
-        if (MsgBox(0, "Are you sure you want to close the server?",
+        if (MsgBox(nullptr, "Are you sure you want to close the server?",
                    MB_ICONQUESTION | MB_YESNO | MB_DEFBUTTON2) == IDYES) {
           if (isServiceProcess()) {
             try {
               rfb::win32::stopService(VNCServerService::Name);
             } catch (rdr::Exception& e) {
-              MsgBox(0, e.str(), MB_ICONERROR | MB_OK);
+              MsgBox(nullptr, e.str(), MB_ICONERROR | MB_OK);
             }
           } else {
             thread.server.stop();
@@ -239,7 +239,7 @@ class STrayIcon : public TrayIcon {
 
 STrayIconThread::STrayIconThread(VNCServerWin32& sm, UINT inactiveIcon_, UINT activeIcon_, 
                                  UINT dis_inactiveIcon_, UINT dis_activeIcon_, UINT menu_)
-: thread_id(-1), windowHandle(0), server(sm),
+: thread_id(-1), windowHandle(nullptr), server(sm),
   inactiveIcon(inactiveIcon_), activeIcon(activeIcon_),
   dis_inactiveIcon(dis_inactiveIcon_), dis_activeIcon(dis_activeIcon_),
   menu(menu_), runTrayIcon(true) {
@@ -266,12 +266,12 @@ void STrayIconThread::worker() {
     windowHandle = icon.getHandle();
 
     MSG msg;
-    while (runTrayIcon && ::GetMessage(&msg, 0, 0, 0) > 0) {
+    while (runTrayIcon && ::GetMessage(&msg, nullptr, 0, 0) > 0) {
       TranslateMessage(&msg);
       DispatchMessage(&msg);
     }
 
-    windowHandle = 0;
+    windowHandle = nullptr;
   }
 }
 
diff --git a/win/winvnc/STrayIcon.h b/win/winvnc/STrayIcon.h
index 511c3ae21..1aa7bfbc9 100644
--- a/win/winvnc/STrayIcon.h
+++ b/win/winvnc/STrayIcon.h
@@ -42,7 +42,7 @@ namespace winvnc {
 
     friend class STrayIcon;
   protected:
-    virtual void worker();
+    void worker() override;
 
     os::Mutex* lock;
     DWORD thread_id;
diff --git a/win/winvnc/VNCServerService.cxx b/win/winvnc/VNCServerService.cxx
index 09a0707b0..8ae4b747a 100644
--- a/win/winvnc/VNCServerService.cxx
+++ b/win/winvnc/VNCServerService.cxx
@@ -38,18 +38,18 @@ using namespace win32;
 const char* winvnc::VNCServerService::Name = "TigerVNC";
 
 // SendSAS is not available until Windows 7, and missing from MinGW
-static HMODULE sasLibrary = NULL;
+static HMODULE sasLibrary = nullptr;
 typedef void WINAPI (*SendSAS_proto)(BOOL AsUser);
-static SendSAS_proto _SendSAS = NULL;
+static SendSAS_proto _SendSAS = nullptr;
 
 VNCServerService::VNCServerService()
   : Service(Name)
-  , stopServiceEvent(CreateEvent(0, FALSE, FALSE, 0))
-  , sessionEvent(CreateEvent(0, FALSE, FALSE, "Global\\SessionEventTigerVNC"))
-  , sessionEventCad(CreateEvent(0, FALSE, FALSE, "Global\\SessionEventTigerVNCCad")) {
-  if (sasLibrary == NULL) {
+  , stopServiceEvent(CreateEvent(nullptr, FALSE, FALSE, nullptr))
+  , sessionEvent(CreateEvent(nullptr, FALSE, FALSE, "Global\\SessionEventTigerVNC"))
+  , sessionEventCad(CreateEvent(nullptr, FALSE, FALSE, "Global\\SessionEventTigerVNCCad")) {
+  if (sasLibrary == nullptr) {
     sasLibrary = LoadLibrary("sas.dll");
-    if (sasLibrary != NULL)
+    if (sasLibrary != nullptr)
       _SendSAS = (SendSAS_proto)(void*)GetProcAddress(sasLibrary, "SendSAS");
   }
   // - Set the service-mode logging defaults
@@ -104,8 +104,8 @@ BOOL GetSessionUserTokenWin(OUT LPHANDLE lphUserToken)
 // START the app as system 
 HANDLE LaunchProcessWin(DWORD /*dwSessionId*/)
 {
-    HANDLE hProcess = NULL;
-    HANDLE hToken = NULL;
+    HANDLE hProcess = nullptr;
+    HANDLE hToken = nullptr;
     if (GetSessionUserTokenWin(&hToken))
     {
         ModuleFileName filename;
@@ -116,9 +116,9 @@ HANDLE LaunchProcessWin(DWORD /*dwSessionId*/)
         si.cb = sizeof si;
         si.dwFlags = STARTF_USESHOWWINDOW;
         PROCESS_INFORMATION	pi;
-        if (CreateProcessAsUser(hToken, NULL, (char*)cmdLine.c_str(),
-                                NULL, NULL, FALSE, DETACHED_PROCESS,
-                                NULL, NULL, &si, &pi))
+        if (CreateProcessAsUser(hToken, nullptr, (char*)cmdLine.c_str(),
+                                nullptr, nullptr, FALSE, DETACHED_PROCESS,
+                                nullptr, nullptr, &si, &pi))
         {
             CloseHandle(pi.hThread);
             hProcess = pi.hProcess;
@@ -132,7 +132,7 @@ DWORD VNCServerService::serviceMain(int /*argc*/, char* /*argv*/ [])
 {
     ConsoleSessionId OlddwSessionId;
 
-    HANDLE hProcess = NULL;
+    HANDLE hProcess = nullptr;
     //We use this event to notify the program that the session has changed
     //The program need to end so the service can restart the program in the correct session
     //wait_for_existing_process();
@@ -150,7 +150,7 @@ DWORD VNCServerService::serviceMain(int /*argc*/, char* /*argv*/ [])
 
         //cad request
         case WAIT_OBJECT_0 + 1:
-            if (_SendSAS != NULL)
+            if (_SendSAS != nullptr)
                 _SendSAS(FALSE);
             break; 
 
@@ -163,7 +163,7 @@ DWORD VNCServerService::serviceMain(int /*argc*/, char* /*argv*/ [])
                     SetEvent(sessionEvent);
                 }
                 DWORD dwExitCode = 0;
-                if (hProcess == NULL ||
+                if (hProcess == nullptr ||
                     (GetExitCodeProcess(hProcess, &dwExitCode) &&
                     dwExitCode != STILL_ACTIVE &&
                     CloseHandle(hProcess)))
diff --git a/win/winvnc/VNCServerService.h b/win/winvnc/VNCServerService.h
index cae448685..3992bc913 100644
--- a/win/winvnc/VNCServerService.h
+++ b/win/winvnc/VNCServerService.h
@@ -28,8 +28,8 @@ namespace winvnc {
   public:
     VNCServerService();
 
-    DWORD serviceMain(int argc, char* argv[]);
-    void stop();
+    DWORD serviceMain(int argc, char* argv[]) override;
+    void stop() override;
 
     static const char* Name;
   protected:
diff --git a/win/winvnc/VNCServerWin32.cxx b/win/winvnc/VNCServerWin32.cxx
index 38b2ef16e..140d82ad1 100644
--- a/win/winvnc/VNCServerWin32.cxx
+++ b/win/winvnc/VNCServerWin32.cxx
@@ -61,13 +61,13 @@ static BoolParameter showTrayIcon("ShowTrayIcon",
 
 VNCServerWin32::VNCServerWin32()
   : command(NoCommand),
-    commandEvent(CreateEvent(0, TRUE, FALSE, 0)),
+    commandEvent(CreateEvent(nullptr, TRUE, FALSE, nullptr)),
     sessionEvent(isServiceProcess() ?
-      CreateEvent(0, FALSE, FALSE, "Global\\SessionEventTigerVNC") : 0),
+      CreateEvent(nullptr, FALSE, FALSE, "Global\\SessionEventTigerVNC") : nullptr),
     vncServer(ComputerName().buf, &desktop),
     thread_id(-1), runServer(false), isDesktopStarted(false),
-    config(&sockMgr), rfbSock(&sockMgr), trayIcon(0),
-    queryConnectDialog(0)
+    config(&sockMgr), rfbSock(&sockMgr), trayIcon(nullptr),
+    queryConnectDialog(nullptr)
 {
   commandLock = new os::Mutex;
   commandSig = new os::Condition(commandLock);
@@ -92,7 +92,7 @@ VNCServerWin32::~VNCServerWin32() {
   delete trayIcon;
 
   // Stop the SDisplay from updating our state
-  desktop.setStatusLocation(0);
+  desktop.setStatusLocation(nullptr);
 
   // Join the Accept/Reject dialog thread
   if (queryConnectDialog) {
@@ -179,15 +179,14 @@ int VNCServerWin32::run() {
   // - Set the address-changed handler for the RFB socket
   rfbSock.setAddressChangeNotifier(this);
 
-  DWORD result = 0;
+  int result = 0;
   try {
     vlog.debug("Entering message loop");
 
     // - Run the server until we're told to quit
     MSG msg;
-    int result = 0;
     while (runServer) {
-      result = sockMgr.getMessage(&msg, NULL, 0, 0);
+      result = sockMgr.getMessage(&msg, nullptr, 0, 0);
       if (result < 0)
         throw rdr::SystemException("getMessage", GetLastError());
       if (!isServiceProcess() && (result == 0))
@@ -226,7 +225,7 @@ bool VNCServerWin32::disconnectClients(const char* reason) {
 }
 
 bool VNCServerWin32::addNewClient(const char* client) {
-  TcpSocket* sock = 0;
+  TcpSocket* sock = nullptr;
   try {
     std::string hostname;
     int port;
@@ -254,7 +253,7 @@ void VNCServerWin32::queryConnection(network::Socket* sock,
                                      const char* userName)
 {
   if (queryOnlyIfLoggedOn && CurrentUserToken().noUserLoggedOn()) {
-    vncServer.approveConnection(sock, true, NULL);
+    vncServer.approveConnection(sock, true, nullptr);
     return;
   }
   if (queryConnectDialog) {
@@ -266,7 +265,7 @@ void VNCServerWin32::queryConnection(network::Socket* sock,
 }
 
 void VNCServerWin32::queryConnectionComplete() {
-  queueCommand(QueryConnectionComplete, 0, 0, false);
+  queueCommand(QueryConnectionComplete, nullptr, 0, false);
 }
 
 
@@ -324,7 +323,7 @@ void VNCServerWin32::processEvent(HANDLE event_) {
                                   "Connection rejected by user");
       queryConnectDialog->wait();
       delete queryConnectDialog;
-      queryConnectDialog = 0;
+      queryConnectDialog = nullptr;
       break;
 
     default:
@@ -396,7 +395,7 @@ void VNCServerWin32::setConnStatus(ListConnInfo* listConn)
 
     status = listConn->iGetStatus();
     if (status == 3) {
-      conn->close(0);
+      conn->close(nullptr);
     } else {
       rfb::AccessRights ar;
 
diff --git a/win/winvnc/VNCServerWin32.h b/win/winvnc/VNCServerWin32.h
index 0a2c330c7..493b3fa6f 100644
--- a/win/winvnc/VNCServerWin32.h
+++ b/win/winvnc/VNCServerWin32.h
@@ -64,7 +64,7 @@ namespace winvnc {
 
     // Disconnect all connected clients
     // THREAD-SAFE
-    bool disconnectClients(const char* reason=0);
+    bool disconnectClients(const char* reason=nullptr);
 
     // Call used to notify VNCServerST of user accept/reject query completion
     // CALLED FROM AcceptConnectDialog THREAD
@@ -81,20 +81,20 @@ namespace winvnc {
     // QueryConnectionHandler interface
     // Callback used to prompt user to accept or reject a connection.
     // CALLBACK IN VNCServerST "HOST" THREAD
-    virtual void queryConnection(network::Socket* sock,
-                                 const char* userName);
+    void queryConnection(network::Socket* sock,
+                         const char* userName) override;
 
     // SocketManager::AddressChangeNotifier interface
     // Used to keep tray icon up to date
-    virtual void processAddressChange();
+    void processAddressChange() override;
 
     // RegConfig::Callback interface
     // Called via the EventManager whenever RegConfig sees the registry change
-    virtual void regConfigChanged();
+    void regConfigChanged() override;
 
     // EventHandler interface
     // Used to perform queued commands
-    virtual void processEvent(HANDLE event);
+    void processEvent(HANDLE event) override;
 
     void getConnInfo(ListConnInfo * listConn);
     void setConnStatus(ListConnInfo* listConn);
diff --git a/win/winvnc/winvnc.cxx b/win/winvnc/winvnc.cxx
index 512464070..d612a43e0 100644
--- a/win/winvnc/winvnc.cxx
+++ b/win/winvnc/winvnc.cxx
@@ -88,7 +88,7 @@ static void programUsage() {
 
 static void MsgBoxOrLog(const char* msg, bool isError=false) {
   if (close_console) {
-    MsgBox(0, msg, (isError ? MB_ICONERROR : MB_ICONINFORMATION) | MB_OK);
+    MsgBox(nullptr, msg, (isError ? MB_ICONERROR : MB_ICONINFORMATION) | MB_OK);
   } else {
     if (isError) {
       try {
@@ -116,8 +116,8 @@ static void processParams(int argc, char** argv) {
           if (ancd.showDialog())
             host = ancd.getHostName();
         }
-        if (host != NULL) {
-          HWND hwnd = FindWindow(0, "winvnc::IPC_Interface");
+        if (host != nullptr) {
+          HWND hwnd = FindWindow(nullptr, "winvnc::IPC_Interface");
           if (!hwnd)
             throw rdr::Exception("Unable to locate existing VNC Server.");
           COPYDATASTRUCT copyData;
@@ -130,12 +130,12 @@ static void processParams(int argc, char** argv) {
         }
       } else if (strcasecmp(argv[i], "-disconnect") == 0) {
         runServer = false;
-        HWND hwnd = FindWindow(0, "winvnc::IPC_Interface");
+        HWND hwnd = FindWindow(nullptr, "winvnc::IPC_Interface");
         if (!hwnd)
           throw rdr::Exception("Unable to locate existing VNC Server.");
         COPYDATASTRUCT copyData;
         copyData.dwData = 2; // *** DisconnectClients
-        copyData.lpData = 0;
+        copyData.lpData = nullptr;
         copyData.cbData = 0;
         printf("Sending disconnect request to VNC Server...\n");
         if (!SendMessage(hwnd, WM_COPYDATA, 0, (LPARAM)&copyData))
@@ -250,7 +250,7 @@ int WINAPI WinMain(HINSTANCE /*inst*/, HINSTANCE /*prevInst*/, char* /*cmdLine*/
 	freopen("CONIN$", "rb", stdin);
 	freopen("CONOUT$", "wb", stdout);
 	freopen("CONOUT$", "wb", stderr);
-    setbuf(stderr, 0);
+    setbuf(stderr, nullptr);
 	initStdIOLoggers();
 	initFileLogger("C:\\temp\\WinVNC4.log");
 	logParams.setParam("*:stderr:100");
diff --git a/win/wm_hooks/wm_hooks.cxx b/win/wm_hooks/wm_hooks.cxx
index c864171b2..a48a17384 100644
--- a/win/wm_hooks/wm_hooks.cxx
+++ b/win/wm_hooks/wm_hooks.cxx
@@ -69,7 +69,7 @@ ATOM ATOM_Popup_Selection = GlobalAddAtom("RFB.WM_Hooks.PopupSelectionAtom");
 // -=- DLL entry point
 //
 
-HINSTANCE dll_instance = 0;
+HINSTANCE dll_instance = nullptr;
 
 BOOL WINAPI DllMain(HANDLE instance, ULONG reason, LPVOID /*reserved*/) {
   switch (reason) {
@@ -92,12 +92,12 @@ BOOL WINAPI DllMain(HANDLE instance, ULONG reason, LPVOID /*reserved*/) {
 
 DWORD hook_owner SHARED = 0;
 DWORD hook_target SHARED = 0;
-HHOOK hook_CallWndProc SHARED = 0;
-HHOOK hook_CallWndProcRet SHARED = 0;
-HHOOK hook_GetMessage SHARED = 0;
-HHOOK hook_DialogMessage SHARED = 0;
+HHOOK hook_CallWndProc SHARED = nullptr;
+HHOOK hook_CallWndProcRet SHARED = nullptr;
+HHOOK hook_GetMessage SHARED = nullptr;
+HHOOK hook_DialogMessage SHARED = nullptr;
 BOOL enable_cursor_shape SHARED = FALSE;
-HCURSOR cursor SHARED = 0;
+HCURSOR cursor SHARED = nullptr;
 #ifdef _DEBUG
 UINT diagnostic_min SHARED =1;
 UINT diagnostic_max SHARED =0;
@@ -138,8 +138,8 @@ bool NotifyRectangle(RECT* rect) {
   LPARAM l = MAKELONG((SHORT)rect->right, (SHORT)rect->bottom);
   return NotifyHookOwner(WM_HK_RectangleChanged, w, l);
 }
-bool NotifyCursor(HCURSOR cursor) {
-  return NotifyHookOwner(WM_HK_CursorChanged, 0, (LPARAM)cursor);
+bool NotifyCursor(HCURSOR cursor_) {
+  return NotifyHookOwner(WM_HK_CursorChanged, 0, (LPARAM)cursor_);
 }
 
 void ProcessWindowMessage(UINT msg, HWND wnd, WPARAM wParam, LPARAM /*lParam*/) {
@@ -252,7 +252,7 @@ void ProcessWindowMessage(UINT msg, HWND wnd, WPARAM wParam, LPARAM /*lParam*/)
 				if (buffsize != 0)
 				{
 					buff = (RGNDATA *) new BYTE [buffsize];
-					if (buff == NULL)
+					if (buff == nullptr)
 						break;
 
 					// Now get the region data
@@ -277,7 +277,7 @@ void ProcessWindowMessage(UINT msg, HWND wnd, WPARAM wParam, LPARAM /*lParam*/)
 			}
 
 			// Now free the region
-			if (region != NULL)
+			if (region != nullptr)
 				DeleteObject(region);
 		}
     */
@@ -353,19 +353,19 @@ BOOL WM_Hooks_Remove(DWORD owner) {
   if (owner != hook_owner) return FALSE;
   if (hook_CallWndProc) {
     UnhookWindowsHookEx(hook_CallWndProc);
-    hook_CallWndProc = 0;
+    hook_CallWndProc = nullptr;
   }
   if (hook_CallWndProcRet) {
     UnhookWindowsHookEx(hook_CallWndProcRet);
-    hook_CallWndProcRet = 0;
+    hook_CallWndProcRet = nullptr;
   }
   if (hook_GetMessage) {
     UnhookWindowsHookEx(hook_GetMessage);
-    hook_GetMessage = 0;
+    hook_GetMessage = nullptr;
   }
   if (hook_DialogMessage) {
     UnhookWindowsHookEx(hook_DialogMessage);
-    hook_DialogMessage = 0;
+    hook_DialogMessage = nullptr;
   }
   hook_owner = 0;
   hook_target = 0;
@@ -376,8 +376,8 @@ BOOL WM_Hooks_Remove(DWORD owner) {
 // -=- User input hooks
 //
 
-HHOOK hook_keyboard SHARED = 0;
-HHOOK hook_pointer SHARED = 0;
+HHOOK hook_keyboard SHARED = nullptr;
+HHOOK hook_pointer SHARED = nullptr;
 bool enable_real_ptr SHARED = true;
 bool enable_synth_ptr SHARED = true;
 bool enable_real_kbd SHARED = true;
@@ -414,11 +414,11 @@ bool RefreshInputHooks() {
   bool set_kbd_hook = !enable_real_kbd || !enable_synth_kbd;
   if (hook_keyboard && !set_kbd_hook) {
     UnhookWindowsHookEx(hook_keyboard);
-    hook_keyboard = 0;
+    hook_keyboard = nullptr;
   }
   if (hook_pointer && !set_ptr_hook) {
     UnhookWindowsHookEx(hook_pointer);
-    hook_pointer = 0;
+    hook_pointer = nullptr;
   }
   if (!hook_keyboard && set_kbd_hook) {
     hook_keyboard = SetWindowsHookEx(WH_KEYBOARD_LL, HookKeyboardHook, dll_instance, 0);