mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-06 22:47:29 -06:00
Fix this sh*t
Sorry, I kind of dropped the ball before.
This commit is contained in:
parent
91ee691c80
commit
3908781f6f
2 changed files with 35 additions and 23 deletions
|
@ -16,6 +16,8 @@ class FirmwareUpdater(QObject):
|
||||||
firmwareUpdateStateChanged = pyqtSignal()
|
firmwareUpdateStateChanged = pyqtSignal()
|
||||||
|
|
||||||
def __init__(self, output_device: PrinterOutputDevice) -> None:
|
def __init__(self, output_device: PrinterOutputDevice) -> None:
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
self._output_device = output_device
|
self._output_device = output_device
|
||||||
|
|
||||||
self._update_firmware_thread = Thread(target=self._updateFirmware, daemon=True)
|
self._update_firmware_thread = Thread(target=self._updateFirmware, daemon=True)
|
||||||
|
@ -31,29 +33,35 @@ class FirmwareUpdater(QObject):
|
||||||
self._firmware_location = QUrl(file).toLocalFile()
|
self._firmware_location = QUrl(file).toLocalFile()
|
||||||
else:
|
else:
|
||||||
self._firmware_location = file
|
self._firmware_location = file
|
||||||
self.showFirmwareInterface()
|
self._showFirmwareInterface()
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.updating)
|
self._setFirmwareUpdateState(FirmwareUpdateState.updating)
|
||||||
|
|
||||||
self._update_firmware_thread.start()
|
self._update_firmware_thread.start()
|
||||||
|
|
||||||
def _updateFirmware(self) -> None:
|
def _updateFirmware(self) -> None:
|
||||||
raise NotImplementedError("_updateFirmware needs to be implemented")
|
raise NotImplementedError("_updateFirmware needs to be implemented")
|
||||||
|
|
||||||
def cleanupAfterUpdate(self) -> None:
|
## Show firmware interface.
|
||||||
|
# This will create the view if its not already created.
|
||||||
|
def _showFirmwareInterface(self) -> None:
|
||||||
|
if self._firmware_view is None:
|
||||||
|
path = Resources.getPath(CuraApplication.ResourceTypes.QmlFiles, "FirmwareUpdateWindow.qml")
|
||||||
|
self._firmware_view = CuraApplication.getInstance().createQmlComponent(path, {"manager": self})
|
||||||
|
|
||||||
|
if not self._firmware_view:
|
||||||
|
return
|
||||||
|
|
||||||
|
self._onFirmwareProgress(0)
|
||||||
|
self._setFirmwareUpdateState(FirmwareUpdateState.idle)
|
||||||
|
self._firmware_view.show()
|
||||||
|
|
||||||
|
## Cleanup after a succesful update
|
||||||
|
def _cleanupAfterUpdate(self) -> None:
|
||||||
# Clean up for next attempt.
|
# Clean up for next attempt.
|
||||||
self._update_firmware_thread = Thread(target=self._updateFirmware, daemon=True)
|
self._update_firmware_thread = Thread(target=self._updateFirmware, daemon=True)
|
||||||
self._firmware_location = ""
|
self._firmware_location = ""
|
||||||
self._onFirmwareProgress(100)
|
self._onFirmwareProgress(100)
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.completed)
|
self._setFirmwareUpdateState(FirmwareUpdateState.completed)
|
||||||
|
|
||||||
## Show firmware interface.
|
|
||||||
# This will create the view if its not already created.
|
|
||||||
def showFirmwareInterface(self) -> None:
|
|
||||||
if self._firmware_view is None:
|
|
||||||
path = Resources.getPath(self.ResourceTypes.QmlFiles, "FirmwareUpdateWindow.qml")
|
|
||||||
self._firmware_view = CuraApplication.getInstance().createQmlComponent(path, {"manager": self})
|
|
||||||
|
|
||||||
if self._firmware_view:
|
|
||||||
self._firmware_view.show()
|
|
||||||
|
|
||||||
@pyqtProperty(float, notify = firmwareProgressChanged)
|
@pyqtProperty(float, notify = firmwareProgressChanged)
|
||||||
def firmwareProgress(self) -> float:
|
def firmwareProgress(self) -> float:
|
||||||
|
@ -63,7 +71,7 @@ class FirmwareUpdater(QObject):
|
||||||
def firmwareUpdateState(self) -> "FirmwareUpdateState":
|
def firmwareUpdateState(self) -> "FirmwareUpdateState":
|
||||||
return self._firmware_update_state
|
return self._firmware_update_state
|
||||||
|
|
||||||
def setFirmwareUpdateState(self, state) -> None:
|
def _setFirmwareUpdateState(self, state) -> None:
|
||||||
if self._firmware_update_state != state:
|
if self._firmware_update_state != state:
|
||||||
self._firmware_update_state = state
|
self._firmware_update_state = state
|
||||||
self.firmwareUpdateStateChanged.emit()
|
self.firmwareUpdateStateChanged.emit()
|
||||||
|
|
|
@ -22,39 +22,43 @@ class AvrFirmwareUpdater(FirmwareUpdater):
|
||||||
assert len(hex_file) > 0
|
assert len(hex_file) > 0
|
||||||
except (FileNotFoundError, AssertionError):
|
except (FileNotFoundError, AssertionError):
|
||||||
Logger.log("e", "Unable to read provided hex file. Could not update firmware.")
|
Logger.log("e", "Unable to read provided hex file. Could not update firmware.")
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.firmware_not_found_error)
|
self._setFirmwareUpdateState(FirmwareUpdateState.firmware_not_found_error)
|
||||||
return
|
return
|
||||||
|
|
||||||
programmer = stk500v2.Stk500v2()
|
programmer = stk500v2.Stk500v2()
|
||||||
programmer.progress_callback = self._onFirmwareProgress
|
programmer.progress_callback = self._onFirmwareProgress
|
||||||
|
|
||||||
|
# Ensure that other connections are closed.
|
||||||
|
if self._output_device.isConnected():
|
||||||
|
self._output_device.close()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
programmer.connect(self._serial_port)
|
programmer.connect(self._output_device._serial_port)
|
||||||
except:
|
except:
|
||||||
programmer.close()
|
programmer.close()
|
||||||
Logger.logException("e", "Failed to update firmware")
|
Logger.logException("e", "Failed to update firmware")
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.communication_error)
|
self._setFirmwareUpdateState(FirmwareUpdateState.communication_error)
|
||||||
return
|
return
|
||||||
|
|
||||||
# Give programmer some time to connect. Might need more in some cases, but this worked in all tested cases.
|
# Give programmer some time to connect. Might need more in some cases, but this worked in all tested cases.
|
||||||
sleep(1)
|
sleep(1)
|
||||||
if not programmer.isConnected():
|
if not programmer.isConnected():
|
||||||
Logger.log("e", "Unable to connect with serial. Could not update firmware")
|
Logger.log("e", "Unable to connect with serial. Could not update firmware")
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.communication_error)
|
self._setFirmwareUpdateState(FirmwareUpdateState.communication_error)
|
||||||
try:
|
try:
|
||||||
programmer.programChip(hex_file)
|
programmer.programChip(hex_file)
|
||||||
except SerialException as e:
|
except SerialException as e:
|
||||||
Logger.log("e", "A serial port exception occured during firmware update: %s" % e)
|
Logger.log("e", "A serial port exception occured during firmware update: %s" % e)
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.io_error)
|
self._setFirmwareUpdateState(FirmwareUpdateState.io_error)
|
||||||
return
|
return
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
Logger.log("e", "An unknown exception occured during firmware update: %s" % e)
|
Logger.log("e", "An unknown exception occured during firmware update: %s" % e)
|
||||||
self.setFirmwareUpdateState(FirmwareUpdateState.unknown_error)
|
self._setFirmwareUpdateState(FirmwareUpdateState.unknown_error)
|
||||||
return
|
return
|
||||||
|
|
||||||
programmer.close()
|
programmer.close()
|
||||||
|
|
||||||
# Try to re-connect with the machine again, which must be done on the Qt thread, so we use call later.
|
# Try to re-connect with the machine again, which must be done on the Qt thread, so we use call later.
|
||||||
CuraApplication.getInstance().callLater(self.connect)
|
CuraApplication.getInstance().callLater(self._output_device.connect)
|
||||||
|
|
||||||
self.cleanupAfterUpdate()
|
self._cleanupAfterUpdate()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue