--- /dev/null
+package net.mograsim.plugin.tables;
+
+import java.util.HashSet;
+import java.util.Set;
+
+import net.mograsim.plugin.asm.AsmNumberUtil.NumberType;
+
+public class DisplaySettings
+{
+ private NumberType dataNumberType;
+ private final Set<Runnable> observers;
+
+ public DisplaySettings()
+ {
+ this(NumberType.HEXADECIMAL);
+ }
+
+ public DisplaySettings(NumberType dataNumberType)
+ {
+ this.dataNumberType = dataNumberType;
+ observers = new HashSet<>();
+ }
+
+ public NumberType getDataNumberType()
+ {
+ return dataNumberType;
+ }
+
+ public void setDataNumberType(NumberType dataNumberType)
+ {
+ this.dataNumberType = dataNumberType;
+ notifyObservers();
+ }
+
+ void notifyObservers()
+ {
+ observers.forEach(r -> r.run());
+ }
+
+ public void addObserver(Runnable ob)
+ {
+ observers.add(ob);
+ }
+
+ public void removeObserver(Runnable ob)
+ {
+ observers.remove(ob);
+ }
+}
\ No newline at end of file
import org.eclipse.jface.viewers.TextCellEditor;
import net.mograsim.plugin.asm.AsmNumberUtil;
-import net.mograsim.plugin.tables.memory.DisplaySettings;
public abstract class NumberCellEditingSupport extends EditingSupport
{
import org.eclipse.jface.viewers.ColumnLabelProvider;
import net.mograsim.plugin.asm.AsmNumberUtil;
-import net.mograsim.plugin.tables.memory.DisplaySettings;
public abstract class NumberColumnLabelProvider extends ColumnLabelProvider
{
--- /dev/null
+package net.mograsim.plugin.tables;
+
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.events.SelectionEvent;
+import org.eclipse.swt.events.SelectionListener;
+import org.eclipse.swt.widgets.Combo;
+import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Label;
+
+import net.mograsim.plugin.asm.AsmNumberUtil.NumberType;
+
+public class RadixSelector
+{
+ private final Composite parent;
+ private final DisplaySettings target;
+ private Label label;
+ private Combo combo;
+
+ public RadixSelector(Composite parent, DisplaySettings target)
+ {
+ this.parent = parent;
+ this.target = target;
+ setupRadixSelector();
+ }
+
+ private void setupRadixSelector()
+ {
+ label = new Label(parent, SWT.NONE);
+ label.setText("Radix: ");
+ combo = new Combo(parent, SWT.READ_ONLY);
+
+ String entries[] = new String[] { "Binary", "Octal", "Decimal", "Hexadecimal" };
+ NumberType corTypes[] = new NumberType[] { NumberType.BINARY, NumberType.OCTAL, NumberType.DECIMAL, NumberType.HEXADECIMAL };
+ combo.setItems(entries);
+ combo.select(3);
+ combo.addSelectionListener(new SelectionListener()
+ {
+ @Override
+ public void widgetSelected(SelectionEvent e)
+ {
+ int index = combo.getSelectionIndex();
+ if (index == -1)
+ target.setDataNumberType(NumberType.HEXADECIMAL);
+ else
+ {
+ target.setDataNumberType(corTypes[index]);
+ }
+ }
+
+ @Override
+ public void widgetDefaultSelected(SelectionEvent e)
+ {
+ widgetSelected(e);
+ }
+ });
+ }
+
+ public Label getLabel()
+ {
+ return label;
+ }
+
+ public Combo getCombo()
+ {
+ return combo;
+ }
+}
+++ /dev/null
-package net.mograsim.plugin.tables.memory;
-
-import net.mograsim.plugin.asm.AsmNumberUtil.NumberType;
-
-public class DisplaySettings
-{
- private NumberType dataNumberType;
-
- public DisplaySettings(NumberType dataNumberType)
- {
- this.dataNumberType = dataNumberType;
- }
-
- public NumberType getDataNumberType()
- {
- return dataNumberType;
- }
-
- public void setDataNumberType(NumberType dataNumberType)
- {
- this.dataNumberType = dataNumberType;
- }
-}
\ No newline at end of file
import org.eclipse.jface.viewers.TableViewer;
+import net.mograsim.plugin.tables.DisplaySettings;
import net.mograsim.plugin.tables.NumberCellEditingSupport;
public class MemoryCellEditingSupport extends NumberCellEditingSupport
import org.eclipse.jface.viewers.TableViewer;
import org.eclipse.jface.viewers.TableViewerColumn;
import org.eclipse.swt.SWT;
-import org.eclipse.swt.events.SelectionEvent;
-import org.eclipse.swt.events.SelectionListener;
import org.eclipse.swt.events.VerifyListener;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
-import org.eclipse.swt.widgets.Combo;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Table;
import net.mograsim.machine.MainMemoryDefinition;
import net.mograsim.machine.standard.memory.WordAddressableMemory;
import net.mograsim.plugin.asm.AsmNumberUtil;
-import net.mograsim.plugin.asm.AsmNumberUtil.NumberType;
+import net.mograsim.plugin.tables.DisplaySettings;
import net.mograsim.plugin.tables.NumberColumnLabelProvider;
+import net.mograsim.plugin.tables.RadixSelector;
public class MemoryView extends ViewPart
{
private DisplaySettings displaySettings;
private String addressFormat;
+ @SuppressWarnings("unused")
@Override
public void createPartControl(Composite parent)
{
provider = new MemoryTableContentProvider();
- displaySettings = new DisplaySettings(NumberType.HEXADECIMAL);
+ displaySettings = new DisplaySettings();
GridLayout layout = new GridLayout(6, false);
parent.setLayout(layout);
provider.setLowerBound(AsmNumberUtil.valueOf(fromText.getText()).longValue());
viewer.refresh();
}
- catch (@SuppressWarnings("unused") NumberFormatException ex)
+ catch (NumberFormatException ex)
{
// Nothing to do here
}
provider.setAmount(AsmNumberUtil.valueOf(amountText.getText()).intValue());
viewer.refresh();
}
- catch (@SuppressWarnings("unused") NumberFormatException ex)
+ catch (NumberFormatException ex)
{
// Nothing to do here
}
});
-
- setupRadixSelector(parent);
-
+ new RadixSelector(parent, displaySettings);
createViewer(parent);
- }
-
- private void setupRadixSelector(Composite parent)
- {
- Label radixLabel = new Label(parent, SWT.NONE);
- radixLabel.setText("Radix: ");
- Combo selectRadix = new Combo(parent, SWT.READ_ONLY);
-
- String entries[] = new String[] { "Binary", "Octal", "Decimal", "Hexadecimal" };
- NumberType corTypes[] = new NumberType[] { NumberType.BINARY, NumberType.OCTAL, NumberType.DECIMAL, NumberType.HEXADECIMAL };
- selectRadix.setItems(entries);
- selectRadix.addSelectionListener(new SelectionListener()
- {
- @Override
- public void widgetSelected(SelectionEvent e)
- {
- int index = selectRadix.getSelectionIndex();
- if (index == -1)
- displaySettings.setDataNumberType(NumberType.HEXADECIMAL);
- else
- {
- displaySettings.setDataNumberType(corTypes[index]);
- }
- viewer.refresh();
- }
- @Override
- public void widgetDefaultSelected(SelectionEvent e)
- {
- widgetSelected(e);
- }
- });
+ displaySettings.addObserver(() -> viewer.refresh());
}
private void createViewer(Composite parent)
import java.io.File;
import java.io.IOException;
+import org.eclipse.jface.viewers.ColumnLabelProvider;
import org.eclipse.jface.viewers.EditingSupport;
import org.eclipse.jface.viewers.TableViewer;
import org.eclipse.jface.viewers.TableViewerColumn;
import net.mograsim.machine.mi.MicroprogramMemoryParser;
import net.mograsim.machine.mi.parameters.ParameterClassification;
import net.mograsim.plugin.asm.AsmNumberUtil.NumberType;
-import net.mograsim.plugin.tables.memory.DisplaySettings;
+import net.mograsim.plugin.tables.DisplaySettings;
+import net.mograsim.plugin.tables.RadixSelector;
import net.mograsim.plugin.util.DropDownMenu;
import net.mograsim.plugin.util.DropDownMenu.DropDownEntry;
private TableViewerColumn[] columns = new TableViewerColumn[0];
private MicroInstructionDefinition miDef;
private MicroprogramMemory memory;
+ private DisplaySettings displaySettings;
+ @SuppressWarnings("unused")
@Override
public void createPartControl(Composite parent)
{
InstructionTableContentProvider provider = new InstructionTableContentProvider();
- GridLayout layout = new GridLayout(1, false);
+ GridLayout layout = new GridLayout(3, false);
setupMenuButtons(parent);
+
+ displaySettings = new DisplaySettings();
+ new RadixSelector(parent, displaySettings);
+
parent.setLayout(layout);
viewer = new TableViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL | SWT.FULL_SELECTION | SWT.BORDER | SWT.VIRTUAL);
Table table = viewer.getTable();
viewer.setUseHashlookup(true);
viewer.setContentProvider(provider);
- viewer.getTable().setLayoutData(new GridData(GridData.GRAB_HORIZONTAL | GridData.GRAB_VERTICAL | GridData.FILL_BOTH));
+ GridData viewerData = new GridData(GridData.GRAB_HORIZONTAL | GridData.GRAB_VERTICAL | GridData.FILL_BOTH);
+ viewerData.horizontalSpan = 3;
+ viewer.getTable().setLayoutData(viewerData);
+
+ displaySettings.addObserver(() -> viewer.refresh());
}
@SuppressWarnings("unused")
int bounds = 20 + 20 * classes[i].getExpectedBits();
TableViewerColumn col = createTableViewerColumn(name, bounds);
- col.setLabelProvider(new ParameterLabelProvider(i));
- col.setEditingSupport(createEditingSupport(miDef, i));
+ createEditingAndLabel(col, miDef, i);
}
}
- private EditingSupport createEditingSupport(MicroInstructionDefinition miDef, int index)
+ private void createEditingAndLabel(TableViewerColumn col, MicroInstructionDefinition miDef, int index)
{
ParameterClassification parameterClassification = miDef.getParameterClassifications()[index];
+ EditingSupport support;
+ ColumnLabelProvider provider;
switch (parameterClassification.getExpectedType())
{
case BOOLEAN_IMMEDIATE:
- return new BooleanEditingSupport(viewer, miDef, index);
+ support = new BooleanEditingSupport(viewer, miDef, index);
+ provider = new ParameterLabelProvider(index);
+ break;
case INTEGER_IMMEDIATE:
- return new IntegerEditingSupport(viewer, miDef, index, new DisplaySettings(NumberType.DECIMAL));
+ support = new IntegerEditingSupport(viewer, miDef, index, new DisplaySettings(NumberType.DECIMAL));
+ provider = new IntegerColumnLabelProvider(displaySettings, index);
+ break;
case MNEMONIC:
- return new MnemonicEditingSupport(viewer, miDef, index);
+ support = new MnemonicEditingSupport(viewer, miDef, index);
+ provider = new ParameterLabelProvider(index);
+ break;
default:
throw new IllegalStateException(
"Unable to create EditingSupport for unknown ParameterType " + parameterClassification.getExpectedType());
}
+ col.setEditingSupport(support);
+ col.setLabelProvider(provider);
}
private TableViewerColumn createTableViewerColumn(String title, int bound)
--- /dev/null
+package net.mograsim.plugin.tables.mi;
+
+import java.math.BigInteger;
+
+import net.mograsim.machine.mi.MicroInstruction;
+import net.mograsim.machine.mi.parameters.IntegerImmediate;
+import net.mograsim.plugin.tables.DisplaySettings;
+import net.mograsim.plugin.tables.NumberColumnLabelProvider;
+
+public class IntegerColumnLabelProvider extends NumberColumnLabelProvider
+{
+ private int index;
+
+ public IntegerColumnLabelProvider(DisplaySettings displaySettings, int index)
+ {
+ super(displaySettings);
+ this.index = index;
+ }
+
+ @Override
+ public BigInteger getAsBigInteger(Object element)
+ {
+ return ((IntegerImmediate) ((MicroInstruction) element).getParameter(index)).getValueAsBigInteger();
+ }
+
+}
import net.mograsim.machine.mi.MicroInstructionDefinition;
import net.mograsim.machine.mi.parameters.IntegerClassification;
import net.mograsim.machine.mi.parameters.IntegerImmediate;
+import net.mograsim.plugin.tables.DisplaySettings;
import net.mograsim.plugin.tables.NumberCellEditingSupport;
-import net.mograsim.plugin.tables.memory.DisplaySettings;
public class IntegerEditingSupport extends NumberCellEditingSupport
{