аналогичная запаковка и распаковка окружения. осталось формирование задач и отображение в таблице
This commit is contained in:
@@ -6,28 +6,36 @@ import _VisualDVM.Global;
|
||||
import _VisualDVM.GlobalData.Compiler.Compiler;
|
||||
import _VisualDVM.GlobalData.Compiler.CompilerType;
|
||||
import _VisualDVM.GlobalData.CompilerEnvironment.CompilerEnvironment;
|
||||
import _VisualDVM.GlobalData.CompilerEnvironment.Json.EnvironmentJson;
|
||||
import _VisualDVM.GlobalData.CompilerEnvironment.Json.EnvironmentsJson;
|
||||
import _VisualDVM.GlobalData.CompilerEnvironment.UI.CompilerEnvironmentsFields;
|
||||
import _VisualDVM.GlobalData.CompilerOption.Json.OptionsJson;
|
||||
import _VisualDVM.Passes.PassCode;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.util.Vector;
|
||||
public class PickCompilerEnvironmentsForTesting extends Pass<String> {
|
||||
public class PickCompilerEnvironmentsForTesting extends Pass<EnvironmentsJson> {
|
||||
Compiler compiler = null;
|
||||
//-
|
||||
@Override
|
||||
protected boolean canStart(Object... args) throws Exception {
|
||||
target = new EnvironmentsJson();
|
||||
if (args[0] == null) {
|
||||
Log.Writeln_("Отсутствует текущий компилятор. Выбор переменных окружения недоступен.");
|
||||
Log.Writeln_("Отсутствует текущий компилятор. Выбор флагов недоступен.");
|
||||
return false;
|
||||
}
|
||||
target = "";
|
||||
compiler = Global.mainModule.getDb().compilers.getUI().getCurrent();
|
||||
compiler = (Compiler) args[0];
|
||||
if (!compiler.type.equals(CompilerType.dvm)) {
|
||||
Log.Writeln_("Выбор переменных окружения возможен только для DVM компилятора,");
|
||||
return false;
|
||||
}
|
||||
if (!(compiler.helpLoaded || Global.mainModule.getPass(PassCode.ShowCompilerHelp).Do(compiler, false)))
|
||||
return false;
|
||||
compiler.environments.Reset();
|
||||
if (args.length>1){
|
||||
target = (EnvironmentsJson) args[1];
|
||||
compiler.environments.Synchronize(target);
|
||||
}
|
||||
Dialog<String, CompilerEnvironmentsFields> dialog =
|
||||
new Dialog<String, CompilerEnvironmentsFields>(CompilerEnvironmentsFields.class) {
|
||||
@Override
|
||||
@@ -51,11 +59,11 @@ public class PickCompilerEnvironmentsForTesting extends Pass<String> {
|
||||
}
|
||||
@Override
|
||||
protected void body() throws Exception {
|
||||
Vector<String> envs = new Vector<>();
|
||||
target.values.clear();
|
||||
for (CompilerEnvironment compilerEnv : compiler.environments.Data.values()) {
|
||||
if (compilerEnv.isSelected())
|
||||
envs.add(compilerEnv.name + "=" + Utils_.DQuotes(compilerEnv.value));
|
||||
if (compilerEnv.isSelected()){
|
||||
target.values.add(new EnvironmentJson(compilerEnv));
|
||||
}
|
||||
}
|
||||
target = String.join(" ", envs);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user