filament_switch_sensor: Minor optimization to note_filament_present()
Avoid calling into the OS to obtain the system time if the filament state hasn't changed. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
718da75910
commit
6716007420
|
@ -83,18 +83,19 @@ class RunoutHelper:
|
||||||
insert = False
|
insert = False
|
||||||
self.runout_enabled = runout
|
self.runout_enabled = runout
|
||||||
self.insert_enabled = insert
|
self.insert_enabled = insert
|
||||||
def note_filament_present(self, state):
|
def note_filament_present(self, is_filament_present):
|
||||||
|
if is_filament_present == self.filament_present:
|
||||||
|
return
|
||||||
|
self.filament_present = is_filament_present
|
||||||
eventtime = self.reactor.monotonic()
|
eventtime = self.reactor.monotonic()
|
||||||
if (eventtime < self.start_time or state == self.filament_present
|
if (eventtime < self.start_time
|
||||||
or (eventtime - self.last_event_time) < self.event_delay
|
or (eventtime - self.last_event_time) < self.event_delay
|
||||||
or not self.sensor_enabled or self.event_running):
|
or not self.sensor_enabled or self.event_running):
|
||||||
# do not process during the initialization time, duplicates,
|
# do not process during the initialization time, duplicates,
|
||||||
# during the event delay time, while an event is running, or
|
# during the event delay time, while an event is running, or
|
||||||
# when the sensor is disabled
|
# when the sensor is disabled
|
||||||
self.filament_present = state
|
|
||||||
return
|
return
|
||||||
self.filament_present = state
|
if is_filament_present:
|
||||||
if state:
|
|
||||||
if self.insert_enabled:
|
if self.insert_enabled:
|
||||||
# insert detected
|
# insert detected
|
||||||
self.event_running = True
|
self.event_running = True
|
||||||
|
|
Loading…
Reference in New Issue