2023-11-19 02:12:44 +03:00
|
|
|
|
package Visual_DVM_2021.Passes.All;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
import Common.Current_;
|
2024-10-11 00:00:30 +03:00
|
|
|
|
import Common.Utils.Utils_;
|
2024-10-09 22:01:19 +03:00
|
|
|
|
import _VisualDVM.Current;
|
2024-10-12 00:17:51 +03:00
|
|
|
|
import _VisualDVM.Global;
|
2024-10-09 22:01:19 +03:00
|
|
|
|
import _VisualDVM.Visual.UI;
|
|
|
|
|
|
import _VisualDVM.Utils;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.GlobalData.GlobalDatabase;
|
|
|
|
|
|
import _VisualDVM.GlobalData.Machine.MachineType;
|
|
|
|
|
|
import _VisualDVM.GlobalData.Tasks.RunTask.RunTask;
|
|
|
|
|
|
import _VisualDVM.GlobalData.Tasks.TaskState;
|
|
|
|
|
|
import _VisualDVM.ProjectData.Project.db_project_info;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
import Visual_DVM_2021.Passes.PassCode;
|
2024-10-10 23:57:36 +03:00
|
|
|
|
import Common.Passes.PassException;
|
|
|
|
|
|
import Common.Passes.Pass;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
|
|
|
|
|
|
import java.util.Vector;
|
2024-10-09 23:37:58 +03:00
|
|
|
|
public class Run extends Pass<db_project_info> {
|
|
|
|
|
|
Pass subpass = null;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
Vector<RunTask> runTasks;
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getIconPath() {
|
|
|
|
|
|
return "/icons/GreenStart.png";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getButtonText() {
|
|
|
|
|
|
return "";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void performPreparation() throws Exception {
|
2024-10-13 22:08:13 +03:00
|
|
|
|
runTasks = Global.mainModule.getRunConfiguration().generateRunTasks(target, Global.mainModule.getCompilationTask());
|
2023-09-17 22:13:42 +03:00
|
|
|
|
for (RunTask runTask : runTasks) {
|
2024-10-12 00:17:51 +03:00
|
|
|
|
Global.mainModule.getDb().Insert(runTask);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
Utils.forceDeleteWithCheck(runTask.getLocalWorkspace());
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showPreparation() throws Exception {
|
2024-10-12 00:17:51 +03:00
|
|
|
|
Global.mainModule.getDb().runTasks.ShowUI();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected boolean canStart(Object... args) {
|
|
|
|
|
|
subpass = null;
|
2024-10-13 22:08:13 +03:00
|
|
|
|
if (Global.mainModule.Check(Log, Current.Project, Current.Machine, Current.User, Current.Makefile, Current.RunConfiguration,
|
2023-09-17 22:13:42 +03:00
|
|
|
|
Current.CompilationTask)) {
|
|
|
|
|
|
//-
|
2024-10-13 22:08:13 +03:00
|
|
|
|
target = Global.mainModule.getProject();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//-
|
2024-10-13 22:08:13 +03:00
|
|
|
|
if (Global.mainModule.getMachine().type.equals(MachineType.MVS_cluster) &&
|
|
|
|
|
|
Global.mainModule.getRunConfiguration().LauncherCall.isEmpty()
|
2023-09-17 22:13:42 +03:00
|
|
|
|
) {
|
|
|
|
|
|
Log.Writeln_("Запуск напрямую на кластере запрещён.Используйте для запуска DVM систему или MPI");
|
|
|
|
|
|
}
|
2024-10-13 22:08:13 +03:00
|
|
|
|
if (!Global.mainModule.getCompilationTask().state.equals(TaskState.Done))
|
2023-09-17 22:13:42 +03:00
|
|
|
|
Log.Writeln_("Текущая задача на компиляцию еще не выполнялась, или была завершена с ошибками");
|
|
|
|
|
|
return Log.isEmpty();
|
|
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void body() throws Exception {
|
2024-10-13 22:08:13 +03:00
|
|
|
|
switch (Global.mainModule.getMachine().type) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
case Local:
|
2024-10-11 00:00:30 +03:00
|
|
|
|
if (Utils_.isWindows()) {
|
2024-10-13 23:55:03 +03:00
|
|
|
|
subpass = Global.mainModule.getPass(PassCode.WindowsLocalRun);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
} else
|
2024-10-13 23:55:03 +03:00
|
|
|
|
subpass = Global.mainModule.getPass(PassCode.LinuxLocalRun);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
break;
|
|
|
|
|
|
case Undefined:
|
2024-01-08 20:37:16 +03:00
|
|
|
|
case MVS_cluster:
|
2024-10-13 22:08:13 +03:00
|
|
|
|
throw new PassException("Запуск не реализован для типа машины " + Utils_.DQuotes(Global.mainModule.getMachine().type));
|
2024-01-08 20:37:16 +03:00
|
|
|
|
/*
|
2023-09-17 22:13:42 +03:00
|
|
|
|
case MVS_cluster:
|
|
|
|
|
|
subpass = passes.get(PassCode_2021.MVSRun);
|
|
|
|
|
|
break;
|
2024-01-08 20:37:16 +03:00
|
|
|
|
*/
|
2023-09-17 22:13:42 +03:00
|
|
|
|
default:
|
2024-10-13 23:55:03 +03:00
|
|
|
|
subpass = Global.mainModule.getPass(PassCode.ServerRun);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
int i = 1;
|
|
|
|
|
|
RunTask current_task = null;
|
|
|
|
|
|
for (RunTask task : runTasks) {
|
|
|
|
|
|
current_task = task;
|
|
|
|
|
|
boolean task_completed = false;
|
|
|
|
|
|
task.setProgress(i, runTasks.size());
|
|
|
|
|
|
//-
|
2024-10-12 00:17:51 +03:00
|
|
|
|
Global.mainModule.getDb().runTasks.RefreshUI();
|
|
|
|
|
|
Global.mainModule.getDb().runTasks.SetCurrentObjectUI(task.id);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//-
|
|
|
|
|
|
subpass.Do(task, target);
|
|
|
|
|
|
//-
|
|
|
|
|
|
switch (task.state) {
|
|
|
|
|
|
case Done:
|
|
|
|
|
|
case DoneWithErrors:
|
|
|
|
|
|
task_completed = true;
|
|
|
|
|
|
if (task.hasDvmSts) {
|
2024-10-13 22:08:13 +03:00
|
|
|
|
Utils.CheckAndCleanDirectory(Global.mainModule.getProject().getStatisticDirectory());
|
2024-10-13 23:55:03 +03:00
|
|
|
|
Global.mainModule.getPass(PassCode.SPF_StatisticAnalyzer).Do(task);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
case Finished:
|
|
|
|
|
|
case Crushed:
|
|
|
|
|
|
case AbortedByTimeout:
|
|
|
|
|
|
task_completed = true;
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
//-
|
2024-10-12 00:17:51 +03:00
|
|
|
|
Global.mainModule.getDb().runTasks.RefreshUI();
|
2023-10-11 18:44:16 +03:00
|
|
|
|
UI.getDebugWindow().ShowCurrentRunTask();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
//-
|
|
|
|
|
|
if (!task_completed) break;
|
|
|
|
|
|
++i;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (current_task!=null){
|
2023-10-11 18:44:16 +03:00
|
|
|
|
UI.getDebugWindow().ShowLastRunTask();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|