diff options
author | George Hazan <ghazan@miranda.im> | 2018-03-29 19:52:35 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2018-03-29 19:52:35 +0300 |
commit | 509b46f98375153fad4157ceb18a8999fd6294f4 (patch) | |
tree | c0e6febf5d69b10abdee27bfacc45eb739085266 | |
parent | 5890b9a61ddfbd0fe84b7db2833bc4761211ffe8 (diff) |
major clutch removed with double service mode plugins launch
-rw-r--r-- | plugins/Db3x_mmap/src/init.cpp | 2 | ||||
-rw-r--r-- | plugins/DbEditorPP/src/main.cpp | 8 | ||||
-rw-r--r-- | plugins/Import/src/main.cpp | 5 | ||||
-rw-r--r-- | src/mir_app/src/modules.cpp | 10 | ||||
-rw-r--r-- | src/mir_app/src/newplugins.cpp | 16 |
5 files changed, 14 insertions, 27 deletions
diff --git a/plugins/Db3x_mmap/src/init.cpp b/plugins/Db3x_mmap/src/init.cpp index 1cca7c767d..3e3db8301b 100644 --- a/plugins/Db3x_mmap/src/init.cpp +++ b/plugins/Db3x_mmap/src/init.cpp @@ -102,7 +102,7 @@ LBL_Error: return nullptr;
}
- if (SetServiceModePlugin(L"import") != SERVICE_ONLYDB) {
+ if (SetServiceModePlugin(L"import") != ERROR_SUCCESS) {
if (IDYES == MessageBoxW(nullptr, TranslateT(MISSING_PLUG_MSG), L"Miranda NG", MB_YESNO))
Utils_OpenUrl("https://miranda-ng.org/p/Import");
goto LBL_Error;
diff --git a/plugins/DbEditorPP/src/main.cpp b/plugins/DbEditorPP/src/main.cpp index dcb399e72f..cc855a2cfc 100644 --- a/plugins/DbEditorPP/src/main.cpp +++ b/plugins/DbEditorPP/src/main.cpp @@ -165,12 +165,10 @@ int PreShutdown(WPARAM, LPARAM) INT_PTR ServiceMode(WPARAM, LPARAM)
{
- if (!g_bServiceMode) {
- g_bServiceMode = true;
+ g_bServiceMode = true;
- IcoLibRegister();
- HookEvent(ME_DB_CONTACT_SETTINGCHANGED, DBSettingChanged);
- }
+ IcoLibRegister();
+ HookEvent(ME_DB_CONTACT_SETTINGCHANGED, DBSettingChanged);
return SERVICE_ONLYDB; // load database and then call us
}
diff --git a/plugins/Import/src/main.cpp b/plugins/Import/src/main.cpp index 2f31ed23c2..86706d178a 100644 --- a/plugins/Import/src/main.cpp +++ b/plugins/Import/src/main.cpp @@ -116,10 +116,7 @@ static int OnExit(WPARAM, LPARAM) static INT_PTR ServiceMode(WPARAM, LPARAM)
{
- if (!g_bServiceMode) {
- g_bServiceMode = true;
- return SERVICE_ONLYDB;
- }
+ g_bServiceMode = true;
ptrW wszFullName(Utils_ReplaceVarsW(L"%miranda_userdata%\\%miranda_profilename%.dat.bak"));
if (!_waccess(wszFullName, 0)) {
diff --git a/src/mir_app/src/modules.cpp b/src/mir_app/src/modules.cpp index a4730df8a6..600683eaa4 100644 --- a/src/mir_app/src/modules.cpp +++ b/src/mir_app/src/modules.cpp @@ -101,16 +101,6 @@ int LoadDefaultModules(void) pfn();
}
- switch (SetServiceModePlugin(CmdLine_GetOption(L"svc"))) {
- case SERVICE_CONTINUE: // continue loading Miranda normally
- case SERVICE_ONLYDB: // load database and go to the message cycle
- break;
- case SERVICE_MONOPOLY: // unload database and go to the message cycle
- return 0;
- default: // smth went wrong, terminating
- return 1;
- }
-
// the database will select which db plugin to use, or fail if no profile is selected
if (LoadDatabaseModule()) return 1;
diff --git a/src/mir_app/src/newplugins.cpp b/src/mir_app/src/newplugins.cpp index 192b916ab7..9a7b38ff12 100644 --- a/src/mir_app/src/newplugins.cpp +++ b/src/mir_app/src/newplugins.cpp @@ -716,18 +716,16 @@ MIR_APP_DLL(int) SetServiceModePlugin(const wchar_t *wszPluginName) {
size_t cbLen = mir_wstrlen(wszPluginName);
if (cbLen == 0)
- return SERVICE_CONTINUE;
+ return 1;
for (auto &p : servicePlugins) {
if (!wcsnicmp(p->pluginname, wszPluginName, cbLen)) {
- int res = LaunchServicePlugin(p);
- if (res == SERVICE_ONLYDB) // load it later
- plugin_service = p;
- return res;
+ plugin_service = p;
+ return 0;
}
}
- return SERVICE_CONTINUE;
+ return 2;
}
/////////////////////////////////////////////////////////////////////////////////////////
@@ -876,7 +874,11 @@ int LoadNewPluginsModuleInfos(void) enumPlugins(scanPluginsDir, 0, 0);
MuuidReplacement stdCrypt = { MIID_CRYPTO, L"stdcrypt", nullptr };
- return !LoadCorePlugin(stdCrypt);
+ if (!LoadCorePlugin(stdCrypt))
+ return 1;
+
+ SetServiceModePlugin(CmdLine_GetOption(L"svc"));
+ return 0;
}
/////////////////////////////////////////////////////////////////////////////////////////
|