Skip to content

Commit

Permalink
feat: check for invalid assoc with fields
Browse files Browse the repository at this point in the history
  • Loading branch information
zaucy committed Jun 28, 2024
1 parent 8ad28c4 commit 3cfed88
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 0 deletions.
39 changes: 39 additions & 0 deletions ecsact/interpret/eval.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1171,6 +1171,28 @@ static auto get_with_field_ids(
return with_field_ids;
}

static auto find_capabilities_for( //
auto sys_like_id,
auto id
) -> std::optional<ecsact_system_capability> {
for(auto&& [comp_id, caps] : ecsact::meta::system_capabilities(sys_like_id)) {
if(ecsact_id_cast<decltype(id)>(comp_id) == id) {
return caps;
}
}

auto parent = ecsact::meta::get_parent_system_id(
// NOTE: this cast only works because we wrote the meta runtime for the
// interpreter. This is bad practice.
static_cast<ecsact_system_id>(sys_like_id)
);
if(parent) {
return find_capabilities_for(*parent, id);
}

return {};
}

static auto eval_system_with_statement_data_common(
ecsact_system_like_id sys_like_id,
ecsact_component_like_id comp_like_id,
Expand Down Expand Up @@ -1201,6 +1223,23 @@ static auto eval_system_with_statement_data_common(
};
}

auto field_type =
ecsact::meta::get_field_type(comp_like_id, *assoc_field_id);

if(field_type.kind == ECSACT_TYPE_KIND_BUILTIN) {
if(field_type.type.builtin != ECSACT_ENTITY_TYPE) {
return ecsact_eval_error{
.code = ECSACT_EVAL_ERR_INVALID_ASSOC_FIELD_TYPE,
.relevant_content = fields[i],
};
}
} else if(field_type.kind != ECSACT_TYPE_KIND_FIELD_INDEX) {
return ecsact_eval_error{
.code = ECSACT_EVAL_ERR_INVALID_ASSOC_FIELD_TYPE,
.relevant_content = fields[i],
};
}

with_field_ids.emplace_back(*assoc_field_id);
}

Expand Down
3 changes: 3 additions & 0 deletions ecsact/interpret/eval_error.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,9 @@ typedef enum ecsact_eval_error_code {
/// Statement supports the given parameter name but the value is invalid
ECSACT_EVAL_ERR_INVALID_PARAMETER_VALUE,

/// Field type is not allowed in 'with' statement
ECSACT_EVAL_ERR_INVALID_ASSOC_FIELD_TYPE,

/// Internal error. Should not happen and is an indiciation of a bug.
ECSACT_EVAL_ERR_INTERNAL = 999,

Expand Down
1 change: 1 addition & 0 deletions test/errors/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ _TESTS = [
"unknown_association_field",
"unknown_component_notify_settings",
"unknown_param_value",
"invalid_assoc_field",
]

[cc_test(
Expand Down
11 changes: 11 additions & 0 deletions test/errors/invalid_assoc_field.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#include "gtest/gtest.h"
#include "ecsact/interpret/eval.h"

#include "test_lib.hh"

TEST(InvalidAssocField, NonEntityBuiltin) {
auto errs =
ecsact_interpret_test_files({"errors/invalid_assoc_field.ecsact"});
ASSERT_EQ(errs.size(), 1);
ASSERT_EQ(errs[0].eval_error, ECSACT_EVAL_ERR_INVALID_ASSOC_FIELD_TYPE);
}
9 changes: 9 additions & 0 deletions test/errors/invalid_assoc_field.ecsact
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
main package invalid_assoc_field;

component A { i32 num; }

system S {
readwrite A with num {
readwrite A;
}
}

0 comments on commit 3cfed88

Please sign in to comment.