2023-11-19 02:12:44 +03:00
|
|
|
|
package Visual_DVM_2021.Passes.All;
|
2024-10-07 14:22:52 +03:00
|
|
|
|
import Common.CommonConstants;
|
2024-10-08 00:39:13 +03:00
|
|
|
|
import Common.CurrentAnchestor;
|
2024-10-08 01:30:25 +03:00
|
|
|
|
import Common.Utils.CommonUtils;
|
2024-10-09 22:01:19 +03:00
|
|
|
|
import _VisualDVM.Current;
|
2024-10-08 22:33:49 +03:00
|
|
|
|
import Common.Visual.Windows.Dialog.Dialog;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
import GlobalData.Compiler.Compiler;
|
|
|
|
|
|
import GlobalData.Compiler.CompilerType;
|
|
|
|
|
|
import GlobalData.CompilerEnvironment.CompilerEnvironment;
|
|
|
|
|
|
import GlobalData.CompilerEnvironment.UI.CompilerEnvironmentsFields;
|
|
|
|
|
|
import GlobalData.EnvironmentValue.EnvironmentValue;
|
2024-10-08 01:30:25 +03:00
|
|
|
|
import GlobalData.GlobalDatabase;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
import GlobalData.RunConfiguration.RunConfiguration;
|
2023-11-19 02:12:44 +03:00
|
|
|
|
import Visual_DVM_2021.Passes.PassCode_2021;
|
|
|
|
|
|
import Visual_DVM_2021.Passes.Pass_2021;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
|
|
|
|
|
|
import javax.swing.*;
|
|
|
|
|
|
import java.util.LinkedHashMap;
|
|
|
|
|
|
public class PickCompilerEnvironments extends Pass_2021<String> {
|
|
|
|
|
|
Compiler compiler = null;
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getIconPath() {
|
|
|
|
|
|
return "/icons/Menu/Regions.png";
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public String getButtonText() {
|
|
|
|
|
|
return "";
|
|
|
|
|
|
}
|
|
|
|
|
|
//-
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected boolean canStart(Object... args) throws Exception {
|
2024-10-08 00:39:13 +03:00
|
|
|
|
if (CurrentAnchestor.Check(Log, Current.RunConfiguration)) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
RunConfiguration configuration = Current.getRunConfiguration();
|
2024-10-07 14:22:52 +03:00
|
|
|
|
if (configuration.compiler_id == CommonConstants.Nan) {
|
2023-09-17 22:13:42 +03:00
|
|
|
|
Log.Writeln_("Отсутвует DVM компилятор, связанный с текущей конфигурацией запуска.\n" +
|
|
|
|
|
|
"Если конфигурация содержит вызов DVM компилятора, но была создана на версии 801 и ниже,\n" +
|
|
|
|
|
|
"войдите в окно её редактирования,нажмите ОК, а затем повторите попытку.");
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
//-
|
|
|
|
|
|
compiler = configuration.getCompiler();
|
|
|
|
|
|
if (!compiler.type.equals(CompilerType.dvm)) {
|
|
|
|
|
|
Log.Writeln_("Выбор переменных окружения возможен только для DVM компилятора,");
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
//-
|
|
|
|
|
|
if (!(compiler.helpLoaded || passes.get(PassCode_2021.ShowCompilerHelp).Do(compiler, false)))
|
|
|
|
|
|
return false;
|
|
|
|
|
|
//-
|
|
|
|
|
|
Dialog<String, CompilerEnvironmentsFields> dialog =
|
|
|
|
|
|
new Dialog<String, CompilerEnvironmentsFields>(CompilerEnvironmentsFields.class) {
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public void InitFields() {
|
|
|
|
|
|
compiler.environments.mountUI((JPanel) fields.getContent());
|
|
|
|
|
|
compiler.environments.ShowUI();
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public boolean NeedsScroll() {
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
public void validateFields() {
|
|
|
|
|
|
for (CompilerEnvironment compilerEnv : compiler.environments.Data.values()) {
|
|
|
|
|
|
if (compilerEnv.isSelected() && compilerEnv.value.isEmpty())
|
|
|
|
|
|
Log.Writeln_("Отмеченная переменная " + compilerEnv.name + " предполагает непустое значение.");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
return dialog.ShowDialog("Назначение переменных окружения конфигурации запуска");
|
|
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void body() throws Exception {
|
|
|
|
|
|
LinkedHashMap<String, String> envValues = Current.getRunConfiguration().getEnvMap();
|
|
|
|
|
|
for (CompilerEnvironment compilerEnv : compiler.environments.Data.values()) {
|
|
|
|
|
|
if (compilerEnv.isSelected()) {
|
|
|
|
|
|
EnvironmentValue confEnv;
|
|
|
|
|
|
if (!envValues.containsKey(compilerEnv.name)) {
|
|
|
|
|
|
confEnv = new EnvironmentValue();
|
|
|
|
|
|
confEnv.machine_id = Current.getRunConfiguration().machine_id;
|
|
|
|
|
|
confEnv.run_configuration_id = Current.getRunConfiguration().id;
|
|
|
|
|
|
confEnv.name = compilerEnv.name;
|
|
|
|
|
|
confEnv.value = compilerEnv.value;
|
2024-10-08 01:30:25 +03:00
|
|
|
|
CommonUtils.db.Insert(confEnv);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
} else {
|
2024-10-08 01:30:25 +03:00
|
|
|
|
confEnv = ((GlobalDatabase)CommonUtils.db).environmentValues.getEnvByName(compilerEnv.name);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
if (confEnv != null) {
|
|
|
|
|
|
confEnv.name = compilerEnv.name;
|
|
|
|
|
|
confEnv.value = compilerEnv.value;
|
2024-10-08 01:30:25 +03:00
|
|
|
|
CommonUtils.db.Update(confEnv);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showDone() throws Exception {
|
2024-10-08 01:30:25 +03:00
|
|
|
|
((GlobalDatabase)CommonUtils.db).environmentValues.ShowUI();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|