add hashmap to scope and identifier loading at runtime

This commit is contained in:
2025-07-12 03:33:59 +01:00
parent fe7eaa8de3
commit c0eb9e3a04
18 changed files with 141 additions and 35 deletions

View File

@@ -43,3 +43,11 @@ initilises a function to a given register.
6. instruction 4 and 5 loop for each argument.
7. the offset of the bytecode of the function.
8. the length of the bytecode of the function.
## OP_IDENTIFIER
initilises a function to a given register.
1. the length of the identifer.
2. the offset of the identifier.
3. the index of the source location.

View File

@@ -2,7 +2,6 @@
#define BYTECODE_DECLARATION_H
#include "../translator.h"
size_t translate_parsed_declaration(Translated *translated,
DArray delcarations);
size_t translate_parsed_declaration(Translated *translated, DArray delcarations);
#endif

View File

@@ -1,9 +1,9 @@
#ifndef BYTECODE_FUNCTION_H
#define BYTECODE_FUNCTION_H
#include "../translator.h"
#include "../../parser/function/function.h"
#include "../translator.h"
size_t translate_parsed_function(Translated *translated,
ParsedFunction *parsedFunction);
ParsedFunction *parsedFunction);
#endif

View File

@@ -4,12 +4,19 @@
#include <stdio.h>
#include <string.h>
size_t translate_parsed_identifier(Translated *translated, char* identifier) {
size_t length = strlen(identifier);
size_t identifier_pos = arena_push(&translated->constants, identifier, length);
size_t translate_parsed_identifier(Translated *translated, ParsedIdentifier *parsedIdentifier) {
size_t length = strlen(parsedIdentifier->name);
size_t identifier_pos = arena_push(&translated->constants, parsedIdentifier->name, length);
set_registers(translated, 1);
size_t start = push_instruction_byte(translated, OP_IDENTIFIER);
push_instruction_code(translated,length);
push_instruction_code(translated, identifier_pos);
SourceLocation source_locations = {
parsedIdentifier->line,
parsedIdentifier->column,
length
};
push_instruction_code(translated, translated->source_locations.size);
darray_push(&translated->source_locations, &source_locations);
return start;
}

View File

@@ -3,6 +3,6 @@
#include "../translator.h"
#include "../../parser/assignable/identifier/identifier.h"
size_t translate_parsed_identifier(Translated *translated, char* identifier);
size_t translate_parsed_identifier(Translated *translated, ParsedIdentifier *parsedIdentifier);
#endif

View File

@@ -80,6 +80,7 @@ Translated init_translator() {
Translated translated;
translated.registerCount = 0;
darray_init(&translated.bytecode, sizeof(uint8_t));
darray_init(&translated.source_locations, sizeof(SourceLocation));
arena_init(&translated.constants);
return translated;
}
@@ -124,7 +125,7 @@ size_t translate_parsed(Translated *translated, ParsedValue *parsedValue) {
return translate_parsed_function(translated,
(ParsedFunction *)parsedValue->data);
case AST_IDENTIFIER:
return translate_parsed_identifier(translated, (char *)parsedValue->data);
return translate_parsed_identifier(translated, (ParsedIdentifier *)parsedValue->data);
}
return 0;
}
@@ -138,5 +139,6 @@ void translate(Translated *translated, DArray *ast) {
void free_translator(Translated *translated) {
darray_free(&translated->bytecode, NULL);
darray_free(&translated->source_locations, NULL);
arena_free(&translated->constants);
}

View File

@@ -21,9 +21,16 @@ typedef struct {
typedef struct {
uint8_t registerCount;
DArray bytecode;
DArray source_locations;
ConstantArena constants;
} Translated;
typedef struct {
uint64_t line;
uint64_t column;
uint64_t length;
} SourceLocation;
void arena_resize(ConstantArena *arena, size_t new_size);
void *arena_get(ConstantArena *arena, size_t offset);
@@ -38,9 +45,9 @@ void set_registers(Translated *translator, uint8_t count);
Translated init_translator();
size_t translate_parsed(Translated * translator, ParsedValue * parsedValue);
size_t translate_parsed(Translated *translated, ParsedValue *parsedValue);
void translate(Translated *translator, DArray *ast);
void translate(Translated *translated, DArray *ast);
void free_translator(Translated *translated);