Cast the void* handle data member to HMODULE* to keep the VC++ compiler
happy. Thanks to Henrik Bach for pointing this out.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18056 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/System/Win32/DynamicLibrary.cpp b/lib/System/Win32/DynamicLibrary.cpp
index 15730d4..b2add2f 100644
--- a/lib/System/Win32/DynamicLibrary.cpp
+++ b/lib/System/Win32/DynamicLibrary.cpp
@@ -12,6 +12,7 @@
 //===----------------------------------------------------------------------===//
 
 #include "Win32.h"
+#include <windef.h>
 
 namespace llvm {
 using namespace sys;
@@ -22,9 +23,10 @@
 //===----------------------------------------------------------------------===//
 
 DynamicLibrary::DynamicLibrary(const char*filename) : handle(0) {
-  handle = LoadLibrary(filename);
+  handle = new HMODULE;
+  *((HMODULE*)handle) = LoadLibrary(filename);
 
-  if (handle == 0) {
+  if (*((HMODULE*)handle) == 0) {
     char Buffer[100];
     // FIXME: This should use FormatMessage
     sprintf(Buffer, "Windows error code %d\n", GetLastError());
@@ -33,13 +35,15 @@
 }
 
 DynamicLibrary::~DynamicLibrary() {
-  if (handle)
-    FreeLibrary(handle);
+  assert(handle !=0 && "Invalid DynamicLibrary handle");
+  if (*((HMODULE*)handle))
+    FreeLibrary(*((HMODULE*)handle));
+  delete (HMODULE*)handle;
 }
 
 void *DynamicLibrary::GetAddressOfSymbol(const char *symbolName) {
   assert(handle !=0 && "Invalid DynamicLibrary handle");
-  return GetProcAddress(handle, symbolName);
+  return (void*) GetProcAddress(*((HMODULE*)handle), symbolName);
 }
 
 }