mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-10 08:54:11 -08:00
Add editors for some additional build options
This commit is contained in:
parent
91273ddaf7
commit
6c17490495
|
@ -18,8 +18,10 @@ Require-Bundle: org.eclipse.core.runtime;bundle-version="[3.8.0,4.0)",
|
||||||
org.eclipse.ui.editors;bundle-version="[3.8.0,4.0.0)",
|
org.eclipse.ui.editors;bundle-version="[3.8.0,4.0.0)",
|
||||||
org.eclipse.ui.ide;bundle-version="[3.8.2,4.0.0)",
|
org.eclipse.ui.ide;bundle-version="[3.8.2,4.0.0)",
|
||||||
org.eclipse.jdt.ui;bundle-version="[3.8.2,4.0.0)",
|
org.eclipse.jdt.ui;bundle-version="[3.8.2,4.0.0)",
|
||||||
org.eclipse.core.filesystem;bundle-version="[1.3.200,1.5.0)",
|
org.eclipse.core.filesystem;bundle-version="[1.3.200,2)",
|
||||||
org.eclipse.core.variables;bundle-version="[3.2.600,3.3)"
|
org.eclipse.core.variables;bundle-version="[3.2.600,4)",
|
||||||
|
org.eclipse.core.databinding.observable;bundle-version="[1.4.1,2)",
|
||||||
|
org.eclipse.jface.databinding;bundle-version="[1.6.0,2)"
|
||||||
Bundle-ClassPath: .,
|
Bundle-ClassPath: .,
|
||||||
lib/asm-5.0.1.jar,
|
lib/asm-5.0.1.jar,
|
||||||
lib/asm-commons-5.0.1.jar,
|
lib/asm-commons-5.0.1.jar,
|
||||||
|
|
|
@ -64,7 +64,7 @@
|
||||||
</extension>
|
</extension>
|
||||||
<extension point="org.eclipse.core.resources.builders" id="builder" name="TeaVM builder">
|
<extension point="org.eclipse.core.resources.builders" id="builder" name="TeaVM builder">
|
||||||
<builder hasNature="true">
|
<builder hasNature="true">
|
||||||
<run class="org.teavm.eclipse.TeaVMBuilder"/>
|
<run class="org.teavm.eclipse.TeaVMProjectBuilder"/>
|
||||||
</builder>
|
</builder>
|
||||||
</extension>
|
</extension>
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
public static final String MAIN_CLASS = "mainClass";
|
public static final String MAIN_CLASS = "mainClass";
|
||||||
public static final String TARGET_DIRECTORY = "targetDirectory";
|
public static final String TARGET_DIRECTORY = "targetDirectory";
|
||||||
public static final String TARGET_FILE_NAME = "targetFileName";
|
public static final String TARGET_FILE_NAME = "targetFileName";
|
||||||
|
public static final String RUNTIME = "runtime";
|
||||||
public static final String MINIFYING = "minifying";
|
public static final String MINIFYING = "minifying";
|
||||||
public static final String INCREMENTAL = "incremental";
|
public static final String INCREMENTAL = "incremental";
|
||||||
public static final String CACHE_DIRECTORY = "cacheDirectory";
|
public static final String CACHE_DIRECTORY = "cacheDirectory";
|
||||||
|
@ -135,6 +136,7 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
private String targetDirectory;
|
private String targetDirectory;
|
||||||
private String targetFileName;
|
private String targetFileName;
|
||||||
private boolean minifying;
|
private boolean minifying;
|
||||||
|
private TeaVMRuntimeMode runtimeMode = TeaVMRuntimeMode.SEPARATE;
|
||||||
private boolean incremental;
|
private boolean incremental;
|
||||||
private String cacheDirectory;
|
private String cacheDirectory;
|
||||||
private boolean sourceMapsGenerated;
|
private boolean sourceMapsGenerated;
|
||||||
|
@ -207,6 +209,16 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
this.minifying = minifying;
|
this.minifying = minifying;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TeaVMRuntimeMode getRuntimeMode() {
|
||||||
|
return runtimeMode;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setRuntimeMode(TeaVMRuntimeMode runtimeMode) {
|
||||||
|
this.runtimeMode = runtimeMode;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isIncremental() {
|
public boolean isIncremental() {
|
||||||
return incremental;
|
return incremental;
|
||||||
|
@ -249,12 +261,15 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Properties getProperties() {
|
public Properties getProperties() {
|
||||||
return new Properties(properties);
|
Properties copy = new Properties();
|
||||||
|
copy.putAll(properties);
|
||||||
|
return copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setProperties(Properties properties) {
|
public void setProperties(Properties properties) {
|
||||||
this.properties = new Properties(properties);
|
this.properties = new Properties();
|
||||||
|
this.properties.putAll(properties);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void load() throws BackingStoreException {
|
public void load() throws BackingStoreException {
|
||||||
|
@ -264,6 +279,7 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
targetDirectory = preferences.get(TARGET_DIRECTORY, "");
|
targetDirectory = preferences.get(TARGET_DIRECTORY, "");
|
||||||
targetFileName = preferences.get(TARGET_FILE_NAME, "");
|
targetFileName = preferences.get(TARGET_FILE_NAME, "");
|
||||||
minifying = preferences.getBoolean(MINIFYING, true);
|
minifying = preferences.getBoolean(MINIFYING, true);
|
||||||
|
runtimeMode = TeaVMRuntimeMode.valueOf(preferences.get(RUNTIME, TeaVMRuntimeMode.SEPARATE.name()));
|
||||||
incremental = preferences.getBoolean(INCREMENTAL, false);
|
incremental = preferences.getBoolean(INCREMENTAL, false);
|
||||||
cacheDirectory = preferences.get(CACHE_DIRECTORY, "");
|
cacheDirectory = preferences.get(CACHE_DIRECTORY, "");
|
||||||
sourceMapsGenerated = preferences.getBoolean(SOURCE_MAPS, true);
|
sourceMapsGenerated = preferences.getBoolean(SOURCE_MAPS, true);
|
||||||
|
@ -283,6 +299,7 @@ public class PreferencesBasedTeaVMProjectSettings implements TeaVMProjectSetting
|
||||||
preferences.put(TARGET_DIRECTORY, targetDirectory);
|
preferences.put(TARGET_DIRECTORY, targetDirectory);
|
||||||
preferences.put(TARGET_FILE_NAME, targetFileName);
|
preferences.put(TARGET_FILE_NAME, targetFileName);
|
||||||
preferences.putBoolean(MINIFYING, minifying);
|
preferences.putBoolean(MINIFYING, minifying);
|
||||||
|
preferences.put(RUNTIME, runtimeMode.name());
|
||||||
preferences.putBoolean(INCREMENTAL, incremental);
|
preferences.putBoolean(INCREMENTAL, incremental);
|
||||||
preferences.put(CACHE_DIRECTORY, cacheDirectory);
|
preferences.put(CACHE_DIRECTORY, cacheDirectory);
|
||||||
preferences.putBoolean(SOURCE_MAPS, sourceMapsGenerated);
|
preferences.putBoolean(SOURCE_MAPS, sourceMapsGenerated);
|
||||||
|
|
|
@ -10,7 +10,7 @@ import org.teavm.vm.TeaVMProgressListener;
|
||||||
* @author Alexey Andreev
|
* @author Alexey Andreev
|
||||||
*/
|
*/
|
||||||
class TeaVMEclipseProgressListener implements TeaVMProgressListener {
|
class TeaVMEclipseProgressListener implements TeaVMProgressListener {
|
||||||
private TeaVMBuilder builder;
|
private TeaVMProjectBuilder builder;
|
||||||
private IProgressMonitor progressMonitor;
|
private IProgressMonitor progressMonitor;
|
||||||
private TeaVMPhase currentPhase;
|
private TeaVMPhase currentPhase;
|
||||||
private int currentProgress;
|
private int currentProgress;
|
||||||
|
@ -18,7 +18,7 @@ class TeaVMEclipseProgressListener implements TeaVMProgressListener {
|
||||||
private int total;
|
private int total;
|
||||||
private int last;
|
private int last;
|
||||||
|
|
||||||
public TeaVMEclipseProgressListener(TeaVMBuilder builder, IProgressMonitor progressMonitor, int total) {
|
public TeaVMEclipseProgressListener(TeaVMProjectBuilder builder, IProgressMonitor progressMonitor, int total) {
|
||||||
this.builder = builder;
|
this.builder = builder;
|
||||||
this.progressMonitor = progressMonitor;
|
this.progressMonitor = progressMonitor;
|
||||||
this.total = total;
|
this.total = total;
|
||||||
|
|
|
@ -31,6 +31,10 @@ public interface TeaVMProfile {
|
||||||
|
|
||||||
void setMinifying(boolean minifying);
|
void setMinifying(boolean minifying);
|
||||||
|
|
||||||
|
TeaVMRuntimeMode getRuntimeMode();
|
||||||
|
|
||||||
|
void setRuntimeMode(TeaVMRuntimeMode runtimeMode);
|
||||||
|
|
||||||
boolean isIncremental();
|
boolean isIncremental();
|
||||||
|
|
||||||
void setIncremental(boolean incremental);
|
void setIncremental(boolean incremental);
|
||||||
|
|
|
@ -24,7 +24,7 @@ import org.teavm.tooling.TeaVMToolException;
|
||||||
*
|
*
|
||||||
* @author Alexey Andreev <konsoletyper@gmail.com>
|
* @author Alexey Andreev <konsoletyper@gmail.com>
|
||||||
*/
|
*/
|
||||||
public class TeaVMBuilder extends IncrementalProjectBuilder {
|
public class TeaVMProjectBuilder extends IncrementalProjectBuilder {
|
||||||
private static final int TICKS_PER_PROFILE = 10000;
|
private static final int TICKS_PER_PROFILE = 10000;
|
||||||
private URL[] classPath;
|
private URL[] classPath;
|
||||||
private IContainer[] sourceContainers;
|
private IContainer[] sourceContainers;
|
||||||
|
@ -39,7 +39,7 @@ public class TeaVMBuilder extends IncrementalProjectBuilder {
|
||||||
monitor.beginTask("Running TeaVM", profiles.length * TICKS_PER_PROFILE);
|
monitor.beginTask("Running TeaVM", profiles.length * TICKS_PER_PROFILE);
|
||||||
try {
|
try {
|
||||||
prepareClassPath();
|
prepareClassPath();
|
||||||
ClassLoader classLoader = new URLClassLoader(classPath, TeaVMBuilder.class.getClassLoader());
|
ClassLoader classLoader = new URLClassLoader(classPath, TeaVMProjectBuilder.class.getClassLoader());
|
||||||
for (TeaVMProfile profile : profiles) {
|
for (TeaVMProfile profile : profiles) {
|
||||||
SubProgressMonitor subMonitor = new SubProgressMonitor(monitor, TICKS_PER_PROFILE);
|
SubProgressMonitor subMonitor = new SubProgressMonitor(monitor, TICKS_PER_PROFILE);
|
||||||
buildProfile(kind, subMonitor, profile, classLoader);
|
buildProfile(kind, subMonitor, profile, classLoader);
|
||||||
|
@ -80,8 +80,8 @@ public class TeaVMBuilder extends IncrementalProjectBuilder {
|
||||||
String targetDir = profile.getTargetDirectory();
|
String targetDir = profile.getTargetDirectory();
|
||||||
tool.setTargetDirectory(new File(varManager.performStringSubstitution(targetDir)));
|
tool.setTargetDirectory(new File(varManager.performStringSubstitution(targetDir)));
|
||||||
tool.setTargetFileName(profile.getTargetFileName());
|
tool.setTargetFileName(profile.getTargetFileName());
|
||||||
tool.setRuntime(RuntimeCopyOperation.SEPARATE);
|
|
||||||
tool.setMinifying(profile.isMinifying());
|
tool.setMinifying(profile.isMinifying());
|
||||||
|
tool.setRuntime(mapRuntime(profile.getRuntimeMode()));
|
||||||
tool.setMainClass(profile.getMainClass());
|
tool.setMainClass(profile.getMainClass());
|
||||||
tool.getProperties().putAll(profile.getProperties());
|
tool.getProperties().putAll(profile.getProperties());
|
||||||
tool.setIncremental(profile.isIncremental());
|
tool.setIncremental(profile.isIncremental());
|
||||||
|
@ -105,6 +105,17 @@ public class TeaVMBuilder extends IncrementalProjectBuilder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private RuntimeCopyOperation mapRuntime(TeaVMRuntimeMode runtimeMode) {
|
||||||
|
switch (runtimeMode) {
|
||||||
|
case MERGE:
|
||||||
|
return RuntimeCopyOperation.MERGED;
|
||||||
|
case SEPARATE:
|
||||||
|
return RuntimeCopyOperation.SEPARATE;
|
||||||
|
default:
|
||||||
|
return RuntimeCopyOperation.NONE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private Set<String> classesToResources(Collection<String> classNames) {
|
private Set<String> classesToResources(Collection<String> classNames) {
|
||||||
Set<String> resourcePaths = new HashSet<>();
|
Set<String> resourcePaths = new HashSet<>();
|
||||||
for (String className : classNames) {
|
for (String className : classNames) {
|
|
@ -0,0 +1,11 @@
|
||||||
|
package org.teavm.eclipse;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Alexey Andreev <konsoletyper@gmail.com>
|
||||||
|
*/
|
||||||
|
public enum TeaVMRuntimeMode {
|
||||||
|
SEPARATE,
|
||||||
|
MERGE,
|
||||||
|
NONE
|
||||||
|
}
|
|
@ -1,5 +1,9 @@
|
||||||
package org.teavm.eclipse.ui;
|
package org.teavm.eclipse.ui;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Properties;
|
||||||
|
import org.eclipse.core.databinding.observable.list.WritableList;
|
||||||
import org.eclipse.core.resources.IProject;
|
import org.eclipse.core.resources.IProject;
|
||||||
import org.eclipse.core.resources.IResource;
|
import org.eclipse.core.resources.IResource;
|
||||||
import org.eclipse.core.resources.ResourcesPlugin;
|
import org.eclipse.core.resources.ResourcesPlugin;
|
||||||
|
@ -8,26 +12,48 @@ import org.eclipse.core.variables.VariablesPlugin;
|
||||||
import org.eclipse.jdt.core.IJavaProject;
|
import org.eclipse.jdt.core.IJavaProject;
|
||||||
import org.eclipse.jdt.core.IType;
|
import org.eclipse.jdt.core.IType;
|
||||||
import org.eclipse.jdt.core.JavaCore;
|
import org.eclipse.jdt.core.JavaCore;
|
||||||
|
import org.eclipse.jface.databinding.viewers.ObservableListContentProvider;
|
||||||
import org.eclipse.jface.dialogs.Dialog;
|
import org.eclipse.jface.dialogs.Dialog;
|
||||||
import org.eclipse.jface.dialogs.IDialogConstants;
|
import org.eclipse.jface.dialogs.IDialogConstants;
|
||||||
|
import org.eclipse.jface.dialogs.MessageDialog;
|
||||||
|
import org.eclipse.jface.viewers.CellEditor;
|
||||||
|
import org.eclipse.jface.viewers.ColumnLabelProvider;
|
||||||
|
import org.eclipse.jface.viewers.ColumnViewer;
|
||||||
|
import org.eclipse.jface.viewers.EditingSupport;
|
||||||
|
import org.eclipse.jface.viewers.TableViewer;
|
||||||
|
import org.eclipse.jface.viewers.TableViewerColumn;
|
||||||
|
import org.eclipse.jface.viewers.TextCellEditor;
|
||||||
import org.eclipse.swt.SWT;
|
import org.eclipse.swt.SWT;
|
||||||
import org.eclipse.swt.events.SelectionAdapter;
|
import org.eclipse.swt.events.SelectionAdapter;
|
||||||
import org.eclipse.swt.events.SelectionEvent;
|
import org.eclipse.swt.events.SelectionEvent;
|
||||||
import org.eclipse.swt.layout.GridData;
|
import org.eclipse.swt.layout.GridData;
|
||||||
import org.eclipse.swt.layout.GridLayout;
|
import org.eclipse.swt.layout.GridLayout;
|
||||||
import org.eclipse.swt.widgets.*;
|
import org.eclipse.swt.widgets.Button;
|
||||||
|
import org.eclipse.swt.widgets.Combo;
|
||||||
|
import org.eclipse.swt.widgets.Composite;
|
||||||
|
import org.eclipse.swt.widgets.Control;
|
||||||
|
import org.eclipse.swt.widgets.DirectoryDialog;
|
||||||
|
import org.eclipse.swt.widgets.Group;
|
||||||
|
import org.eclipse.swt.widgets.Label;
|
||||||
|
import org.eclipse.swt.widgets.MessageBox;
|
||||||
|
import org.eclipse.swt.widgets.Shell;
|
||||||
|
import org.eclipse.swt.widgets.Table;
|
||||||
|
import org.eclipse.swt.widgets.Text;
|
||||||
import org.eclipse.ui.dialogs.ElementTreeSelectionDialog;
|
import org.eclipse.ui.dialogs.ElementTreeSelectionDialog;
|
||||||
import org.eclipse.ui.model.WorkbenchContentProvider;
|
import org.eclipse.ui.model.WorkbenchContentProvider;
|
||||||
import org.eclipse.ui.model.WorkbenchLabelProvider;
|
import org.eclipse.ui.model.WorkbenchLabelProvider;
|
||||||
import org.eclipse.ui.views.navigator.ResourceComparator;
|
import org.eclipse.ui.views.navigator.ResourceComparator;
|
||||||
import org.teavm.eclipse.TeaVMProfile;
|
import org.teavm.eclipse.TeaVMProfile;
|
||||||
import org.teavm.eclipse.TeaVMProjectSettings;
|
import org.teavm.eclipse.TeaVMProjectSettings;
|
||||||
|
import org.teavm.eclipse.TeaVMRuntimeMode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Alexey Andreev <konsoletyper@gmail.com>
|
* @author Alexey Andreev <konsoletyper@gmail.com>
|
||||||
*/
|
*/
|
||||||
public class TeaVMProfileDialog extends Dialog {
|
public class TeaVMProfileDialog extends Dialog {
|
||||||
|
private static List<TeaVMRuntimeMode> runtimeModes = Arrays.asList(TeaVMRuntimeMode.SEPARATE,
|
||||||
|
TeaVMRuntimeMode.MERGE, TeaVMRuntimeMode.NONE);
|
||||||
private Text nameField;
|
private Text nameField;
|
||||||
private Text mainClassField;
|
private Text mainClassField;
|
||||||
private Button mainClassChooseButton;
|
private Button mainClassChooseButton;
|
||||||
|
@ -36,6 +62,17 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
private Button targetDirectoryFileSystemButton;
|
private Button targetDirectoryFileSystemButton;
|
||||||
private Text targetFileNameField;
|
private Text targetFileNameField;
|
||||||
private Button minifyingButton;
|
private Button minifyingButton;
|
||||||
|
private Combo runtimeField;
|
||||||
|
private Button incrementalButton;
|
||||||
|
private Text cacheDirectoryField;
|
||||||
|
private Button cacheDirectoryWorkspaceButton;
|
||||||
|
private Button cacheDirectoryFileSystemButton;
|
||||||
|
private Button debugInformationButton;
|
||||||
|
private Button sourceMapsButton;
|
||||||
|
private TableViewer propertiesTableViewer;
|
||||||
|
private Button addPropertyButton;
|
||||||
|
private Button deletePropertyButton;
|
||||||
|
private WritableList propertyList = new WritableList();
|
||||||
private IJavaProject javaProject;
|
private IJavaProject javaProject;
|
||||||
private TeaVMProjectSettings settings;
|
private TeaVMProjectSettings settings;
|
||||||
private TeaVMProfile profile;
|
private TeaVMProfile profile;
|
||||||
|
@ -61,43 +98,199 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
@Override
|
@Override
|
||||||
protected Control createDialogArea(Composite parent) {
|
protected Control createDialogArea(Composite parent) {
|
||||||
Composite area = (Composite)super.createDialogArea(parent);
|
Composite area = (Composite)super.createDialogArea(parent);
|
||||||
area.setLayoutData(new GridData(SWT.FILL, SWT.TOP, true, true));
|
area.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));
|
||||||
|
//ScrolledComposite scrollContainer = new ScrolledComposite(area, SWT.V_SCROLL | SWT.H_SCROLL);
|
||||||
|
//scrollContainer.setLayoutData(new GridData(SWT.FILL, SWT.TOP, true, true));
|
||||||
Composite container = new Composite(area, SWT.NONE);
|
Composite container = new Composite(area, SWT.NONE);
|
||||||
container.setLayoutData(new GridData(SWT.FILL, SWT.TOP, true, true));
|
container.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));
|
||||||
GridLayout layout = new GridLayout(2, false);
|
/*scrollContainer.setContent(container);
|
||||||
layout.horizontalSpacing = 5;
|
scrollContainer.setExpandHorizontal(true);
|
||||||
|
scrollContainer.setExpandVertical(true);*/
|
||||||
|
GridLayout layout = new GridLayout(1, false);
|
||||||
|
layout.marginHeight = 8;
|
||||||
|
layout.verticalSpacing = 10;
|
||||||
container.setLayout(layout);
|
container.setLayout(layout);
|
||||||
createNameField(container);
|
createMainGroup(container);
|
||||||
createMainClassField(container);
|
createOutputGroup(container);
|
||||||
createTargetDirectoryField(container);
|
createIncrementalGroup(container);
|
||||||
createTargetFileNameField(container);
|
createDebugGroup(container);
|
||||||
createMinifyField(container);
|
createPropertiesGroup(container);
|
||||||
load();
|
load();
|
||||||
|
//container.setSize(container.computeSize(SWT.DEFAULT, SWT.DEFAULT));
|
||||||
|
//scrollContainer.setMinSize(container.getSize());
|
||||||
|
//return scrollContainer;
|
||||||
return container;
|
return container;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void createMainGroup(Composite parent) {
|
||||||
|
Group group = createGroup(parent, "Main settings", 3, false);
|
||||||
|
createNameField(group);
|
||||||
|
createMainClassField(group);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createOutputGroup(Composite parent) {
|
||||||
|
Group group = createGroup(parent, "Output settings", 4, false);
|
||||||
|
createTargetDirectoryField(group);
|
||||||
|
createTargetFileNameField(group);
|
||||||
|
createRuntimeField(group);
|
||||||
|
createMinifyField(group);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createIncrementalGroup(Composite parent) {
|
||||||
|
Group group = createGroup(parent, "Incremental build settings", 4, false);
|
||||||
|
createIncrementalField(group);
|
||||||
|
createCacheDirectoryField(group);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createDebugGroup(Composite parent) {
|
||||||
|
Group group = createGroup(parent, "Debug settings", 1, false);
|
||||||
|
createDebugInformationField(group);
|
||||||
|
createSourceMapsField(group);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createPropertiesGroup(Composite parent) {
|
||||||
|
Group group = createGroup(parent, "Properties", 2, true);
|
||||||
|
propertiesTableViewer = new TableViewer(group, SWT.BORDER | SWT.V_SCROLL);
|
||||||
|
propertiesTableViewer.getTable().setLinesVisible(true);
|
||||||
|
propertiesTableViewer.getTable().setHeaderVisible(true);
|
||||||
|
propertiesTableViewer.getTable().setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true, 1, 3));
|
||||||
|
propertiesTableViewer.setContentProvider(new ObservableListContentProvider());
|
||||||
|
propertiesTableViewer.setInput(propertyList);
|
||||||
|
|
||||||
|
TableViewerColumn propertyColumn = new TableViewerColumn(propertiesTableViewer, SWT.LEFT);
|
||||||
|
propertyColumn.getColumn().setWidth(200);
|
||||||
|
propertyColumn.getColumn().setText("Property");
|
||||||
|
propertyColumn.setLabelProvider(new ColumnLabelProvider() {
|
||||||
|
@Override public String getText(Object element) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
return item.key;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
propertyColumn.setEditingSupport(new KeyValueEditingSupport(propertyColumn.getViewer(),
|
||||||
|
propertiesTableViewer.getTable()) {
|
||||||
|
@Override protected Object getValue(Object element) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
return item.key;
|
||||||
|
}
|
||||||
|
@Override protected void setValue(Object element, Object value) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
item.key = (String)value;
|
||||||
|
getViewer().update(element, null);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
TableViewerColumn valueColumn = new TableViewerColumn(propertiesTableViewer, SWT.LEFT);
|
||||||
|
valueColumn.getColumn().setWidth(200);
|
||||||
|
valueColumn.getColumn().setText("Value");
|
||||||
|
valueColumn.setLabelProvider(new ColumnLabelProvider() {
|
||||||
|
@Override public String getText(Object element) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
return item.value;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
valueColumn.setEditingSupport(new KeyValueEditingSupport(valueColumn.getViewer(),
|
||||||
|
propertiesTableViewer.getTable()) {
|
||||||
|
@Override protected Object getValue(Object element) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
return item.value;
|
||||||
|
}
|
||||||
|
@Override protected void setValue(Object element, Object value) {
|
||||||
|
KeyValue item = (KeyValue)element;
|
||||||
|
item.value = (String)value;
|
||||||
|
getViewer().update(element, null);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addPropertyButton = new Button(group, SWT.PUSH);
|
||||||
|
addPropertyButton.setText("Add");
|
||||||
|
addPropertyButton.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, false, false));
|
||||||
|
addPropertyButton.addSelectionListener(new SelectionAdapter() {
|
||||||
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
addProperty();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
deletePropertyButton = new Button(group, SWT.PUSH);
|
||||||
|
deletePropertyButton.setText("Delete");
|
||||||
|
deletePropertyButton.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, false, false));
|
||||||
|
deletePropertyButton.addSelectionListener(new SelectionAdapter() {
|
||||||
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
deleteProperty();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
static abstract class KeyValueEditingSupport extends EditingSupport {
|
||||||
|
private TextCellEditor editor;
|
||||||
|
|
||||||
|
public KeyValueEditingSupport(ColumnViewer viewer, Table table) {
|
||||||
|
super(viewer);
|
||||||
|
editor = new TextCellEditor(table);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected CellEditor getCellEditor(Object element) {
|
||||||
|
return editor;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean canEdit(Object element) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addProperty() {
|
||||||
|
KeyValue item = new KeyValue();
|
||||||
|
propertyList.add(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void deleteProperty() {
|
||||||
|
int index = propertiesTableViewer.getTable().getSelectionIndex();
|
||||||
|
if (index < 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
KeyValue item = (KeyValue)propertyList.get(index);
|
||||||
|
boolean confirmed = MessageDialog.openConfirm(getShell(), "Property deletion confirmation",
|
||||||
|
"Are you sure to delete property " + item.key + "?");
|
||||||
|
if (!confirmed) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
propertyList.remove(index);
|
||||||
|
}
|
||||||
|
|
||||||
|
static class KeyValue {
|
||||||
|
String key = "";
|
||||||
|
String value = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
private Group createGroup(Composite parent, String title, int columns, boolean fillVert) {
|
||||||
|
Group group = new Group(parent, SWT.NONE);
|
||||||
|
group.setLayoutData(new GridData(SWT.FILL, fillVert ? SWT.FILL : SWT.TOP, true, fillVert));
|
||||||
|
group.setText(title);
|
||||||
|
GridLayout layout = new GridLayout(columns, false);
|
||||||
|
layout.horizontalSpacing = 3;
|
||||||
|
layout.verticalSpacing = 2;
|
||||||
|
layout.marginWidth = 10;
|
||||||
|
group.setLayout(layout);
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
|
||||||
private void createNameField(Composite container) {
|
private void createNameField(Composite container) {
|
||||||
Label label = new Label(container, SWT.NONE);
|
Label label = new Label(container, SWT.NONE);
|
||||||
label.setText("&Name:");
|
label.setText("&Name:");
|
||||||
|
|
||||||
nameField = new Text(container, SWT.SINGLE | SWT.BORDER);
|
nameField = new Text(container, SWT.SINGLE | SWT.BORDER);
|
||||||
nameField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
nameField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false, 2, 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createMainClassField(Composite container) {
|
private void createMainClassField(Composite container) {
|
||||||
Label label = new Label(container, SWT.NONE);
|
Label label = new Label(container, SWT.NONE);
|
||||||
label.setText("&Main class:");
|
label.setText("&Main class:");
|
||||||
|
|
||||||
Composite row = new Composite(container, SWT.NONE);
|
mainClassField = new Text(container, SWT.SINGLE | SWT.BORDER);
|
||||||
row.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
|
||||||
GridLayout rowLayout = new GridLayout(2, false);
|
|
||||||
rowLayout.marginWidth = 2;
|
|
||||||
row.setLayout(rowLayout);
|
|
||||||
|
|
||||||
mainClassField = new Text(row, SWT.SINGLE | SWT.BORDER);
|
|
||||||
mainClassField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
mainClassField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
||||||
|
|
||||||
mainClassChooseButton = new Button(row, SWT.PUSH);
|
mainClassChooseButton = new Button(container, SWT.PUSH);
|
||||||
mainClassChooseButton.setText("Choose...");
|
mainClassChooseButton.setText("Choose...");
|
||||||
mainClassChooseButton.addSelectionListener(new SelectionAdapter() {
|
mainClassChooseButton.addSelectionListener(new SelectionAdapter() {
|
||||||
@Override public void widgetSelected(SelectionEvent e) {
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
@ -110,28 +303,28 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
Label label = new Label(container, SWT.NONE);
|
Label label = new Label(container, SWT.NONE);
|
||||||
label.setText("&Target directory:");
|
label.setText("&Target directory:");
|
||||||
|
|
||||||
Composite row = new Composite(container, SWT.NONE);
|
targetDirectoryField = new Text(container, SWT.SINGLE | SWT.BORDER | SWT.READ_ONLY);
|
||||||
row.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
|
||||||
GridLayout rowLayout = new GridLayout(3, false);
|
|
||||||
rowLayout.marginWidth = 2;
|
|
||||||
row.setLayout(rowLayout);
|
|
||||||
|
|
||||||
targetDirectoryField = new Text(row, SWT.SINGLE | SWT.BORDER | SWT.READ_ONLY);
|
|
||||||
targetDirectoryField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
targetDirectoryField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
||||||
|
|
||||||
targetDirectoryWorkspaceButton = new Button(row, SWT.PUSH);
|
targetDirectoryWorkspaceButton = new Button(container, SWT.PUSH);
|
||||||
targetDirectoryWorkspaceButton.setText("Workspace...");
|
targetDirectoryWorkspaceButton.setText("Workspace...");
|
||||||
targetDirectoryWorkspaceButton.addSelectionListener(new SelectionAdapter() {
|
targetDirectoryWorkspaceButton.addSelectionListener(new SelectionAdapter() {
|
||||||
@Override public void widgetSelected(SelectionEvent e) {
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
chooseWorkspaceTargetDirectory();
|
String dir = chooseWorkspaceDirectory("Please, select a target directory");
|
||||||
|
if (dir != null) {
|
||||||
|
targetDirectoryField.setText(dir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
targetDirectoryFileSystemButton = new Button(row, SWT.PUSH);
|
targetDirectoryFileSystemButton = new Button(container, SWT.PUSH);
|
||||||
targetDirectoryFileSystemButton.setText("External...");
|
targetDirectoryFileSystemButton.setText("External...");
|
||||||
targetDirectoryFileSystemButton.addSelectionListener(new SelectionAdapter() {
|
targetDirectoryFileSystemButton.addSelectionListener(new SelectionAdapter() {
|
||||||
@Override public void widgetSelected(SelectionEvent e) {
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
chooseFileSystemTargetDirectory();
|
String dir = chooseFileSystemDirectory("Please, select a target directory");
|
||||||
|
if (dir != null) {
|
||||||
|
targetDirectoryField.setText(dir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -141,13 +334,77 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
label.setText("&Target file:");
|
label.setText("&Target file:");
|
||||||
|
|
||||||
targetFileNameField = new Text(container, SWT.SINGLE | SWT.BORDER);
|
targetFileNameField = new Text(container, SWT.SINGLE | SWT.BORDER);
|
||||||
targetFileNameField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
targetFileNameField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false, 3, 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createRuntimeField(Composite container) {
|
||||||
|
Label label = new Label(container, SWT.NONE);
|
||||||
|
label.setText("Attach &runtime:");
|
||||||
|
|
||||||
|
runtimeField = new Combo(container, SWT.DROP_DOWN | SWT.READ_ONLY);
|
||||||
|
runtimeField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, false, false, 3, 1));
|
||||||
|
runtimeField.add("as a separate file (runtime.js)");
|
||||||
|
runtimeField.add("merge into output file");
|
||||||
|
runtimeField.add("don't attach");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createMinifyField(Composite container) {
|
private void createMinifyField(Composite container) {
|
||||||
minifyingButton = new Button(container, SWT.CHECK);
|
minifyingButton = new Button(container, SWT.CHECK);
|
||||||
minifyingButton.setLayoutData(new GridData(SWT.LEFT, SWT.CENTER, false, false, 2, 1));
|
minifyingButton.setLayoutData(new GridData(SWT.LEFT, SWT.CENTER, false, false, 4, 1));
|
||||||
minifyingButton.setText("generate minified (obfuscated) code");
|
minifyingButton.setText("generate minified (&obfuscated) code");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createIncrementalField(Composite container) {
|
||||||
|
incrementalButton = new Button(container, SWT.CHECK);
|
||||||
|
incrementalButton.setLayoutData(new GridData(SWT.LEFT, SWT.CENTER, false, false, 4, 1));
|
||||||
|
incrementalButton.setText("Build &incrementally");
|
||||||
|
incrementalButton.addSelectionListener(new SelectionAdapter() {
|
||||||
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
updateCacheFieldsEnabled();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createCacheDirectoryField(Composite container) {
|
||||||
|
Label label = new Label(container, SWT.NONE);
|
||||||
|
label.setText("Cac&he directory:");
|
||||||
|
|
||||||
|
cacheDirectoryField = new Text(container, SWT.SINGLE | SWT.BORDER | SWT.READ_ONLY);
|
||||||
|
cacheDirectoryField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false));
|
||||||
|
|
||||||
|
cacheDirectoryWorkspaceButton = new Button(container, SWT.PUSH);
|
||||||
|
cacheDirectoryWorkspaceButton.setText("Workspace...");
|
||||||
|
cacheDirectoryWorkspaceButton.addSelectionListener(new SelectionAdapter() {
|
||||||
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
String dir = chooseWorkspaceDirectory("Please, select a directory for the incremental cache");
|
||||||
|
if (dir != null) {
|
||||||
|
cacheDirectoryField.setText(dir);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
cacheDirectoryFileSystemButton = new Button(container, SWT.PUSH);
|
||||||
|
cacheDirectoryFileSystemButton.setText("External...");
|
||||||
|
cacheDirectoryFileSystemButton.addSelectionListener(new SelectionAdapter() {
|
||||||
|
@Override public void widgetSelected(SelectionEvent e) {
|
||||||
|
String dir = chooseFileSystemDirectory("Please, select a directory for the incremental cache");
|
||||||
|
if (dir != null) {
|
||||||
|
cacheDirectoryField.setText(dir);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
updateCacheFieldsEnabled();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createDebugInformationField(Composite container) {
|
||||||
|
debugInformationButton = new Button(container, SWT.CHECK);
|
||||||
|
debugInformationButton.setText("Generate debug information for TeaVM native debugger");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createSourceMapsField(Composite container) {
|
||||||
|
sourceMapsButton = new Button(container, SWT.CHECK);
|
||||||
|
sourceMapsButton.setText("Generate source maps");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setProject(IProject project) throws CoreException {
|
public void setProject(IProject project) throws CoreException {
|
||||||
|
@ -169,11 +426,11 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void chooseWorkspaceTargetDirectory() {
|
private String chooseWorkspaceDirectory(String prompt) {
|
||||||
ElementTreeSelectionDialog dialog = new ElementTreeSelectionDialog(getShell(), new WorkbenchLabelProvider(),
|
ElementTreeSelectionDialog dialog = new ElementTreeSelectionDialog(getShell(), new WorkbenchLabelProvider(),
|
||||||
new WorkbenchContentProvider());
|
new WorkbenchContentProvider());
|
||||||
dialog.setTitle("Selecting target directory");
|
dialog.setTitle("Selecting directory");
|
||||||
dialog.setMessage("Please, select a target directory for TeaVM build");
|
dialog.setMessage(prompt);
|
||||||
dialog.setInput(ResourcesPlugin.getWorkspace().getRoot());
|
dialog.setInput(ResourcesPlugin.getWorkspace().getRoot());
|
||||||
dialog.setComparator(new ResourceComparator(ResourceComparator.NAME));
|
dialog.setComparator(new ResourceComparator(ResourceComparator.NAME));
|
||||||
if (dialog.open() == IDialogConstants.OK_ID) {
|
if (dialog.open() == IDialogConstants.OK_ID) {
|
||||||
|
@ -182,18 +439,18 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
String path = resource.getFullPath().toString();
|
String path = resource.getFullPath().toString();
|
||||||
String fileLoc = VariablesPlugin.getDefault().getStringVariableManager()
|
String fileLoc = VariablesPlugin.getDefault().getStringVariableManager()
|
||||||
.generateVariableExpression("workspace_loc", path);
|
.generateVariableExpression("workspace_loc", path);
|
||||||
targetDirectoryField.setText(fileLoc);
|
return fileLoc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void chooseFileSystemTargetDirectory() {
|
private String chooseFileSystemDirectory(String prompt) {
|
||||||
String filePath = targetDirectoryField.getText();
|
String filePath = targetDirectoryField.getText();
|
||||||
DirectoryDialog dialog = new DirectoryDialog(getShell());
|
DirectoryDialog dialog = new DirectoryDialog(getShell());
|
||||||
|
dialog.setMessage(prompt);
|
||||||
filePath = dialog.open();
|
filePath = dialog.open();
|
||||||
if (filePath != null) {
|
return filePath;
|
||||||
targetDirectoryField.setText(filePath);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -208,12 +465,32 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateCacheFieldsEnabled() {
|
||||||
|
cacheDirectoryField.setEnabled(incrementalButton.getSelection());
|
||||||
|
cacheDirectoryFileSystemButton.setEnabled(incrementalButton.getSelection());
|
||||||
|
cacheDirectoryWorkspaceButton.setEnabled(incrementalButton.getSelection());
|
||||||
|
}
|
||||||
|
|
||||||
private void load() {
|
private void load() {
|
||||||
nameField.setText(profile.getName());
|
nameField.setText(profile.getName());
|
||||||
mainClassField.setText(profile.getMainClass() != null ? profile.getMainClass() : "");
|
mainClassField.setText(profile.getMainClass() != null ? profile.getMainClass() : "");
|
||||||
targetDirectoryField.setText(profile.getTargetDirectory());
|
targetDirectoryField.setText(profile.getTargetDirectory());
|
||||||
targetFileNameField.setText(profile.getTargetFileName());
|
targetFileNameField.setText(profile.getTargetFileName());
|
||||||
minifyingButton.setSelection(profile.isMinifying());
|
minifyingButton.setSelection(profile.isMinifying());
|
||||||
|
runtimeField.select(runtimeModes.indexOf(profile.getRuntimeMode()));
|
||||||
|
incrementalButton.setSelection(profile.isIncremental());
|
||||||
|
cacheDirectoryField.setText(profile.getCacheDirectory());
|
||||||
|
debugInformationButton.setSelection(profile.isDebugInformationGenerated());
|
||||||
|
sourceMapsButton.setSelection(profile.isSourceMapsGenerated());
|
||||||
|
propertyList.clear();
|
||||||
|
Properties properties = profile.getProperties();
|
||||||
|
for (Object key : properties.keySet()) {
|
||||||
|
KeyValue property = new KeyValue();
|
||||||
|
property.key = (String)key;
|
||||||
|
property.value = properties.getProperty((String)key);
|
||||||
|
propertyList.add(property);
|
||||||
|
}
|
||||||
|
updateCacheFieldsEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean save() {
|
private boolean save() {
|
||||||
|
@ -228,6 +505,17 @@ public class TeaVMProfileDialog extends Dialog {
|
||||||
profile.setTargetDirectory(targetDirectoryField.getText());
|
profile.setTargetDirectory(targetDirectoryField.getText());
|
||||||
profile.setTargetFileName(targetFileNameField.getText().trim());
|
profile.setTargetFileName(targetFileNameField.getText().trim());
|
||||||
profile.setMinifying(minifyingButton.getSelection());
|
profile.setMinifying(minifyingButton.getSelection());
|
||||||
|
profile.setRuntimeMode(runtimeModes.get(runtimeField.getSelectionIndex()));
|
||||||
|
profile.setIncremental(incrementalButton.getSelection());
|
||||||
|
profile.setCacheDirectory(cacheDirectoryField.getText());
|
||||||
|
profile.setDebugInformationGenerated(debugInformationButton.getSelection());
|
||||||
|
profile.setSourceMapsGenerated(sourceMapsButton.getSelection());
|
||||||
|
Properties properties = new Properties();
|
||||||
|
for (Object item : propertyList) {
|
||||||
|
KeyValue property = (KeyValue)item;
|
||||||
|
properties.setProperty(property.key, property.value);
|
||||||
|
}
|
||||||
|
profile.setProperties(properties);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ import org.eclipse.core.resources.IProject;
|
||||||
import org.eclipse.core.runtime.CoreException;
|
import org.eclipse.core.runtime.CoreException;
|
||||||
import org.eclipse.core.runtime.IStatus;
|
import org.eclipse.core.runtime.IStatus;
|
||||||
import org.eclipse.jface.dialogs.ErrorDialog;
|
import org.eclipse.jface.dialogs.ErrorDialog;
|
||||||
|
import org.eclipse.jface.dialogs.MessageDialog;
|
||||||
import org.eclipse.swt.SWT;
|
import org.eclipse.swt.SWT;
|
||||||
import org.eclipse.swt.events.SelectionAdapter;
|
import org.eclipse.swt.events.SelectionAdapter;
|
||||||
import org.eclipse.swt.events.SelectionEvent;
|
import org.eclipse.swt.events.SelectionEvent;
|
||||||
|
@ -181,6 +182,11 @@ public class TeaVMProjectPropertyPage extends PropertyPage implements IWorkbench
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
TableItem item = profilesTable.getSelection()[0];
|
TableItem item = profilesTable.getSelection()[0];
|
||||||
|
boolean confirmed = MessageDialog.openConfirm(getShell(), "Deletion confirmation",
|
||||||
|
"Are you sure to delete profile " + item.getText(0) + "?");
|
||||||
|
if (!confirmed) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
settings.deleteProfile((TeaVMProfile)item.getData());
|
settings.deleteProfile((TeaVMProfile)item.getData());
|
||||||
item.dispose();
|
item.dispose();
|
||||||
}
|
}
|
||||||
|
@ -189,6 +195,10 @@ public class TeaVMProjectPropertyPage extends PropertyPage implements IWorkbench
|
||||||
public boolean performOk() {
|
public boolean performOk() {
|
||||||
try {
|
try {
|
||||||
updateNature();
|
updateNature();
|
||||||
|
for (int i = 0; i < profilesTable.getItemCount(); ++i) {
|
||||||
|
TableItem item = profilesTable.getItem(i);
|
||||||
|
storeItem(item);
|
||||||
|
}
|
||||||
settings.save();
|
settings.save();
|
||||||
} catch (CoreException e) {
|
} catch (CoreException e) {
|
||||||
reportStatus(e.getStatus());
|
reportStatus(e.getStatus());
|
||||||
|
|
Loading…
Reference in New Issue
Block a user