package net.mograsim.plugin.tables.mi;
import org.eclipse.jface.viewers.CellEditor;
-import org.eclipse.jface.viewers.CheckboxCellEditor;
import org.eclipse.jface.viewers.EditingSupport;
import org.eclipse.jface.viewers.TableViewer;
-import net.mograsim.logic.core.types.Bit;
import net.mograsim.machine.mi.MicroInstruction;
import net.mograsim.machine.mi.MicroInstructionDefinition;
import net.mograsim.machine.mi.parameters.BooleanClassification;
super(viewer);
this.viewer = viewer;
this.boolClass = (BooleanClassification) definition.getParameterClassification(index);
- editor = new CheckboxCellEditor(viewer.getTable());
+ editor = new CyclingCellEditor(viewer.getTable(), boolClass.size());// new CheckboxCellEditor(viewer.getTable());
this.index = index;
}
{
InstructionTableRow row = (InstructionTableRow) element;
// true is 0 because the true value comes first in the combo box
- return row.data.getCell(row.address).getParameter(index).getValue().getMSBit(0).equals(Bit.ONE);
+ return ((Mnemonic) row.data.getCell(row.address).getParameter(index)).ordinal();
}
@Override
InstructionTableRow row = (InstructionTableRow) element;
MicroInstructionParameter[] params = row.data.getCell(row.address).getParameters();
// true is 0 because the true value comes first in the combo box
- Mnemonic newParam = boolClass.get((Boolean) value);
+ Mnemonic newParam = boolClass.get((Integer) value);
params[index] = newParam;
row.data.setCell(row.address, MicroInstruction.create(params));
--- /dev/null
+package net.mograsim.plugin.tables.mi;
+
+import org.eclipse.jface.viewers.CellEditor;
+import org.eclipse.swt.widgets.Composite;
+import org.eclipse.swt.widgets.Control;
+
+public class CyclingCellEditor extends CellEditor
+{
+ private final int size;
+ private int index = -1;
+
+ public CyclingCellEditor(int size)
+ {
+ super();
+ this.size = size;
+ }
+
+ public CyclingCellEditor(Composite parent, int size)
+ {
+ super(parent);
+ this.size = size;
+ }
+
+ public CyclingCellEditor(Composite parent, int size, int style)
+ {
+ super(parent, style);
+ this.size = size;
+ }
+
+ @Override
+ protected Control createControl(Composite parent)
+ {
+ // Nothing to return
+ return null;
+ }
+
+ @Override
+ protected Object doGetValue()
+ {
+ return index;
+ }
+
+ @Override
+ protected void doSetFocus()
+ {
+ // Nothing to focus
+ }
+
+ @Override
+ protected void doSetValue(Object index)
+ {
+ this.index = (Integer) index;
+ }
+
+ @Override
+ public void activate()
+ {
+ index = (index + 1) % size;
+ fireApplyEditorValue();
+ }
+}