package net.mograsim.machine.mi.parameters;
+import static net.mograsim.logic.core.types.Bit.X;
+
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
-import net.mograsim.logic.core.types.Bit;
import net.mograsim.logic.core.types.BitVector;
+import net.mograsim.machine.MachineException;
import net.mograsim.machine.mi.parameters.MicroInstructionParameter.ParameterType;
public class MnemonicFamily implements ParameterClassification
MnemonicFamily(String defaultValueName, MnemonicPair... values)
{
+ if (values.length == 0)
+ throw new MachineException("Mnemonics must not be empty!");
this.values = new Mnemonic[values.length];
this.stringValues = new String[values.length];
setup(values);
- int defaultValueIndex = -1;
+ // if no valid defaultValue is specified, pick first value as default
+ int defaultValueIndex = 0;
for (int i = 0; i < values.length; i++)
if (stringValues[i].equals(defaultValueName))
{
public MnemonicFamilyBuilder addX()
{
- pairs.add(new MnemonicPair("X", BitVector.of(Bit.ZERO, bits)));
+ pairs.add(new MnemonicPair("X", BitVector.of(X, bits)));
return this;
}