Changed mnemonic X to use BitVector X; added X for integer immediates
[Mograsim.git] / plugins / net.mograsim.plugin.core / src / net / mograsim / plugin / tables / mi / IntegerEditingSupport.java
index 4f5b616..2cc130a 100644 (file)
@@ -21,7 +21,7 @@ public class IntegerEditingSupport extends NumberCellEditingSupport
        public IntegerEditingSupport(TableViewer viewer, MicroInstructionDefinition miDef, int index, DisplaySettings displaySettings,
                        InstructionTableContentProvider provider)
        {
-               super(viewer, displaySettings);
+               super(viewer, displaySettings, true);
                classification = (IntegerClassification) miDef.getParameterClassifications()[index];
                this.index = index;
                this.provider = provider;
@@ -32,7 +32,10 @@ public class IntegerEditingSupport extends NumberCellEditingSupport
        {
                InstructionTableRow row = ((InstructionTableRow) element);
                MicroInstructionParameter[] params = row.data.getCell(row.address).getParameters();
-               params[index] = new IntegerImmediate(value, classification.getExpectedBits());
+               IntegerImmediate newParam = new IntegerImmediate(classification, value, classification.getExpectedBits());
+               if (params[index].equals(newParam))
+                       return;
+               params[index] = newParam;
                row.data.setCell(row.address, MicroInstruction.create(params));
                provider.update(row.address);
 //             viewer.update(element, null); Does not do anything for some reason
@@ -45,4 +48,11 @@ public class IntegerEditingSupport extends NumberCellEditingSupport
                return ((IntegerImmediate) row.data.getCell(row.address).getParameter(index)).getValueAsBigInteger();
        }
 
+       @Override
+       public int getBitLength(Object element)
+       {
+               return ((InstructionTableRow) element).getData().getDefinition().getMicroInstructionDefinition().getParameterClassification(index)
+                               .getExpectedBits();
+       }
+
 }