diff options
| -rw-r--r-- | src/runtime.c | 31 | ||||
| -rw-r--r-- | src/runtime.h | 11 | 
2 files changed, 42 insertions, 0 deletions
| diff --git a/src/runtime.c b/src/runtime.c index 57101e0..d938c46 100644 --- a/src/runtime.c +++ b/src/runtime.c @@ -335,3 +335,34 @@ data_t vm_pop_word(vm_t *vm)    }    return DWORD(w);  } + +void vm_not_byte(vm_t *vm) +{ +  if (vm->stack.ptr == 0) +    // TODO: Error STACK_UNDERFLOW +    return; + +  byte a = vm_pop_byte(vm).as_byte; +  vm_push_byte(vm, DBYTE(!a)); +} + +void vm_not_hword(vm_t *vm) +{ +  if (vm->stack.ptr < HWORD_SIZE) +    // TODO: Error STACK_UNDERFLOW +    return; + +  hword a = vm_pop_hword(vm).as_hword; +  vm_push_hword(vm, DHWORD(!a)); +} + +void vm_not_word(vm_t *vm) +{ +  if (vm->stack.ptr < WORD_SIZE) +    // TODO: Error STACK_UNDERFLOW +    return; + +  word a = vm_pop_word(vm).as_word; +  vm_push_word(vm, DWORD(!a)); +} + diff --git a/src/runtime.h b/src/runtime.h index 8ff0142..4a2f849 100644 --- a/src/runtime.h +++ b/src/runtime.h @@ -100,4 +100,15 @@ static const pop_f POP_ROUTINES[] = {      [OP_POP_WORD]  = vm_pop_word,  }; +void vm_not_byte(vm_t *); +void vm_not_hword(vm_t *); +void vm_not_word(vm_t *); + +typedef void (*not_f)(vm_t *); +static const not_f NOT_ROUTINES[] = { +    [OP_NOT_BYTE]  = vm_not_byte, +    [OP_NOT_HWORD] = vm_not_hword, +    [OP_NOT_WORD]  = vm_not_word, +}; +  #endif | 
