Files
VisualSapfor/src/Visual_DVM_2021/Passes/All/Run.java

119 lines
4.5 KiB
Java
Raw Normal View History

package Visual_DVM_2021.Passes.All;
2024-10-09 23:37:58 +03:00
import Common.Current_;
2024-10-07 14:22:52 +03:00
import Common.Utils.CommonUtils;
2024-10-09 22:01:19 +03:00
import _VisualDVM.Current;
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;
import Visual_DVM_2021.Passes.PassException;
2024-10-09 23:37:58 +03:00
import Visual_DVM_2021.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 {
runTasks = Current.getRunConfiguration().generateRunTasks(target, Current.getCompilationTask());
for (RunTask runTask : runTasks) {
CommonUtils.db.Insert(runTask);
2023-09-17 22:13:42 +03:00
Utils.forceDeleteWithCheck(runTask.getLocalWorkspace());
}
}
@Override
protected void showPreparation() throws Exception {
((GlobalDatabase)CommonUtils.db).runTasks.ShowUI();
2023-09-17 22:13:42 +03:00
}
@Override
protected boolean canStart(Object... args) {
subpass = null;
2024-10-09 23:37:58 +03:00
if (Current_.Check(Log, Current.Project, Current.Machine, Current.User, Current.Makefile, Current.RunConfiguration,
2023-09-17 22:13:42 +03:00
Current.CompilationTask)) {
//-
target = Current.getProject();
//-
if (Current.getMachine().type.equals(MachineType.MVS_cluster) &&
Current.getRunConfiguration().LauncherCall.isEmpty()
) {
Log.Writeln_("Запуск напрямую на кластере запрещён.Используйте для запуска DVM систему или MPI");
}
if (!Current.getCompilationTask().state.equals(TaskState.Done))
Log.Writeln_("Текущая задача на компиляцию еще не выполнялась, или была завершена с ошибками");
return Log.isEmpty();
}
return false;
}
@Override
protected void body() throws Exception {
switch (Current.getMachine().type) {
case Local:
2024-10-08 22:33:49 +03:00
if (CommonUtils.isWindows()) {
2024-10-09 23:37:58 +03:00
subpass = passes.get(PassCode.WindowsLocalRun);
2023-09-17 22:13:42 +03:00
} else
2024-10-09 23:37:58 +03:00
subpass = passes.get(PassCode.LinuxLocalRun);
2023-09-17 22:13:42 +03:00
break;
case Undefined:
case MVS_cluster:
2024-10-07 14:22:52 +03:00
throw new PassException("Запуск не реализован для типа машины " + CommonUtils.DQuotes(Current.getMachine().type));
/*
2023-09-17 22:13:42 +03:00
case MVS_cluster:
subpass = passes.get(PassCode_2021.MVSRun);
break;
*/
2023-09-17 22:13:42 +03:00
default:
2024-10-09 23:37:58 +03:00
subpass = passes.get(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());
//-
((GlobalDatabase)CommonUtils.db).runTasks.RefreshUI();
((GlobalDatabase)CommonUtils.db).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) {
Utils.CheckAndCleanDirectory(Current.getProject().getStatisticDirectory());
2024-10-09 23:37:58 +03:00
Pass.passes.get(PassCode.SPF_StatisticAnalyzer).Do(task);
2023-09-17 22:13:42 +03:00
}
break;
case Finished:
case Crushed:
case AbortedByTimeout:
task_completed = true;
break;
}
//-
((GlobalDatabase)CommonUtils.db).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
}
}
}