gcode: Eliminate build_config() method

Lookup the printer components during the set_printer_ready() callback.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2017-03-12 22:02:32 -04:00
parent 168cb95bd5
commit be91c1229f
2 changed files with 5 additions and 5 deletions

View File

@ -34,15 +34,16 @@ class GCodeParser:
self.homing_add = [0.0, 0.0, 0.0, 0.0] self.homing_add = [0.0, 0.0, 0.0, 0.0]
self.axis2pos = {'X': 0, 'Y': 1, 'Z': 2, 'E': 3} self.axis2pos = {'X': 0, 'Y': 1, 'Z': 2, 'E': 3}
self.build_handlers() self.build_handlers()
def build_config(self): def build_handlers(self):
self.toolhead = self.printer.objects['toolhead'] # Lookup printer components
self.toolhead = self.printer.objects.get('toolhead')
self.heater_nozzle = None self.heater_nozzle = None
extruder = self.printer.objects.get('extruder') extruder = self.printer.objects.get('extruder')
if extruder: if extruder:
self.heater_nozzle = extruder.heater self.heater_nozzle = extruder.heater
self.heater_bed = self.printer.objects.get('heater_bed') self.heater_bed = self.printer.objects.get('heater_bed')
self.fan = self.printer.objects.get('fan') self.fan = self.printer.objects.get('fan')
def build_handlers(self): # Map command handlers
handlers = ['G1', 'G4', 'G20', 'G21', 'G28', 'G90', 'G91', 'G92', handlers = ['G1', 'G4', 'G20', 'G21', 'G28', 'G90', 'G91', 'G92',
'M18', 'M82', 'M83', 'M105', 'M110', 'M112', 'M114', 'M115', 'M18', 'M82', 'M83', 'M105', 'M110', 'M112', 'M114', 'M115',
'M206', 'M400', 'M206', 'M400',

View File

@ -100,6 +100,7 @@ class Printer:
self.startup_state = startup_state self.startup_state = startup_state
self.software_version = version self.software_version = version
self.reactor = reactor.Reactor() self.reactor = reactor.Reactor()
self.objects = {}
self.gcode = gcode.GCodeParser(self, input_fd, is_fileinput) self.gcode = gcode.GCodeParser(self, input_fd, is_fileinput)
self.stats_timer = self.reactor.register_timer(self.stats) self.stats_timer = self.reactor.register_timer(self.stats)
self.connect_timer = self.reactor.register_timer( self.connect_timer = self.reactor.register_timer(
@ -111,7 +112,6 @@ class Printer:
self.run_result = None self.run_result = None
self.fileconfig = None self.fileconfig = None
self.mcu = None self.mcu = None
self.objects = {}
def set_fileoutput(self, debugoutput, dictionary): def set_fileoutput(self, debugoutput, dictionary):
self.debugoutput = debugoutput self.debugoutput = debugoutput
self.dictionary = dictionary self.dictionary = dictionary
@ -152,7 +152,6 @@ class Printer:
def build_config(self): def build_config(self):
for oname in sorted(self.objects.keys()): for oname in sorted(self.objects.keys()):
self.objects[oname].build_config() self.objects[oname].build_config()
self.gcode.build_config()
self.mcu.build_config() self.mcu.build_config()
def validate_config(self): def validate_config(self):
valid_sections = dict([(s, 1) for s, o in self.all_config_options]) valid_sections = dict([(s, 1) for s, o in self.all_config_options])