Diff

core/modulemanager.lua @ 9867:984f27e4b8a3

modulemanager: Set module status on successful or failed module load
author Matthew Wild <mwild1@gmail.com>
date Tue, 19 Mar 2019 09:05:15 +0000
parent 9563:732314eb3258
child 10250:1006739de449
line wrap: on
line diff
--- a/core/modulemanager.lua	Tue Mar 19 09:04:40 2019 +0000
+++ b/core/modulemanager.lua	Tue Mar 19 09:05:15 2019 +0000
@@ -169,6 +169,7 @@
 	local mod, err = pluginloader.load_code(module_name, nil, pluginenv);
 	if not mod then
 		log("error", "Unable to load module '%s': %s", module_name or "nil", err or "nil");
+		api_instance:set_status("error", "Failed to load (see log)");
 		return nil, err;
 	end
 
@@ -182,6 +183,7 @@
 			ok, err = call_module_method(pluginenv, "load");
 			if not ok then
 				log("warn", "Error loading module '%s' on '%s': %s", module_name, host, err or "nil");
+				api_instance:set_status("warn", "Error during load (see log)");
 			end
 		end
 		api_instance.reloading, api_instance.saved_state = nil, nil;
@@ -204,6 +206,9 @@
 	if not ok then
 		modulemap[api_instance.host][module_name] = nil;
 		log("error", "Error initializing module '%s' on '%s': %s", module_name, host, err or "nil");
+		api_instance:set_status("warn", "Error during load (see log)");
+	else
+		api_instance:set_status("core", "Loaded", false);
 	end
 	return ok and pluginenv, err;
 end