-from __future__ import absolute_import
__copyright__ = "Copyright (C) 2013 David Braam - Released under terms of the AGPLv3 License"
-import os, wx, threading, sys
+import os
+import wx
+import threading
+import sys
+import time
from Cura.avr_isp import stk500v2
from Cura.avr_isp import ispBase
from Cura.util import profile
from Cura.util import resources
-def getDefaultFirmware():
- if profile.getMachineSetting('machine_type') == 'ultimaker':
- if profile.getMachineSetting('has_heated_bed') == 'True':
+def getDefaultFirmware(machineIndex = None):
+ if profile.getMachineSetting('machine_type', machineIndex) == 'ultimaker':
+ if profile.getMachineSetting('has_heated_bed', machineIndex) == 'True':
return None
- if profile.getMachineSettingFloat('extruder_amount') > 2:
+ if profile.getMachineSettingFloat('extruder_amount', machineIndex) > 2:
return None
- if profile.getMachineSettingFloat('extruder_amount') > 1:
+ if profile.getMachineSettingFloat('extruder_amount', machineIndex) > 1:
if sys.platform.startswith('linux'):
return resources.getPathForFirmware("MarlinUltimaker-115200-dual.hex")
else:
return resources.getPathForFirmware("MarlinUltimaker-115200.hex")
else:
return resources.getPathForFirmware("MarlinUltimaker-250000.hex")
- if profile.getMachineSetting('machine_type') == 'ultimaker2':
+ if profile.getMachineSetting('machine_type', machineIndex) == 'ultimaker2':
return resources.getPathForFirmware("MarlinUltimaker2.hex")
return None
class InstallFirmware(wx.Dialog):
- def __init__(self, filename = None, port = None):
- super(InstallFirmware, self).__init__(parent=None, title="Firmware install", size=(250, 100))
+ def __init__(self, filename = None, port = None, machineIndex = None):
+ super(InstallFirmware, self).__init__(parent=None, title="Firmware install for %s" % (profile.getMachineSetting('machine_name', machineIndex).title()), size=(250, 100))
if port is None:
port = profile.getMachineSetting('serial_port')
if filename is None:
- filename = getDefaultFirmware()
+ filename = getDefaultFirmware(machineIndex)
if filename is None:
wx.MessageBox(_("I am sorry, but Cura does not ship with a default firmware for your machine configuration."), _("Firmware update"), wx.OK | wx.ICON_ERROR)
self.Destroy()
return
+ if profile.getMachineSetting('machine_type', machineIndex) == 'reprap':
+ wx.MessageBox(_("Cura only supports firmware updates for ATMega2560 based hardware.\nSo updating your RepRap with Cura might or might not work."), _("Firmware update"), wx.OK | wx.ICON_INFORMATION)
sizer = wx.BoxSizer(wx.VERTICAL)
self.progressLabel = wx.StaticText(self, -1, 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\nX')
- sizer.Add(self.progressLabel, 0, flag=wx.ALIGN_CENTER)
+ sizer.Add(self.progressLabel, 0, flag=wx.ALIGN_CENTER|wx.ALL, border=5)
self.progressGauge = wx.Gauge(self, -1)
sizer.Add(self.progressGauge, 0, flag=wx.EXPAND)
self.okButton = wx.Button(self, -1, _("OK"))
self.okButton.Disable()
self.okButton.Bind(wx.EVT_BUTTON, self.OnOk)
- sizer.Add(self.okButton, 0, flag=wx.ALIGN_CENTER)
+ sizer.Add(self.okButton, 0, flag=wx.ALIGN_CENTER|wx.ALL, border=5)
self.SetSizer(sizer)
self.filename = filename
self.Layout()
self.Fit()
- threading.Thread(target=self.OnRun).start()
+ self.thread = threading.Thread(target=self.OnRun)
+ self.thread.daemon = True
+ self.thread.start()
self.ShowModal()
self.Destroy()
programmer = stk500v2.Stk500v2()
programmer.progressCallback = self.OnProgress
if self.port == 'AUTO':
- for self.port in machineCom.serialList(True):
- try:
- programmer.connect(self.port)
- break
- except ispBase.IspError:
- pass
+ wx.CallAfter(self.updateLabel, _("Please connect the printer to\nyour computer with the USB cable."))
+ while not programmer.isConnected():
+ for self.port in machineCom.serialList(True):
+ try:
+ programmer.connect(self.port)
+ break
+ except ispBase.IspError:
+ pass
+ time.sleep(1)
+ if not self:
+ #Window destroyed
+ return
else:
try:
programmer.connect(self.port)
except ispBase.IspError:
pass
- if programmer.isConnected():
- wx.CallAfter(self.updateLabel, _("Uploading firmware..."))
- try:
- programmer.programChip(hexFile)
- wx.CallAfter(self.updateLabel, _("Done!\nInstalled firmware: %s") % (os.path.basename(self.filename)))
- except ispBase.IspError as e:
- wx.CallAfter(self.updateLabel, _("Failed to write firmware.\n") + str(e))
-
- programmer.close()
- wx.CallAfter(self.okButton.Enable)
+ if not programmer.isConnected():
+ wx.MessageBox(_("Failed to find machine for firmware upgrade\nIs your machine connected to the PC?"),
+ _("Firmware update"), wx.OK | wx.ICON_ERROR)
+ wx.CallAfter(self.Close)
return
- wx.MessageBox(_("Failed to find machine for firmware upgrade\nIs your machine connected to the PC?"),
- _("Firmware update"), wx.OK | wx.ICON_ERROR)
- wx.CallAfter(self.Close)
+
+ wx.CallAfter(self.updateLabel, _("Uploading firmware..."))
+ try:
+ programmer.programChip(hexFile)
+ wx.CallAfter(self.updateLabel, _("Done!\nInstalled firmware: %s") % (os.path.basename(self.filename)))
+ except ispBase.IspError as e:
+ wx.CallAfter(self.updateLabel, _("Failed to write firmware.\n") + str(e))
+
+ programmer.close()
+ wx.CallAfter(self.okButton.Enable)
def updateLabel(self, text):
self.progressLabel.SetLabel(text)