diff --git a/prototype/compiler.cc b/prototype/compiler.cc index c5fad04..102cda3 100644 --- a/prototype/compiler.cc +++ b/prototype/compiler.cc @@ -4769,6 +4769,8 @@ void BytecodeGenerator::HandleStmt(StmtNode* stmt, body_code.push_back(Bytecode(_AQVM_OPERATOR_GOTO, body_name_ptr_index)); size_t void_name_index = global_memory_.Add(0x01, 3, "$0"); size_t void_name_ptr_index = global_memory_.Add(0x06, 8); + code.push_back(Bytecode(_AQVM_OPERATOR_PTR, void_name_index, + void_name_ptr_index)); code.push_back(Bytecode(_AQVM_OPERATOR_IF, condition_index, body_name_ptr_index, void_name_ptr_index)); break; diff --git a/prototype/hello-world.aq b/prototype/hello-world.aq new file mode 100644 index 0000000..302e182 --- /dev/null +++ b/prototype/hello-world.aq @@ -0,0 +1,4 @@ +int print(char* str){} +void main(){ + print("Hello World!"); +} \ No newline at end of file diff --git a/prototype/hello-world.aqbc b/prototype/hello-world.aqbc new file mode 100644 index 0000000..8c03d60 Binary files /dev/null and b/prototype/hello-world.aqbc differ diff --git a/prototype/vm.c b/prototype/vm.c index 1d782cf..6016171 100644 --- a/prototype/vm.c +++ b/prototype/vm.c @@ -1059,12 +1059,12 @@ int DIV(size_t result, size_t operand1, size_t operand2) { GetUint64tData(operand1) / GetUint64tData(operand2)); break; case 0x04: - SetFloatData(result, - GetUint64tData(operand1) / GetUint64tData(operand2)); + SetFloatData(result, (double)GetUint64tData(operand1) / + (double)GetUint64tData(operand2)); break; case 0x05: - SetDoubleData(result, - GetUint64tData(operand1) / GetUint64tData(operand2)); + SetDoubleData(result, (double)GetUint64tData(operand1) / + (double)GetUint64tData(operand2)); break; case 0x06: SetUint64tData(result, @@ -2464,13 +2464,13 @@ int THROW() { return 0; } int WIDE() { return 0; } void print(InternalObject args, size_t return_value) { - SetIntData(return_value, printf((char*)GetPtrData(*args.index))); + SetIntData(return_value, printf("%s", (char*)GetPtrData(*args.index))); } unsigned int hash(const char* str) { unsigned long hash = 5381; int c; - while (c = *str++) { + while ((c = *str++)) { hash = ((hash << 5) + hash) + c; } return hash % 1024; @@ -2495,7 +2495,7 @@ void* AddFunction(void* location) { void* origin_location = location; size_t all_size = is_big_endian ? *(uint64_t*)location : SwapUint64t(*(uint64_t*)location); - printf("AddFunction Size: %lu\n", all_size); + printf("AddFunction Size: %zu\n", all_size); size_t commands_size = all_size; location = (void*)((uintptr_t)location + 8); struct FuncList* table = &func_table[hash(location)]; @@ -2886,7 +2886,7 @@ int main(int argc, char* argv[]) { bytecode_file = (void*)((uintptr_t)bytecode_file + memory->size / 2); } - printf("Memory size: %lu\n", *(uint8_t*)bytecode_file); + printf("Memory size: %hhu\n", *(uint8_t*)bytecode_file); while (bytecode_file < bytecode_end) { printf("AddFunction\n");