bltouch: Don't raise an error in verify_state()

Return the triggered state from verify_state() and update the callers
to raise the error (if needed).

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-03-29 17:50:28 -04:00
parent d6034013e7
commit 87bfa06b9e
1 changed files with 17 additions and 18 deletions

View File

@ -101,14 +101,12 @@ class BLTouchEndstopWrapper:
cmd_clock += mcu.seconds_to_clock(max(duration, MIN_CMD_TIME)) cmd_clock += mcu.seconds_to_clock(max(duration, MIN_CMD_TIME))
self.next_cmd_time = mcu.clock_to_print_time(cmd_clock) self.next_cmd_time = mcu.clock_to_print_time(cmd_clock)
return self.next_cmd_time return self.next_cmd_time
def verify_state(self, check_start_time, check_end_time, triggered, msg): def verify_state(self, check_start_time, check_end_time, triggered):
# Perform endstop check to verify bltouch reports desired state # Perform endstop check to verify bltouch reports desired state
self.mcu_endstop.home_start(check_start_time, ENDSTOP_SAMPLE_TIME, self.mcu_endstop.home_start(check_start_time, ENDSTOP_SAMPLE_TIME,
ENDSTOP_SAMPLE_COUNT, ENDSTOP_REST_TIME, ENDSTOP_SAMPLE_COUNT, ENDSTOP_REST_TIME,
triggered=triggered) triggered=triggered)
did_trigger = self.mcu_endstop.home_wait(check_end_time) return self.mcu_endstop.home_wait(check_end_time)
if not did_trigger:
raise homing.EndstopError("BLTouch failed to %s" % (msg,))
def raise_probe(self): def raise_probe(self):
for retry in range(3): for retry in range(3):
self.sync_mcu_print_time() self.sync_mcu_print_time()
@ -117,18 +115,18 @@ class BLTouchEndstopWrapper:
check_start_time = self.send_cmd('pin_up', check_start_time = self.send_cmd('pin_up',
duration=self.pin_move_time) duration=self.pin_move_time)
check_end_time = self.send_cmd(None) check_end_time = self.send_cmd(None)
if self.pin_up_not_triggered: if not self.pin_up_not_triggered:
try: # No way to verify - return successfully
self.verify_state(check_start_time, check_end_time, break
False, "raise probe") success = self.verify_state(check_start_time, check_end_time, False)
except homing.CommandError as e: if success:
if retry >= 2: # The "probe raised" test completed successfully
raise break
msg = "Failed to verify BLTouch probe is raised; retrying." if retry >= 2:
self.gcode.respond_info(msg) raise homing.EndstopError("BLTouch failed to raise probe")
self.next_cmd_time += RETRY_RESET_TIME msg = "Failed to verify BLTouch probe is raised; retrying."
continue self.gcode.respond_info(msg)
break self.next_cmd_time += RETRY_RESET_TIME
def lower_probe(self): def lower_probe(self):
self.test_sensor() self.test_sensor()
self.sync_print_time() self.sync_print_time()
@ -149,8 +147,9 @@ class BLTouchEndstopWrapper:
check_start_time = self.send_cmd('reset', duration=self.pin_move_time) check_start_time = self.send_cmd('reset', duration=self.pin_move_time)
check_end_time = self.send_cmd('touch_mode') check_end_time = self.send_cmd('touch_mode')
self.send_cmd(None) self.send_cmd(None)
self.verify_state(check_start_time, check_end_time, True, success = self.verify_state(check_start_time, check_end_time, True)
"verify sensor state") if not success:
raise homing.EndstopError("BLTouch failed to verify sensor state")
# Test was successful # Test was successful
self.next_test_time = check_end_time + TEST_TIME self.next_test_time = check_end_time + TEST_TIME
self.sync_print_time() self.sync_print_time()