Compare commits
2 commits
647f739d08
...
2ce8200366
Author | SHA1 | Date | |
---|---|---|---|
2ce8200366 | |||
471cf679cd |
7 changed files with 127 additions and 6 deletions
4
make.sh
4
make.sh
|
@ -5,5 +5,7 @@ gcc `find src/ -name '*.c'` \
|
||||||
submodules/utilitiec/build/lib/liballocator-interface.a \
|
submodules/utilitiec/build/lib/liballocator-interface.a \
|
||||||
submodules/utilitiec/build/lib/libStringView.a \
|
submodules/utilitiec/build/lib/libStringView.a \
|
||||||
submodules/utilitiec/build/lib/libScratchpad.a \
|
submodules/utilitiec/build/lib/libScratchpad.a \
|
||||||
|
submodules/utilitiec/build/lib/libhashmap.a \
|
||||||
|
submodules/utilitiec/build/lib/libsiphash.a \
|
||||||
-Isubmodules/utilitiec/src \
|
-Isubmodules/utilitiec/src \
|
||||||
-lm -ggdb -Wall -Wextra -pedantic -o bin/flup
|
-lm -ggdb -Wall -Wextra -pedantic -o bin/flup && echo "build successful"
|
||||||
|
|
|
@ -53,6 +53,21 @@ int CallFrame_DefineVariable(CallFrame* self, StringView name, Value value)
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int CallFrame_DefineObjectType(CallFrame* self, ObjectType* type)
|
||||||
|
{
|
||||||
|
FlupType* t = CallFrame_Reserve(self, sizeof(FlupType), alignof(FlupType));
|
||||||
|
if (t == NULL) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
t->type = type;
|
||||||
|
|
||||||
|
// prepend to linked list
|
||||||
|
t->next = self->types;
|
||||||
|
self->types = t;
|
||||||
|
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
int CallFrame_StackPop(CallFrame* self, Value* dest)
|
int CallFrame_StackPop(CallFrame* self, Value* dest)
|
||||||
{
|
{
|
||||||
|
|
|
@ -27,6 +27,11 @@
|
||||||
#include "../submodules/utilitiec/src/StringView/StringView.h"
|
#include "../submodules/utilitiec/src/StringView/StringView.h"
|
||||||
#include "../submodules/utilitiec/src/Scratchpad/Scratchpad.h"
|
#include "../submodules/utilitiec/src/Scratchpad/Scratchpad.h"
|
||||||
|
|
||||||
|
typedef struct FlupType_s {
|
||||||
|
ObjectType* type;
|
||||||
|
struct FlupType_s* next;
|
||||||
|
} FlupType;
|
||||||
|
|
||||||
typedef struct CallFrame_s {
|
typedef struct CallFrame_s {
|
||||||
size_t instruction_pointer;
|
size_t instruction_pointer;
|
||||||
/* ip = condition start : start
|
/* ip = condition start : start
|
||||||
|
@ -34,9 +39,11 @@ typedef struct CallFrame_s {
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
FlupFunction* self_function;
|
FlupFunction* self_function;
|
||||||
|
|
||||||
FlupFunctionAlternative* alternative;
|
FlupFunctionAlternative* alternative;
|
||||||
FlupFunction* functions; // functions defined in this callframe
|
FlupFunction* functions; // functions defined in this callframe
|
||||||
FlupVariable* variables; // variables defined in this callframe
|
FlupVariable* variables; // variables defined in this callframe
|
||||||
|
FlupType* types; // types defined in this callframe
|
||||||
DynamicArray stack; // Value
|
DynamicArray stack; // Value
|
||||||
Scratchpad memory_pad;
|
Scratchpad memory_pad;
|
||||||
} CallFrame;
|
} CallFrame;
|
||||||
|
@ -45,6 +52,7 @@ int CallFrame_Create(CallFrame* self, FlupFunction* self_function);
|
||||||
void CallFrame_Destroy(CallFrame* self);
|
void CallFrame_Destroy(CallFrame* self);
|
||||||
|
|
||||||
int CallFrame_DefineVariable(CallFrame* self, StringView name, Value value);
|
int CallFrame_DefineVariable(CallFrame* self, StringView name, Value value);
|
||||||
|
int CallFrame_DefineObjectType(CallFrame* self, ObjectType* type);
|
||||||
int CallFrame_StackPop(CallFrame* self, Value* dest);
|
int CallFrame_StackPop(CallFrame* self, Value* dest);
|
||||||
int CallFrame_StackPush(CallFrame* self, Value* value);
|
int CallFrame_StackPush(CallFrame* self, Value* value);
|
||||||
FlupVariable* CallFrame_FindVariable(CallFrame* self, StringView name);
|
FlupVariable* CallFrame_FindVariable(CallFrame* self, StringView name);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include "interpreter.h"
|
#include "interpreter.h"
|
||||||
#include "builtin-functions.h"
|
#include "builtin-functions.h"
|
||||||
|
#include "object-type.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdalign.h>
|
#include <stdalign.h>
|
||||||
|
@ -484,6 +485,11 @@ int Interpreter_ExecuteNext(Interpreter* self, size_t stop_token)
|
||||||
top_frame->instruction_pointer++;
|
top_frame->instruction_pointer++;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case TOKENTYPE_STRING:
|
||||||
|
{
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case TOKENTYPE_PIPE:
|
case TOKENTYPE_PIPE:
|
||||||
case TOKENTYPE_SEMICOLON:
|
case TOKENTYPE_SEMICOLON:
|
||||||
case TOKENTYPE_LEFT_BRACE:
|
case TOKENTYPE_LEFT_BRACE:
|
||||||
|
@ -500,7 +506,6 @@ int Interpreter_ExecuteNext(Interpreter* self, size_t stop_token)
|
||||||
case TOKENTYPE_COMMA:
|
case TOKENTYPE_COMMA:
|
||||||
case TOKENTYPE_LEFT_PAREN:
|
case TOKENTYPE_LEFT_PAREN:
|
||||||
case TOKENTYPE_RIGHT_PAREN:
|
case TOKENTYPE_RIGHT_PAREN:
|
||||||
case TOKENTYPE_STRING:
|
|
||||||
fprintf(stderr, "Unexpected token with type: %s, continuing with next token...\n", TokenType_ToString(t->type));
|
fprintf(stderr, "Unexpected token with type: %s, continuing with next token...\n", TokenType_ToString(t->type));
|
||||||
top_frame->instruction_pointer++;
|
top_frame->instruction_pointer++;
|
||||||
break;
|
break;
|
||||||
|
@ -620,6 +625,40 @@ int Interpreter_Run(Interpreter* self)
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int Interpreter_Startup(Interpreter* self, CallFrame* root_frame)
|
||||||
|
{
|
||||||
|
ObjectType* base_type = CallFrame_Reserve(root_frame, sizeof(ObjectType), alignof(ObjectType));
|
||||||
|
if (ObjectType_Create(base_type, StringView_FromString("Base"), base_type, 0, NULL)) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectType* list_type = CallFrame_Reserve(root_frame, sizeof(ObjectType), alignof(ObjectType));
|
||||||
|
if (ObjectType_Create(list_type, StringView_FromString("List"), base_type, 2, NULL)) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
if (ObjectType_DefineObjectAttribute(list_type, base_type, StringView_FromString("value"))) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
if (ObjectType_DefineObjectAttribute(list_type, list_type, StringView_FromString("tail"))) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
if (CallFrame_DefineObjectType(root_frame, list_type)) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectType* char_type = CallFrame_Reserve(root_frame, sizeof(ObjectType), alignof(ObjectType));
|
||||||
|
if (ObjectType_Create(char_type, StringView_FromString("Char"), base_type, 2, NULL)) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
if (ObjectType_DefinePrimitiveAttribute(list_type, VALUETYPE_BYTE, StringView_FromString("char"))) {
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
self->implicit_char_type = char_type;
|
||||||
|
self->implicit_base_type = base_type;
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
int Interpreter_Interpret(Interpreter* self)
|
int Interpreter_Interpret(Interpreter* self)
|
||||||
{
|
{
|
||||||
CallFrame* first_frame;
|
CallFrame* first_frame;
|
||||||
|
|
|
@ -19,6 +19,10 @@ struct Interpreter_s {
|
||||||
|
|
||||||
DynamicArray* tokens;
|
DynamicArray* tokens;
|
||||||
DynamicArray call_frames; // stores CallFrame
|
DynamicArray call_frames; // stores CallFrame
|
||||||
|
|
||||||
|
// global stuff
|
||||||
|
ObjectType* implicit_char_type;
|
||||||
|
ObjectType* implicit_base_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
int Interpreter_Create(Interpreter* self, DynamicArray* tokens);
|
int Interpreter_Create(Interpreter* self, DynamicArray* tokens);
|
||||||
|
|
45
src/object-type.c
Normal file
45
src/object-type.c
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
#include "object-type.h"
|
||||||
|
|
||||||
|
int ObjectType_Create(ObjectType* self, StringView name, ObjectType* supertype, size_t attribute_count_guess, allocator_t* allocator)
|
||||||
|
{
|
||||||
|
struct HashMapConfig config = HashMap_DefaultConfig();
|
||||||
|
config.allocator = allocator;
|
||||||
|
int hashmap_code = HashMap_Create(&self->attributes, &config, attribute_count_guess * (1 / config.load_factor) + 1);
|
||||||
|
if (hashmap_code) {
|
||||||
|
return hashmap_code;
|
||||||
|
}
|
||||||
|
self->name = name;
|
||||||
|
self->reference_count = 0;
|
||||||
|
supertype->reference_count++;
|
||||||
|
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ObjectType_Destroy(ObjectType* self)
|
||||||
|
{
|
||||||
|
self->supertype->reference_count--;
|
||||||
|
// TODO: Emit a warning when there are still references?
|
||||||
|
HashMap_Destroy(&self->attributes);
|
||||||
|
}
|
||||||
|
|
||||||
|
int ObjectType_DefineObjectAttribute(ObjectType* self, ObjectType* attribute_type, StringView attribute_name)
|
||||||
|
{
|
||||||
|
ObjectTypeAttribute attribute = {
|
||||||
|
.name = attribute_name,
|
||||||
|
VALUETYPE_OBJECT,
|
||||||
|
attribute_type,
|
||||||
|
HashMap_Size(&self->attributes),
|
||||||
|
};
|
||||||
|
return HashMap_Put(&self->attributes, attribute_name.source, attribute_name.length, &attribute);
|
||||||
|
}
|
||||||
|
|
||||||
|
int ObjectType_DefinePrimitiveAttribute(ObjectType* self, enum ValueType attribute_type, StringView attribute_name)
|
||||||
|
{
|
||||||
|
ObjectTypeAttribute attribute = {
|
||||||
|
.name = attribute_name,
|
||||||
|
attribute_type,
|
||||||
|
NULL,
|
||||||
|
HashMap_Size(&self->attributes),
|
||||||
|
};
|
||||||
|
return HashMap_Put(&self->attributes, attribute_name.source, attribute_name.length, &attribute);
|
||||||
|
}
|
|
@ -1,5 +1,3 @@
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This code is part of the programming language flup
|
* This code is part of the programming language flup
|
||||||
* flup comes with ABSOLUTELY NO WARRANTY and is licensed under AGPL-3.0 or later.
|
* flup comes with ABSOLUTELY NO WARRANTY and is licensed under AGPL-3.0 or later.
|
||||||
|
@ -25,17 +23,27 @@
|
||||||
#include "../submodules/utilitiec/src/hashmap/hashmap.h"
|
#include "../submodules/utilitiec/src/hashmap/hashmap.h"
|
||||||
#include "../submodules/utilitiec/src/StringView/StringView.h"
|
#include "../submodules/utilitiec/src/StringView/StringView.h"
|
||||||
|
|
||||||
|
typedef struct ObjectType_s ObjectType;
|
||||||
|
|
||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
|
||||||
typedef struct ObjectTypeAttribute_s {
|
typedef struct ObjectTypeAttribute_s {
|
||||||
StringView name;
|
StringView name;
|
||||||
enum ValueType type;
|
enum ValueType type;
|
||||||
|
ObjectType* object_type; // only active if there type is VALUETYPE_OBJECT
|
||||||
uint32_t index;
|
uint32_t index;
|
||||||
} ObjectTypeAttribute;
|
} ObjectTypeAttribute;
|
||||||
|
|
||||||
typedef struct ObjectType_s {
|
struct ObjectType_s {
|
||||||
hashmap_t attributes; // map of (char* name) -> (ObjectTypeAttribute entry)
|
hashmap_t attributes; // map of (char* name) -> (ObjectTypeAttribute entry)
|
||||||
StringView name;
|
StringView name;
|
||||||
} ObjectType;
|
size_t reference_count; // count of references from subtypes and object instances
|
||||||
|
struct ObjectType_s* supertype;
|
||||||
|
};
|
||||||
|
|
||||||
|
void ObjectType_Destroy(ObjectType* self);
|
||||||
|
int ObjectType_Create(ObjectType* self, StringView name, ObjectType* supertype, size_t attribute_count_guess, allocator_t* allocator);
|
||||||
|
int ObjectType_DefineObjectAttribute(ObjectType* self, ObjectType* attribute_type, StringView attribute_name);
|
||||||
|
int ObjectType_DefinePrimitiveAttribute(ObjectType* self, enum ValueType attribute_type, StringView attribute_name);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue