summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugins/Db3x_mmap/src/init.cpp2
-rw-r--r--plugins/DbEditorPP/src/main.cpp8
-rw-r--r--plugins/Import/src/main.cpp5
-rw-r--r--src/mir_app/src/modules.cpp10
-rw-r--r--src/mir_app/src/newplugins.cpp16
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;
}
/////////////////////////////////////////////////////////////////////////////////////////