summaryrefslogtreecommitdiff
path: root/cpp/src
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/src')
-rw-r--r--cpp/src/Ice/DynamicLibrary.cpp10
-rw-r--r--cpp/src/Ice/PluginManagerI.cpp3
-rw-r--r--cpp/src/IceBox/ServiceManagerI.cpp5
3 files changed, 11 insertions, 7 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());
diff --git a/cpp/src/Ice/PluginManagerI.cpp b/cpp/src/Ice/PluginManagerI.cpp
index 8f705b31ead..48aae7190e7 100644
--- a/cpp/src/Ice/PluginManagerI.cpp
+++ b/cpp/src/Ice/PluginManagerI.cpp
@@ -298,7 +298,6 @@ void
Ice::PluginManagerI::loadPlugin(const string& name, const string& pluginSpec, StringSeq& cmdArgs)
{
assert(_communicator);
-
//
// Separate the entry point from the arguments.
//
@@ -343,7 +342,7 @@ Ice::PluginManagerI::loadPlugin(const string& name, const string& pluginSpec, St
// Load the entry point symbol.
//
PluginPtr plugin;
- DynamicLibraryPtr library = new DynamicLibrary();
+ DynamicLibraryPtr library = new DynamicLibrary(IceInternal::getInstance(_communicator)->initializationData().stringConverter);
DynamicLibrary::symbol_type sym = library->loadEntryPoint(entryPoint);
if(sym == 0)
{
diff --git a/cpp/src/IceBox/ServiceManagerI.cpp b/cpp/src/IceBox/ServiceManagerI.cpp
index f5575d72504..fc760f6c68e 100644
--- a/cpp/src/IceBox/ServiceManagerI.cpp
+++ b/cpp/src/IceBox/ServiceManagerI.cpp
@@ -12,6 +12,8 @@
#include <Ice/Ice.h>
#include <Ice/DynamicLibrary.h>
#include <Ice/SliceChecksums.h>
+#include <Ice/Initialize.h>
+#include <Ice/Instance.h>
#include <IceBox/ServiceManagerI.h>
using namespace Ice;
@@ -591,7 +593,8 @@ IceBox::ServiceManagerI::start(const string& service, const string& entryPoint,
//
// Load the entry point.
//
- IceInternal::DynamicLibraryPtr library = new IceInternal::DynamicLibrary();
+ IceInternal::DynamicLibraryPtr library =
+ new IceInternal::DynamicLibrary(IceInternal::getInstance(_communicator)->initializationData().stringConverter);
IceInternal::DynamicLibrary::symbol_type sym = library->loadEntryPoint(entryPoint, false);
if(sym == 0)
{