entity_ui_proc generation

This commit is contained in:
2024-11-28 00:15:07 +01:00
parent ff74156d60
commit 80de060002
4 changed files with 170 additions and 0 deletions

View File

@@ -81,6 +81,32 @@ should_serialize :: (type: *Type_Info_Struct, member: Type_Info_Struct_Member) -
return true;
}
generate_member_ui :: (type: *Type_Info_Struct, builder: *String_Builder, path: string = "") {
for type.members {
if should_serialize(type, it) {
new_path : string;
if path.count == 0 {
new_path = it.name;
} else {
new_path = tprint("%1.%2", path, it.name);
}
if it.type.type == {
//case .STRUCT; {
// info_struct := cast(*Type_Info_Struct) it.type;
// generate_member_serialization(info_struct, builder, new_path);
//}
//case .BOOL; #through;
//case .FLOAT; #through;
//case .ENUM; #through;
case .INTEGER; {
print_to_builder(builder, "\tui_int_field(tprint(\"%\"), *e.%);\n", new_path, new_path);
}
}
}
}
}
generate_member_serialization :: (type: *Type_Info_Struct, builder: *String_Builder, path: string = "") {
for type.members {
if should_serialize(type, it) {
@@ -159,6 +185,18 @@ generate_member_copy :: (type: *Type_Info_Struct, builder: *String_Builder, path
}
}
generate_ui_procedure_for_entity :: (code_struct: *Code_Struct) {
name := code_struct.defined_type.name;
// Serialize
ui : String_Builder;
print_to_builder(*ui, "entity_ui_proc :: (e: *%) {\n", name);
generate_member_ui(code_struct.defined_type, *ui);
print_to_builder(*ui, "}\n");
array_add(*entity_serialize_proc_string, builder_to_string(*ui));
}
generate_serialize_procedure_for_entity :: (code_struct: *Code_Struct) {
name := code_struct.defined_type.name;
@@ -213,6 +251,7 @@ note_struct :: (code_struct: *Code_Struct) {
print("Detected entity '%'.\n", name);
generate_serialize_procedure_for_entity(code_struct);
generate_ui_procedure_for_entity(code_struct);
}
}
}
@@ -356,6 +395,17 @@ generate_code :: (w: Workspace) {
add_build_string(build_string, w);
}
{
builder: String_Builder;
for entity_type_names {
print_to_builder(*builder, "\tcase %1; entity_ui_proc(cast(*%1)e);\n", it);
}
build_string := sprint(ENTITY_UI, builder_to_string(*builder));
add_build_string(build_string, w);
}
{
builder: String_Builder;
@@ -462,6 +512,14 @@ duplicate_entity :: (e: *Entity) -> *Entity {
}
DONE
ENTITY_UI :: #string DONE
entity_ui :: (e: *Entity) {
if e.type == {
%1
}
}
DONE
INIT_SCENE :: #string DONE
init_scene :: (scene: *Scene) {
%1