stepper: No need to pass printer reference to kinematic/stepper constructors

The config reference already stores a reference to the printer object.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2018-06-21 13:47:39 -04:00
parent 76e2b041b4
commit d0590ccb0e
6 changed files with 40 additions and 45 deletions

View File

@ -9,10 +9,10 @@ import stepper, homing, chelper
StepList = (0, 1, 2) StepList = (0, 1, 2)
class CartKinematics: class CartKinematics:
def __init__(self, toolhead, printer, config): def __init__(self, toolhead, config):
self.printer = printer self.printer = config.get_printer()
self.steppers = [stepper.LookupMultiHomingStepper( self.steppers = [stepper.LookupMultiHomingStepper(
printer, config.getsection('stepper_' + n)) config.getsection('stepper_' + n))
for n in ['x', 'y', 'z']] for n in ['x', 'y', 'z']]
max_velocity, max_accel = toolhead.get_max_velocity() max_velocity, max_accel = toolhead.get_max_velocity()
self.max_z_velocity = config.getfloat( self.max_z_velocity = config.getfloat(
@ -40,12 +40,12 @@ class CartKinematics:
dc_config = config.getsection('dual_carriage') dc_config = config.getsection('dual_carriage')
dc_axis = dc_config.getchoice('axis', {'x': 'x', 'y': 'y'}) dc_axis = dc_config.getchoice('axis', {'x': 'x', 'y': 'y'})
self.dual_carriage_axis = {'x': 0, 'y': 1}[dc_axis] self.dual_carriage_axis = {'x': 0, 'y': 1}[dc_axis]
dc_stepper = stepper.LookupMultiHomingStepper(printer, dc_config) dc_stepper = stepper.LookupMultiHomingStepper(dc_config)
dc_stepper.setup_cartesian_itersolve(dc_axis) dc_stepper.setup_cartesian_itersolve(dc_axis)
dc_stepper.set_max_jerk(max_halt_velocity, max_accel) dc_stepper.set_max_jerk(max_halt_velocity, max_accel)
self.dual_carriage_steppers = [ self.dual_carriage_steppers = [
self.steppers[self.dual_carriage_axis], dc_stepper] self.steppers[self.dual_carriage_axis], dc_stepper]
printer.lookup_object('gcode').register_command( self.printer.lookup_object('gcode').register_command(
'SET_DUAL_CARRIAGE', self.cmd_SET_DUAL_CARRIAGE, 'SET_DUAL_CARRIAGE', self.cmd_SET_DUAL_CARRIAGE,
desc=self.cmd_SET_DUAL_CARRIAGE_help) desc=self.cmd_SET_DUAL_CARRIAGE_help)
def get_steppers(self, flags=""): def get_steppers(self, flags=""):

View File

@ -9,14 +9,11 @@ import stepper, homing, chelper
StepList = (0, 1, 2) StepList = (0, 1, 2)
class CoreXYKinematics: class CoreXYKinematics:
def __init__(self, toolhead, printer, config): def __init__(self, toolhead, config):
self.steppers = [ self.steppers = [
stepper.PrinterHomingStepper( stepper.PrinterHomingStepper(config.getsection('stepper_x')),
printer, config.getsection('stepper_x')), stepper.PrinterHomingStepper(config.getsection('stepper_y')),
stepper.PrinterHomingStepper( stepper.LookupMultiHomingStepper(config.getsection('stepper_z'))]
printer, config.getsection('stepper_y')),
stepper.LookupMultiHomingStepper(
printer, config.getsection('stepper_z'))]
self.steppers[0].mcu_endstop.add_stepper(self.steppers[1].mcu_stepper) self.steppers[0].mcu_endstop.add_stepper(self.steppers[1].mcu_stepper)
self.steppers[1].mcu_endstop.add_stepper(self.steppers[0].mcu_stepper) self.steppers[1].mcu_endstop.add_stepper(self.steppers[0].mcu_stepper)
max_velocity, max_accel = toolhead.get_max_velocity() max_velocity, max_accel = toolhead.get_max_velocity()

View File

@ -12,16 +12,16 @@ StepList = (0, 1, 2)
SLOW_RATIO = 3. SLOW_RATIO = 3.
class DeltaKinematics: class DeltaKinematics:
def __init__(self, toolhead, printer, config): def __init__(self, toolhead, config):
stepper_configs = [config.getsection('stepper_' + n) stepper_configs = [config.getsection('stepper_' + n)
for n in ['a', 'b', 'c']] for n in ['a', 'b', 'c']]
stepper_a = stepper.PrinterHomingStepper( stepper_a = stepper.PrinterHomingStepper(
printer, stepper_configs[0], need_position_minmax = False) stepper_configs[0], need_position_minmax = False)
stepper_b = stepper.PrinterHomingStepper( stepper_b = stepper.PrinterHomingStepper(
printer, stepper_configs[1], need_position_minmax = False, stepper_configs[1], need_position_minmax = False,
default_position_endstop=stepper_a.position_endstop) default_position_endstop=stepper_a.position_endstop)
stepper_c = stepper.PrinterHomingStepper( stepper_c = stepper.PrinterHomingStepper(
printer, stepper_configs[2], need_position_minmax = False, stepper_configs[2], need_position_minmax = False,
default_position_endstop=stepper_a.position_endstop) default_position_endstop=stepper_a.position_endstop)
self.steppers = [stepper_a, stepper_b, stepper_c] self.steppers = [stepper_a, stepper_b, stepper_c]
self.need_motor_enable = self.need_home = True self.need_motor_enable = self.need_home = True

View File

@ -9,16 +9,16 @@ import stepper, homing, chelper
EXTRUDE_DIFF_IGNORE = 1.02 EXTRUDE_DIFF_IGNORE = 1.02
class PrinterExtruder: class PrinterExtruder:
def __init__(self, printer, config): def __init__(self, config):
self.printer = printer self.printer = config.get_printer()
self.name = config.get_name() self.name = config.get_name()
shared_heater = config.get('shared_heater', None) shared_heater = config.get('shared_heater', None)
pheater = printer.lookup_object('heater') pheater = self.printer.lookup_object('heater')
if shared_heater is None: if shared_heater is None:
self.heater = pheater.setup_heater(config) self.heater = pheater.setup_heater(config)
else: else:
self.heater = pheater.lookup_heater(shared_heater) self.heater = pheater.lookup_heater(shared_heater)
self.stepper = stepper.PrinterStepper(printer, config) self.stepper = stepper.PrinterStepper(config)
self.nozzle_diameter = config.getfloat('nozzle_diameter', above=0.) self.nozzle_diameter = config.getfloat('nozzle_diameter', above=0.)
filament_diameter = config.getfloat( filament_diameter = config.getfloat(
'filament_diameter', minval=self.nozzle_diameter) 'filament_diameter', minval=self.nozzle_diameter)
@ -28,7 +28,7 @@ class PrinterExtruder:
, above=0.) , above=0.)
self.max_extrude_ratio = max_cross_section / self.filament_area self.max_extrude_ratio = max_cross_section / self.filament_area
logging.info("Extruder max_extrude_ratio=%.6f", self.max_extrude_ratio) logging.info("Extruder max_extrude_ratio=%.6f", self.max_extrude_ratio)
toolhead = printer.lookup_object('toolhead') toolhead = self.printer.lookup_object('toolhead')
max_velocity, max_accel = toolhead.get_max_velocity() max_velocity, max_accel = toolhead.get_max_velocity()
self.max_e_velocity = config.getfloat( self.max_e_velocity = config.getfloat(
'max_extrude_only_velocity', max_velocity * self.max_extrude_ratio 'max_extrude_only_velocity', max_velocity * self.max_extrude_ratio
@ -236,12 +236,11 @@ def add_printer_objects(printer, config):
section = 'extruder%d' % (i,) section = 'extruder%d' % (i,)
if not config.has_section(section): if not config.has_section(section):
if not i and config.has_section('extruder'): if not i and config.has_section('extruder'):
printer.add_object('extruder0', PrinterExtruder( pe = PrinterExtruder(config.getsection('extruder'))
printer, config.getsection('extruder'))) printer.add_object('extruder0', pe)
continue continue
break break
printer.add_object(section, PrinterExtruder( printer.add_object(section, PrinterExtruder(config.getsection(section)))
printer, config.getsection(section)))
def get_printer_extruders(printer): def get_printer_extruders(printer):
out = [] out = []

View File

@ -34,8 +34,8 @@ def lookup_enable_pin(ppins, pin):
# Code storing the definitions for a stepper motor # Code storing the definitions for a stepper motor
class PrinterStepper: class PrinterStepper:
def __init__(self, printer, config): def __init__(self, config):
self.printer = printer printer = config.get_printer()
self.name = config.get_name() self.name = config.get_name()
if self.name.startswith('stepper_'): if self.name.startswith('stepper_'):
self.name = self.name[8:] self.name = self.name[8:]
@ -74,11 +74,11 @@ class PrinterStepper:
# Support for stepper controlled linear axis with an endstop # Support for stepper controlled linear axis with an endstop
class PrinterHomingStepper(PrinterStepper): class PrinterHomingStepper(PrinterStepper):
def __init__(self, printer, config, need_position_minmax=True, def __init__(self, config, need_position_minmax=True,
default_position_endstop=None): default_position_endstop=None):
PrinterStepper.__init__(self, printer, config) PrinterStepper.__init__(self, config)
# Endstop and its position # Endstop and its position
ppins = printer.lookup_object('pins') ppins = config.get_printer().lookup_object('pins')
self.mcu_endstop = ppins.setup_pin('endstop', config.get('endstop_pin')) self.mcu_endstop = ppins.setup_pin('endstop', config.get('endstop_pin'))
self.mcu_endstop.add_stepper(self.mcu_stepper) self.mcu_endstop.add_stepper(self.mcu_stepper)
if default_position_endstop is None: if default_position_endstop is None:
@ -179,8 +179,8 @@ class PrinterHomingStepper(PrinterStepper):
# Wrapper for dual stepper motor support # Wrapper for dual stepper motor support
class PrinterMultiStepper(PrinterHomingStepper): class PrinterMultiStepper(PrinterHomingStepper):
def __init__(self, printer, config): def __init__(self, config):
PrinterHomingStepper.__init__(self, printer, config) PrinterHomingStepper.__init__(self, config)
self.endstops = PrinterHomingStepper.get_endstops(self) self.endstops = PrinterHomingStepper.get_endstops(self)
self.extras = [] self.extras = []
self.all_step_itersolve = [self.step_itersolve] self.all_step_itersolve = [self.step_itersolve]
@ -188,12 +188,12 @@ class PrinterMultiStepper(PrinterHomingStepper):
if not config.has_section(config.get_name() + str(i)): if not config.has_section(config.get_name() + str(i)):
break break
extraconfig = config.getsection(config.get_name() + str(i)) extraconfig = config.getsection(config.get_name() + str(i))
extra = PrinterStepper(printer, extraconfig) extra = PrinterStepper(extraconfig)
self.extras.append(extra) self.extras.append(extra)
self.all_step_itersolve.append(extra.step_itersolve) self.all_step_itersolve.append(extra.step_itersolve)
extraendstop = extraconfig.get('endstop_pin', None) extraendstop = extraconfig.get('endstop_pin', None)
if extraendstop is not None: if extraendstop is not None:
ppins = printer.lookup_object('pins') ppins = config.get_printer().lookup_object('pins')
mcu_endstop = ppins.setup_pin('endstop', extraendstop) mcu_endstop = ppins.setup_pin('endstop', extraendstop)
mcu_endstop.add_stepper(extra.mcu_stepper) mcu_endstop.add_stepper(extra.mcu_stepper)
self.endstops.append((mcu_endstop, extra.name)) self.endstops.append((mcu_endstop, extra.name))
@ -225,7 +225,7 @@ class PrinterMultiStepper(PrinterHomingStepper):
def get_endstops(self): def get_endstops(self):
return self.endstops return self.endstops
def LookupMultiHomingStepper(printer, config): def LookupMultiHomingStepper(config):
if not config.has_section(config.get_name() + '1'): if not config.has_section(config.get_name() + '1'):
return PrinterHomingStepper(printer, config) return PrinterHomingStepper(config)
return PrinterMultiStepper(printer, config) return PrinterMultiStepper(config)

View File

@ -186,10 +186,10 @@ STALL_TIME = 0.100
# Main code to track events (and their timing) on the printer toolhead # Main code to track events (and their timing) on the printer toolhead
class ToolHead: class ToolHead:
def __init__(self, printer, config): def __init__(self, config):
self.printer = printer self.printer = config.get_printer()
self.reactor = printer.get_reactor() self.reactor = self.printer.get_reactor()
self.all_mcus = printer.lookup_module_objects('mcu') self.all_mcus = self.printer.lookup_module_objects('mcu')
self.mcu = self.all_mcus[0] self.mcu = self.all_mcus[0]
self.max_velocity = config.getfloat('max_velocity', above=0.) self.max_velocity = config.getfloat('max_velocity', above=0.)
self.max_accel = config.getfloat('max_accel', above=0.) self.max_accel = config.getfloat('max_accel', above=0.)
@ -232,10 +232,9 @@ class ToolHead:
kintypes = {'cartesian': cartesian.CartKinematics, kintypes = {'cartesian': cartesian.CartKinematics,
'corexy': corexy.CoreXYKinematics, 'corexy': corexy.CoreXYKinematics,
'delta': delta.DeltaKinematics} 'delta': delta.DeltaKinematics}
self.kin = config.getchoice('kinematics', kintypes)( self.kin = config.getchoice('kinematics', kintypes)(self, config)
self, printer, config)
# SET_VELOCITY_LIMIT command # SET_VELOCITY_LIMIT command
gcode = printer.lookup_object('gcode') gcode = self.printer.lookup_object('gcode')
gcode.register_command('SET_VELOCITY_LIMIT', self.cmd_SET_VELOCITY_LIMIT, gcode.register_command('SET_VELOCITY_LIMIT', self.cmd_SET_VELOCITY_LIMIT,
desc=self.cmd_SET_VELOCITY_LIMIT_help) desc=self.cmd_SET_VELOCITY_LIMIT_help)
gcode.register_command('M204', self.cmd_M204) gcode.register_command('M204', self.cmd_M204)
@ -443,4 +442,4 @@ class ToolHead:
self.max_accel = min(accel, self.config_max_accel) self.max_accel = min(accel, self.config_max_accel)
def add_printer_objects(printer, config): def add_printer_objects(printer, config):
printer.add_object('toolhead', ToolHead(printer, config)) printer.add_object('toolhead', ToolHead(config))