Fix updating show plan being thrown out due to dodgy equality.

This commit is contained in:
Matthew Stratford 2021-05-02 19:09:59 +01:00
parent 49f9e9d05a
commit 26240431aa

View file

@ -51,15 +51,16 @@ class StateManager:
self._log("Failed to create state file.", CRITICAL) self._log("Failed to create state file.", CRITICAL)
return return
file_raw: str
with open(self.filepath, "r") as file: with open(self.filepath, "r") as file:
file_state = file.read() file_raw = file.read()
if file_state == "": if file_raw == "":
self._log("State file is empty. Setting default state.") self._log("State file is empty. Setting default state.")
self.state = default_state self.state = default_state
else: else:
try: try:
file_state: Dict[str, Any] = json.loads(file_state) file_state: Dict[str, Any] = json.loads(file_raw)
# Turn from JSON -> PlanItem # Turn from JSON -> PlanItem
if "channel" in file_state: if "channel" in file_state:
@ -148,7 +149,8 @@ class StateManager:
state_to_update = self.state state_to_update = self.state
if key in state_to_update and index == -1 and state_to_update[key] == value: # Lists (esp show_plan) is difficult to compare. Just update anyway
if key in state_to_update and index == -1 and (not isinstance(value, list)) and state_to_update[key] == value:
# We're trying to update the state with the same value. # We're trying to update the state with the same value.
# In this case, ignore the update # In this case, ignore the update
return return