gcode: Eliminate the process_batch() method

Allow the callers of process_batch() to directly inspect the gcode
mutex.  Those callers can then directly invoke run_script().

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2019-06-09 13:33:21 -04:00
parent 962f7b98bd
commit 30d2ae8f9f
3 changed files with 12 additions and 16 deletions

View File

@ -42,12 +42,10 @@ class IdleTimeout:
self.state = "Printing" self.state = "Printing"
try: try:
script = self.idle_gcode.render() script = self.idle_gcode.render()
res = self.gcode.process_batch(script.split('\n')) res = self.gcode.run_script(script)
except: except:
logging.exception("idle timeout gcode execution") logging.exception("idle timeout gcode execution")
return eventtime + 1. self.state = "Ready"
if not res:
# Raced with incoming g-code commands
return eventtime + 1. return eventtime + 1.
print_time = self.toolhead.get_last_move_time() print_time = self.toolhead.get_last_move_time()
self.state = "Idle" self.state = "Idle"
@ -64,7 +62,7 @@ class IdleTimeout:
if idle_time < self.idle_timeout: if idle_time < self.idle_timeout:
# Wait for idle timeout # Wait for idle timeout
return eventtime + self.idle_timeout - idle_time return eventtime + self.idle_timeout - idle_time
if not self.gcode.process_batch([]): if self.gcode.get_mutex().test():
# Gcode class busy # Gcode class busy
return eventtime + 1. return eventtime + 1.
# Idle timeout has elapsed # Idle timeout has elapsed
@ -82,7 +80,7 @@ class IdleTimeout:
if buffer_time > -READY_TIMEOUT: if buffer_time > -READY_TIMEOUT:
# Wait for ready timeout # Wait for ready timeout
return eventtime + READY_TIMEOUT + buffer_time return eventtime + READY_TIMEOUT + buffer_time
if not self.gcode.process_batch([]): if self.gcode.get_mutex().test():
# Gcode class busy # Gcode class busy
return eventtime + READY_TIMEOUT return eventtime + READY_TIMEOUT
# Transition to "ready" state # Transition to "ready" state

View File

@ -146,6 +146,7 @@ class VirtualSD:
self.gcode.respond_error("Unable to seek file") self.gcode.respond_error("Unable to seek file")
self.work_timer = None self.work_timer = None
return self.reactor.NEVER return self.reactor.NEVER
gcode_mutex = self.gcode.get_mutex()
partial_input = "" partial_input = ""
lines = [] lines = []
while not self.must_pause_work: while not self.must_pause_work:
@ -170,12 +171,13 @@ class VirtualSD:
lines.reverse() lines.reverse()
self.reactor.pause(self.reactor.NOW) self.reactor.pause(self.reactor.NOW)
continue continue
# Dispatch command # Pause if any other request is pending in the gcode class
try: if gcode_mutex.test():
res = self.gcode.process_batch([lines[-1]])
if not res:
self.reactor.pause(self.reactor.monotonic() + 0.100) self.reactor.pause(self.reactor.monotonic() + 0.100)
continue continue
# Dispatch command
try:
self.gcode.run_script(lines[-1])
except self.gcode.error as e: except self.gcode.error as e:
break break
except: except:

View File

@ -277,12 +277,6 @@ class GCodeParser:
if self.fd_handle is None: if self.fd_handle is None:
self.fd_handle = self.reactor.register_fd(self.fd, self.fd_handle = self.reactor.register_fd(self.fd,
self._process_data) self._process_data)
def process_batch(self, commands):
if self.mutex.test():
return False
with self.mutex:
self._process_commands(commands, need_ack=False)
return True
def run_script_from_command(self, script): def run_script_from_command(self, script):
prev_need_ack = self.need_ack prev_need_ack = self.need_ack
try: try:
@ -292,6 +286,8 @@ class GCodeParser:
def run_script(self, script): def run_script(self, script):
with self.mutex: with self.mutex:
self._process_commands(script.split('\n'), need_ack=False) self._process_commands(script.split('\n'), need_ack=False)
def get_mutex(self):
return self.mutex
# Response handling # Response handling
def ack(self, msg=None): def ack(self, msg=None):
if not self.need_ack or self.is_fileinput: if not self.need_ack or self.is_fileinput: