From 392d362e0bcdf806dcf480981dfa18cbfe428bf4 Mon Sep 17 00:00:00 2001 From: Myk Taylor Date: Tue, 14 Jan 2025 02:26:57 -0800 Subject: [PATCH] output proper error messages when plugin operations fail --- library/Core.cpp | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/library/Core.cpp b/library/Core.cpp index cddc76dbd5..94a94d748c 100644 --- a/library/Core.cpp +++ b/library/Core.cpp @@ -799,30 +799,35 @@ command_result Core::runCommand(color_ostream &con, const std::string &first_, s all = true; } } + auto ret = CR_OK; if (all) { - if (load) - plug_mgr->loadAll(); - else if (unload) - plug_mgr->unloadAll(); - else - plug_mgr->reloadAll(); - return CR_OK; + if (load && !plug_mgr->loadAll()) + ret = CR_FAILURE; + else if (unload && !plug_mgr->unloadAll()) + ret = CR_FAILURE; + else if (!plug_mgr->reloadAll()) + ret = CR_FAILURE; } for (auto p = parts.begin(); p != parts.end(); p++) { if (!p->size() || (*p)[0] == '-') continue; - if (load) - plug_mgr->load(*p); - else if (unload) - plug_mgr->unload(*p); - else - plug_mgr->reload(*p); + if (load && !plug_mgr->load(*p)) + ret = CR_FAILURE; + else if (unload && !plug_mgr->unload(*p)) + ret = CR_FAILURE; + else if (!plug_mgr->reload(*p)) + ret = CR_FAILURE; } + if (ret != CR_OK) + con.printerr("%s failed\n", first.c_str()); + return ret; } - else + else { con.printerr("%s: no arguments\n", first.c_str()); + return CR_FAILURE; + } } else if( first == "enable" || first == "disable" ) {