summaryrefslogtreecommitdiff
path: root/cpp/src/Ice/DynamicLibrary.cpp
diff options
context:
space:
mode:
authorJose <jose@zeroc.com>2012-02-21 15:12:22 +0100
committerJose <jose@zeroc.com>2012-02-21 15:12:22 +0100
commita88c32a39e09573d08d5426e50cdb6bff29ad14b (patch)
tree597ef891b8165bb8458f42e44039d6fb10d002ac /cpp/src/Ice/DynamicLibrary.cpp
parentICE-4322 - Use "#pragma once" in Slice files (diff)
downloadice-a88c32a39e09573d08d5426e50cdb6bff29ad14b.tar.bz2
ice-a88c32a39e09573d08d5426e50cdb6bff29ad14b.tar.xz
ice-a88c32a39e09573d08d5426e50cdb6bff29ad14b.zip
ICE-4588 - DynamicLibrary & LoadLibraryW
Diffstat (limited to 'cpp/src/Ice/DynamicLibrary.cpp')
-rw-r--r--cpp/src/Ice/DynamicLibrary.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/cpp/src/Ice/DynamicLibrary.cpp b/cpp/src/Ice/DynamicLibrary.cpp
index 031d9942fc7..7cefbcebeea 100644
--- a/cpp/src/Ice/DynamicLibrary.cpp
+++ b/cpp/src/Ice/DynamicLibrary.cpp
@@ -9,6 +9,7 @@
#include <Ice/DynamicLibrary.h>
#include <IceUtil/StringUtil.h>
+#include <IceUtil/Unicode.h>
#ifndef _WIN32
# include <dlfcn.h>
@@ -21,8 +22,9 @@ using namespace std;
IceUtil::Shared* IceInternal::upCast(DynamicLibrary* p) { return p; }
IceUtil::Shared* IceInternal::upCast(DynamicLibraryList* p) { return p; }
-IceInternal::DynamicLibrary::DynamicLibrary()
- : _hnd(0)
+IceInternal::DynamicLibrary::DynamicLibrary(const Ice::StringConverterPtr& stringConverter) :
+ _stringConverter(stringConverter),
+ _hnd(0)
{
}
@@ -155,7 +157,7 @@ bool
IceInternal::DynamicLibrary::load(const string& lib)
{
#ifdef _WIN32
- _hnd = LoadLibrary(lib.c_str());
+ _hnd = LoadLibraryW(IceUtil::stringToWstring(nativeToUTF8(_stringConverter, lib)).c_str());
#else
int flags = RTLD_NOW | RTLD_GLOBAL;
@@ -193,7 +195,7 @@ IceInternal::DynamicLibrary::getSymbol(const string& name)
string newName = "_" + name;
symbol_type result = GetProcAddress(_hnd, newName.c_str());
# else
- symbol_type result = GetProcAddress(_hnd,name.c_str());
+ symbol_type result = GetProcAddress(_hnd, name.c_str());
# endif
#else
symbol_type result = dlsym(_hnd, name.c_str());