aboutsummaryrefslogtreecommitdiffstats
path: root/src/platforms/windows/windowsHandler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/platforms/windows/windowsHandler.cpp')
-rw-r--r--src/platforms/windows/windowsHandler.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/platforms/windows/windowsHandler.cpp b/src/platforms/windows/windowsHandler.cpp
index 1ed4025b..824589b7 100644
--- a/src/platforms/windows/windowsHandler.cpp
+++ b/src/platforms/windows/windowsHandler.cpp
@@ -29,6 +29,8 @@
#include "vmime/platforms/windows/windowsHandler.hpp"
+#include "vmime/platforms/windows/windowsCriticalSection.hpp"
+
#include <time.h>
#include <locale.h>
#include <process.h>
@@ -239,6 +241,12 @@ unsigned int windowsHandler::getProcessId() const
}
+unsigned int windowsHandler::getThreadId() cont
+{
+ return static_cast <unsigned int>(::GetCurrentThreadId());
+}
+
+
#if VMIME_HAVE_MESSAGING_FEATURES
ref <vmime::net::socketFactory> windowsHandler::getSocketFactory()
@@ -272,6 +280,21 @@ void windowsHandler::wait() const
}
+void windowsHandler::generateRandomBytes(unsigned char* buffer, const unsigned int count)
+{
+ HCRYPTPROV cryptProvider = 0;
+ CryptAcquireContext(&cryptProvider, 0, 0, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT);
+ CryptGenRandom(cryptProvider, static_cast <unsigned long>(count), static_cast <unsigned char*>(buffer));
+ CryptReleaseContext(cryptProvider, 0);
+}
+
+
+ref <utility::sync::criticalSection> posixHandler::createCriticalSection()
+{
+ return vmime::create <windowsCriticalSection>();
+}
+
+
} // posix
} // platforms
} // vmime