diff --git a/octoprint_klipper/__init__.py b/octoprint_klipper/__init__.py
index 2cf6e42..f172ad4 100644
--- a/octoprint_klipper/__init__.py
+++ b/octoprint_klipper/__init__.py
@@ -568,6 +568,30 @@ class KlipperPlugin(
dataToValidated.readfp(buf)
else:
dataToValidated.read_string(dataToBeValidated)
+
+ sections_search_list = ["bltouch",
+ "probe"]
+ value_search_list = [ "x_offset",
+ "y_offset",
+ "z_offset"]
+ try:
+ # cycle through sections and then values
+ for y in sections_search_list:
+ for x in value_search_list:
+ if dataToValidated.has_option(y, x):
+ a_float = dataToValidated.getfloat(y, x)
+ except ValueError as error:
+ self.log_error(
+ "Error: Invalid Value for "+x+" in Section: "+y+"\n" +
+ "{}".format(str(error))
+ )
+ self.send_message("PopUp", "warning", "OctoKlipper: Invalid Config\n",
+ "Config got not saved!\n" +
+ "You can reload your last changes\n" +
+ "on the 'Klipper Configuration' tab.\n\n" +
+ "Invalid Value for "+x+" in Section: "+y+"\n" + "{}".format(str(error)))
+ self._parsing_check_response = False
+ return False
except configparser.Error as error:
if sys.version_info[0] < 3:
error.message = error.message.replace("\\n","")
@@ -588,9 +612,10 @@ class KlipperPlugin(
"You can reload your last changes\n" +
"on the 'Klipper Configuration' tab.\n\n" + str(error))
self._parsing_check_response = False
+ return False
else:
self._parsing_check_response = True
- return
+ return True
#incorrectlines = []
# for section in dataToValidated.sections():