Add STDIN interrupt and error handling for all interrupts

This commit is contained in:
2020-05-17 13:28:59 +02:00
parent f8eaabfc55
commit 06de5290da
5 changed files with 32 additions and 2 deletions

View File

@@ -34,6 +34,13 @@ namespace Execute
message += '"';
}
InterruptIndexOutOfRange::InterruptIndexOutOfRange(int const index)
{
message = "Interrupt index ";
message += std::to_string(index);
message += " is out of range";
}
namespace Internal
{
BadValueType::BadValueType()

View File

@@ -7,6 +7,7 @@ namespace Execute
{
return std::vector<InterruptFn>
{
/* STDOUT INTERRUPTS */
// 0 print char
[](Execute::Registers & registers, std::vector<std::uint8_t> & memory) { std::putc(registers.A, stdout); },
// 1 print decimal integer
@@ -21,6 +22,13 @@ namespace Execute
{
std::putc(memory[i], stdout);
}
},
/* STDIN INTERRUPTS */
// 10 get char from STDIN
[](Execute::Registers & registers, std::vector<std::uint8_t> & memory)
{
registers.A = std::getchar();
}
};
}

View File

@@ -89,7 +89,13 @@ namespace Interpret
void InterruptStatement::Execute(Execute::Flags & flags, Execute::State & state, Execute::Registers & registers)
{
state.interrupts[firstArgument.GetValue(state, registers)](registers, state.memory);
auto const interruptIndex = firstArgument.GetValue(state, registers);
if (interruptIndex < 0 || static_cast<unsigned>(interruptIndex) > state.interrupts.size())
{
throw Execute::InterruptIndexOutOfRange(interruptIndex);
}
state.interrupts[interruptIndex](registers, state.memory);
}
void PopStatement::Execute(Execute::Flags & flags, Execute::State & state, Execute::Registers & registers)