summaryrefslogtreecommitdiff
path: root/tiger-compiler/src/combine/tasks.cc
diff options
context:
space:
mode:
authorMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:07:58 +0200
committerMartial Simon <msimon_fr@hotmail.com>2025-09-15 01:07:58 +0200
commit967be9e750221ab2ab783f95df79bb26d290a45e (patch)
tree6802900a5e975f9f68b169f0f503f040056d6952 /tiger-compiler/src/combine/tasks.cc
add: added projectsHEADmain
Diffstat (limited to 'tiger-compiler/src/combine/tasks.cc')
-rw-r--r--tiger-compiler/src/combine/tasks.cc74
1 files changed, 74 insertions, 0 deletions
diff --git a/tiger-compiler/src/combine/tasks.cc b/tiger-compiler/src/combine/tasks.cc
new file mode 100644
index 0000000..48470ac
--- /dev/null
+++ b/tiger-compiler/src/combine/tasks.cc
@@ -0,0 +1,74 @@
+/**
+ ** \file combine/tasks.cc
+ ** \brief Combine module related tasks' implementation.
+ */
+
+#include <ast/tasks.hh>
+#include <bind/tasks.hh>
+#include <desugar/tasks.hh>
+#include <escapes/tasks.hh>
+#include <object/tasks.hh>
+
+#include <astclone/libastclone.hh>
+#include <desugar/libdesugar.hh>
+#include <inlining/libinlining.hh>
+
+#include <common.hh>
+
+#include <combine/libcombine.hh>
+#define DEFINE_TASKS 1
+#include <combine/tasks.hh>
+#undef DEFINE_TASKS
+
+namespace combine::tasks
+{
+ std::unique_ptr<overload::overfun_bindings_type> the_overfun_bindings =
+ nullptr;
+
+ void combine_bindings_compute()
+ {
+ auto result =
+ ::combine::combine_bind(*ast::tasks::the_program, c_overload_p);
+ ::combine::tasks::the_overfun_bindings =
+ std::make_unique<overload::overfun_bindings_type>(
+ std::move(result.first));
+
+ task_error() << result.second << &misc::error::exit_on_error;
+ }
+
+ void combine_types_compute()
+ {
+ task_error() << ::combine::combine_types_check(
+ *ast::tasks::the_program, *::combine::tasks::the_overfun_bindings,
+ c_overload_p);
+ the_overfun_bindings.reset();
+ task_error().exit_on_error();
+ }
+
+ void combine_rename()
+ {
+ // FIXME: Some code was deleted here (Call appropriate renaming tasks).
+ }
+
+ void combine_desugar()
+ {
+ if (c_object_p)
+ ::object::tasks::object_desugar();
+
+ if (c_desugar_p)
+ ::desugar::tasks::desugar();
+
+ if (c_bounds_p)
+ astclone::apply(::desugar::bounds_checks_add, ast::tasks::the_program);
+
+ if (c_inline_p)
+ astclone::apply(::inlining::inline_expand, ast::tasks::the_program);
+
+ if (c_prune_p)
+ astclone::apply(::inlining::prune, ast::tasks::the_program);
+
+ if (c_escapes_p)
+ ::escapes::tasks::escapes_compute();
+ }
+
+} // namespace combine::tasks