aboutsummaryrefslogtreecommitdiff
path: root/src/checker.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-11-17 18:50:30 +0000
committergingerBill <bill@gingerbill.org>2020-11-17 18:50:30 +0000
commit2bd0fd932a4eb1c2e6bc8702450c230186bb3c44 (patch)
tree7f3441c0de7036aaa3f67aaa1edf4f610984f35c /src/checker.cpp
parent11577db6a84d17998478dc22b607a203cdf00a7e (diff)
Begin rudimentary work on implementing `odin test` tooling with `*_test.odin` files
Diffstat (limited to 'src/checker.cpp')
-rw-r--r--src/checker.cpp50
1 files changed, 48 insertions, 2 deletions
diff --git a/src/checker.cpp b/src/checker.cpp
index 88aed4c62..61b1e4bae 100644
--- a/src/checker.cpp
+++ b/src/checker.cpp
@@ -839,6 +839,8 @@ void init_checker_info(CheckerInfo *i) {
array_init(&i->variable_init_order, a);
array_init(&i->required_foreign_imports_through_force, a);
array_init(&i->required_global_variables, a);
+ array_init(&i->testing_procedures, a, 0, 0);
+
i->allow_identifier_uses = build_context.query_data_set_settings.kind == QueryDataSet_GoToDefinitions;
if (i->allow_identifier_uses) {
@@ -1854,7 +1856,50 @@ void generate_minimum_dependency_set(Checker *c, Entity *start) {
}
}
- add_dependency_to_set(c, start);
+ if (build_context.command_kind == Command_test) {
+ AstPackage *pkg = c->info.init_package;
+ Scope *s = pkg->scope;
+ for_array(i, s->elements.entries) {
+ Entity *e = s->elements.entries[i].value;
+ if (e->kind != Entity_Procedure) {
+ continue;
+ }
+ String name = e->token.string;
+ String prefix = str_lit("test_");
+
+
+ if (!string_starts_with(name, prefix)) {
+ continue;
+ }
+
+ bool is_tester = false;
+ if (name != prefix) {
+ is_tester = true;
+ } else {
+ if (e->file && e->file->is_test) {
+ error(e->token, "Invalid testing procedure name: %.*s", LIT(name));
+ }
+ }
+
+ Type *t = base_type(e->type);
+ GB_ASSERT(t->kind == Type_Proc);
+ if (t->Proc.param_count == 0 && t->Proc.result_count == 0) {
+ // Good
+ } else {
+ gbString str = type_to_string(t);
+ error(e->token, "Testing procedures must have a signature type of proc(), got %s", str);
+ gb_string_free(str);
+ is_tester = false;
+ }
+
+ if (is_tester) {
+ add_dependency_to_set(c, e);
+ array_add(&c->info.testing_procedures, e);
+ }
+ }
+ } else {
+ add_dependency_to_set(c, start);
+ }
}
bool is_entity_a_dependency(Entity *e) {
@@ -4344,6 +4389,7 @@ void check_parsed_files(Checker *c) {
string_map_set(&c->info.packages, p->fullpath, p);
if (scope->flags&ScopeFlag_Init) {
+ c->info.init_package = p;
c->info.init_scope = scope;
}
if (p->kind == Package_Runtime) {
@@ -4613,7 +4659,7 @@ void check_parsed_files(Checker *c) {
TIME_SECTION("check entry point");
- if (build_context.build_mode == BuildMode_Executable && !build_context.no_entry_point) {
+ if (build_context.build_mode == BuildMode_Executable && !build_context.no_entry_point && build_context.command_kind != Command_test) {
Scope *s = c->info.init_scope;
GB_ASSERT(s != nullptr);
GB_ASSERT(s->flags&ScopeFlag_Init);