diff options
Diffstat (limited to 'cpp/src')
-rw-r--r-- | cpp/src/Ice/DynamicLibrary.cpp | 10 | ||||
-rw-r--r-- | cpp/src/Ice/PluginManagerI.cpp | 3 | ||||
-rw-r--r-- | cpp/src/IceBox/ServiceManagerI.cpp | 5 |
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) { |