diff options
author | Pranav P | 2023-06-03 17:35:25 +0530 |
---|---|---|
committer | Pranav P | 2023-06-03 17:35:25 +0530 |
commit | abf7ef8beebf78552d068ebeed1393fd79a81abc (patch) | |
tree | 40b8ebba9619dd5634a0c2494fe010f37340b2af /src/ngspiceSimulation | |
parent | d8a2de2ef6126654184a1924cd21d242bea1be18 (diff) | |
download | eSim-abf7ef8beebf78552d068ebeed1393fd79a81abc.tar.gz eSim-abf7ef8beebf78552d068ebeed1393fd79a81abc.tar.bz2 eSim-abf7ef8beebf78552d068ebeed1393fd79a81abc.zip |
Got rid of simulationEssentials
Diffstat (limited to 'src/ngspiceSimulation')
-rw-r--r-- | src/ngspiceSimulation/NgspiceWidget.py | 37 |
1 files changed, 24 insertions, 13 deletions
diff --git a/src/ngspiceSimulation/NgspiceWidget.py b/src/ngspiceSimulation/NgspiceWidget.py index d6f75853..aa175bf6 100644 --- a/src/ngspiceSimulation/NgspiceWidget.py +++ b/src/ngspiceSimulation/NgspiceWidget.py @@ -1,12 +1,13 @@ from PyQt5 import QtWidgets, QtCore from configuration.Appconfig import Appconfig from frontEnd import TerminalUi +import os # This Class creates NgSpice Window class NgspiceWidget(QtWidgets.QWidget): - def __init__(self, command, simulationEssentials): + def __init__(self, command, startSimulation): """ - Creates constructor for NgspiceWidget class. - Checks whether OS is Linux or Windows and @@ -20,18 +21,21 @@ class NgspiceWidget(QtWidgets.QWidget): self.terminalUi = TerminalUi.TerminalUi(self.process, self.args) self.layout = QtWidgets.QVBoxLayout(self) self.layout.addWidget(self.terminalUi) - self.checkChangeInPlotData = \ - simulationEssentials['checkChangeInPlotData'] - toggleToolbarButtons = simulationEssentials['toggleToolbarButtons'] - print("Argument to ngspice command : ", command) - self.process.started.connect(lambda: toggleToolbarButtons(state=False)) +# This variable makes sure that finished.connect is called exactly once + self.process.isFinishConnected = False + + self.process.\ + started.\ + connect(lambda: + startSimulation(process=self.process, + function=self.finishSimulation)) + self.process.setWorkingDirectory(self.projDir) self.process.start('ngspice', self.args) self.process.readyReadStandardOutput.connect( lambda: self.readyReadAll()) - self.process.finished.connect(self.finishSimulation) self.obj_appconfig.process_obj.append(self.process) print(self.obj_appconfig.proc_dict) ( @@ -39,12 +43,14 @@ class NgspiceWidget(QtWidgets.QWidget): [self.obj_appconfig.current_project['ProjectName']].append( self.process.pid()) ) - self.gawProcess = QtCore.QProcess(self) - self.gawCommand = "gaw " + command.replace(".cir.out", ".raw") - self.gawProcess.start('sh', ['-c', self.gawCommand]) - print(self.gawCommand) - def finishSimulation(self, exitCode, exitStatus): + if os.name != "nt": + self.gawProcess = QtCore.QProcess(self) + self.gawCommand = "gaw " + command.replace(".cir.out", ".raw") + self.gawProcess.start('sh', ['-c', self.gawCommand]) + print(self.gawCommand) + + def finishSimulation(self, exitCode, exitStatus, checkChangeInPlotData): """This function is intended to run when the ngspice simulation finishes. It singals to the function that generates the plots and also writes in the appropriate status of the @@ -56,6 +62,11 @@ class NgspiceWidget(QtWidgets.QWidget): :param exitStatus: The exit status signal of the qprocess that runs ngspice :type exitStatus: class:`QtCore.QProcess.ExitStatus` + :param checkChangeInPlotData: Takes the plotting function + as input and uses it to generate the plots. The reason + why this is passed in such a way is to minimize the no. + of functions passed through a chain of objects. + :type checkChangeInPlotData: function """ # To stop progressbar from running after simulation is completed @@ -65,7 +76,7 @@ class NgspiceWidget(QtWidgets.QWidget): # st = os.stat(os.path.join(self.projDir, "plot_data_i.txt")) # if st.st_mtime >= self.currTime: if exitStatus == QtCore.QProcess.NormalExit: - self.checkChangeInPlotData(exitCode) + checkChangeInPlotData(exitCode) # self.terminalUi.writeSimulationStatusToConsole() failedFormat = '<span style="color:#ff3333; font-size:26px;"> \ |