Newer
Older
# -*- coding: utf-8 -*-
import os
from signal import SIGTERM, SIGSTOP, SIGCONT
Pierre-Antoine Rouby
committed
from Model.Except import NotImplementedMethodeError
class AbstractSolver(object):
def __init__(self, name):
super(AbstractSolver, self).__init__()
self._current_process = None
self._status = STATUS.NOT_LAUNCHED
# Informations
self._type = ""
self._name = name
self._description = ""
self._path_input = ""
self._path_solver = ""
self._path_output = ""
self._cmd_input = ""
self._cmd_solver = ""
self._cmd_output = ""
self._process = None
self._output = None
return f"{self._name} : {self._type} : {self._description}"
def __getitem__(self, key):
ret = None
if key == "name":
ret = self._name
elif key == "description":
ret = self._description
elif key == "type":
ret = self._type
return ret
@classmethod
def default_parameters(cls):
("all_final_time", "999:99:00:00"),
]
return lst
Pierre-Antoine Rouby
committed
@classmethod
Pierre-Antoine Rouby
committed
lst = [
]
return lst
@property
def name(self):
return self._name
@property
def description(self):
return self._description
@property
def status(self):
return self._status
@property
def type(self):
return self._type
@status.setter
def status(self, status):
self._status = status
def is_running(self):
return self._status == STATUS.RUNNING
def is_paused(self):
return self._status == STATUS.PAUSED
def is_stoped(self):
return self._status == STATUS.STOPED
@name.setter
def name(self, name):
self._name = name
@description.setter
def description(self, description):
self._description = description
def set_input(self, path, cmd):
self._path_input = path
self._cmd_input = cmd
def set_solver(self, path, cmd):
self._path_solver = path
self._cmd_solver = cmd
def set_output(self, path, cmd):
self._path_output = path
self._cmd_output = cmd
##########
# Export #
##########
def export(self, study, repertory, qlog = None):
raise NotImplementedMethodeError(self, self.export)
#######
# Run #
#######
def run_input_data_fomater(self):
if self._cmd_input == "":
return True
return False
def run_solver(self):
if self._cmd_solver == "":
cmd = self._cmd_solver
cmd = cmd.replace("@path", self._path_solver).split()
exe = cmd[0]
args = cmd[1:]
self._process.start(
exe, args,
)
self._process.readyRead.connect(self._data_ready)
self._process.finished.connect(self._finished)
return True
def run_output_data_fomater(self):
if self._cmd_output == "":
def _data_ready(self):
s = self._process.readAll().data().decode()
if self._output is not None:
for x in s.split('\n'):
self._output.put(x)
def _finished(self, exit_code, exit_status):
if self._output is not None:
self._output.put(exit_code)
def run(self, process, output_queue):
self._process = process
self._output = output_queue
if self.run_input_data_fomater():
if self.run_solver():
return self.run_output_data_fomater()
if self._process is None:
return True
def start(self, process = None):
if process is not None:
self._process = process
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
if self._status == STATUS.PAUSED:
os.kill(self._process.pid(), SIGCONT)
self._status = STATUS.RUNNING
else:
self.run_solver()
return True
def pause(self):
if self._process is None:
return False
os.kill(self._process.pid(), SIGSTOP)
self._status = STATUS.PAUSED
return True
def stop(self):
if self._process is None:
return False
self._process.terminate()
self._status = STATUS.STOPED
return True
def wait(self):
if self._process is None:
return False
self._process.wait()
self._status = STATUS.STOPED
return True