From 2482c26316d833803bec5a7e8df2f952f363794f Mon Sep 17 00:00:00 2001 From: Akash Mozumdar Date: Tue, 14 Jan 2020 17:24:27 -0700 Subject: [PATCH] fix issues with extensions having dot in name --- GUI/extenwindow.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/GUI/extenwindow.cpp b/GUI/extenwindow.cpp index 180dae0..8c9e8c8 100644 --- a/GUI/extenwindow.cpp +++ b/GUI/extenwindow.cpp @@ -34,7 +34,7 @@ namespace // Extension is dll and exports "OnNewSentence" if (QTextFile(extenName + ".dll", QIODevice::ReadOnly).readAll().contains("OnNewSentence")) { - if (HMODULE module = LoadLibraryW(S(extenName).c_str())) + if (HMODULE module = LoadLibraryW(S(extenName + ".dll").c_str())) { if (auto callback = (decltype(Extension::callback))GetProcAddress(module, "OnNewSentence")) { @@ -51,7 +51,7 @@ namespace void Unload(int index) { std::scoped_lock writeLock(extenMutex); - FreeLibrary(GetModuleHandleW(extensions.at(index).name.c_str())); + FreeLibrary(GetModuleHandleW((extensions.at(index).name + L".dll").c_str())); extensions.erase(extensions.begin() + index); } @@ -80,7 +80,7 @@ bool DispatchSentenceToExtensions(std::wstring& sentence, const InfoForExtension void CleanupExtensions() { std::scoped_lock writeLock(extenMutex); - for (auto extension : extensions) FreeLibrary(GetModuleHandleW(extension.name.c_str())); + for (auto extension : extensions) FreeLibrary(GetModuleHandleW((extension.name + L".dll").c_str())); extensions.clear(); }