From ce408dc9511f567037fda413ca2c5da8702482e1 Mon Sep 17 00:00:00 2001 From: Casey Langen Date: Sat, 28 May 2016 18:36:52 -0700 Subject: [PATCH] Fixed bug in PluginFactory.cpp where plugins may not be loaded when they should be. --- src/core/plugin/PluginFactory.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/core/plugin/PluginFactory.cpp b/src/core/plugin/PluginFactory.cpp index 4b0d56806..c03804c5a 100644 --- a/src/core/plugin/PluginFactory.cpp +++ b/src/core/plugin/PluginFactory.cpp @@ -40,6 +40,7 @@ #include #include #include +#include static const std::string TAG = "PluginFactory"; static boost::mutex instanceMutex; @@ -93,7 +94,6 @@ void PluginFactory::LoadPlugins(){ std::string filename(file->path().string()); #ifdef WIN32 /* if the file ends with ".dll", we'll try to load it*/ - if (filename.substr(filename.size() - 4) == ".dll") { HMODULE dll = LoadLibrary(u8to16(filename).c_str()); @@ -115,7 +115,6 @@ void PluginFactory::LoadPlugins(){ #elif __APPLE__ if (filename.substr(filename.size() - 6) == ".dylib") { void* dll = NULL; - char* err; try { dll = dlopen(filename.c_str(), RTLD_LOCAL); @@ -125,7 +124,9 @@ void PluginFactory::LoadPlugins(){ continue; } - if (err != NULL || (err = dlerror()) != NULL) { + if (!dll) { + char *err = dlerror(); + musik::debug::err( TAG, "could not load shared library " + filename +