MimIR
MimIR is my Intermediate Representation
Loading...
Searching...
No Matches
emit.cpp
Go to the documentation of this file.
1#include "mim/def.h"
2#include "mim/rewrite.h"
3
4#include "mim/ast/ast.h"
5
6using namespace std::literals;
7
8namespace mim::ast {
9
10using Tag = Tok::Tag;
11
12class Emitter {
13public:
15 : ast_(ast) {}
16
17 AST& ast() const { return ast_; }
18 World& world() { return ast().world(); }
19 Driver& driver() { return world().driver(); }
20
21 /// @p name is the full syntactic name of *this* registration (`%plugin.tag` or `%plugin.tag.sub`).
22 /// We must take it from the declaration rather than from Def::sym, since hash-consing can make several
23 /// annexes share a single Def (e.g. `let %foo.bar = 23; let %foo.baz = 23;`).
24 void attach(AnnexInfo* annex, sub_t sub, Sym name, const Def* def) {
25 if (annex) world().annexes().attach(annex->plugin_id(), annex->id.tag, sub, name, def);
26 }
27
28 absl::node_hash_map<Sigma*, fe::SymMap<size_t>, GIDHash<const Def*>> sigma2sym2idx;
29
30private:
31 AST& ast_;
32};
33
34/*
35 * Module
36 */
37
38void Module::emit(AST& ast) const {
39 auto emitter = Emitter(ast);
40 emit(emitter);
41}
42
43void Module::emit(Emitter& e) const {
44 auto _ = e.world().push(loc());
45 for (const auto& import : implicit_imports())
46 import->emit(e);
47 for (const auto& import : imports())
48 import->emit(e);
49 for (const auto& decl : decls())
50 decl->emit(e);
51}
52
53void Import::emit(Emitter& e) const { module()->emit(e); }
54
55/*
56 * Ptrn::emit_value
57 */
58
59const Def* ErrorPtrn::emit_value(Emitter&, const Def* def) const { return def; }
60
61const Def* IdPtrn::emit_value(Emitter& e, const Def* def) const {
62 emit_type(e);
63 return def_ = def->set(dbg());
64}
65
66const Def* GrpPtrn::emit_value(Emitter&, const Def* def) const { return def_ = def->set(dbg()); }
67
68const Def* AliasPtrn::emit_value(Emitter& e, const Def* def) const {
69 return def_ = ptrn()->emit_value(e, def)->set(dbg());
70}
71
72const Def* TuplePtrn::emit_value(Emitter& e, const Def* def) const {
73 auto _ = e.world().push(loc());
74 emit_type(e);
75 for (size_t i = 0, n = num_ptrns(); i != n; ++i)
76 ptrn(i)->emit_value(e, def->proj(n, i));
77 return def_ = def;
78}
79
80/*
81 * Ptrn::emit_Type
82 */
83
84const Def* ErrorPtrn::emit_type(Emitter&) const { fe::unreachable(); }
85
86const Def* IdPtrn::emit_type(Emitter& e) const {
87 auto _ = e.world().push(loc());
88 return type() ? type()->emit(e) : e.world().mut_hole_type();
89}
90
91const Def* AliasPtrn::emit_type(Emitter& e) const { return ptrn()->emit_type(e); }
92
93const Def* GrpPtrn::emit_type(Emitter& e) const { return id()->emit_type(e); }
94
95const Def* TuplePtrn::emit_type(Emitter& e) const { return emit_body(e, {}); }
96
97const Def* TuplePtrn::emit_body(Emitter& e, const Def* decl) const {
98 auto _ = e.world().push(loc());
99 auto n = num_ptrns();
100 Sigma* sigma;
101 if (decl) {
102 sigma = decl->as_mut<Sigma>();
103 } else {
104 auto type = e.world().type_infer_univ();
105 sigma = e.world().mut_sigma(type, n);
106 }
107 auto var = sigma->var();
108 auto& sym2idx = e.sigma2sym2idx[sigma];
109
110 for (size_t i = 0; i != n; ++i) {
111 sigma->set(i, ptrn(i)->emit_type(e));
112 ptrn(i)->emit_value(e, var->proj(n, i));
113 if (auto id = ptrn(i)->isa<IdPtrn>()) sym2idx[id->dbg().sym()] = i;
114 }
115
116 if (auto imm = sigma->immutabilize()) return imm;
117 return sigma;
118}
119
120const Def* TuplePtrn::emit_decl(Emitter& e, const Def* type) const {
121 auto _ = e.world().push(loc());
122 type = type ? type : e.world().type_infer_univ();
123 return e.world().mut_sigma(type, num_ptrns());
124}
125
126/*
127 * Expr
128 */
129
130const Def* Expr::emit(Emitter& e) const {
131 auto _ = e.world().push(loc());
132 return emit_(e);
133}
134
135const Def* ErrorExpr::emit_(Emitter&) const { fe::unreachable(); }
136const Def* HoleExpr::emit_(Emitter& e) const { return e.world().mut_hole_type(); }
137
138const Def* IdExpr::emit_(Emitter&) const {
139 assert(decl());
140 return decl()->def();
141}
142
143const Def* TypeExpr::emit_(Emitter& e) const {
144 auto l = level()->emit(e);
145 return e.world().type(l);
146}
147
148const Def* RuleExpr::emit_(Emitter& e) const {
149 auto m = dom()->emit(e);
150 return e.world().reform(m);
151}
152
153const Def* PrimaryExpr ::emit_(Emitter& e) const {
154 // clang-format off
155 switch (tag()) {
156 case Tag::K_Univ: return e.world().univ();
157 case Tag::K_Nat: return e.world().type_nat();
158 case Tag::K_Idx: return e.world().type_idx();
159 case Tag::K_Bool: return e.world().type_bool();
160 case Tag::K_ff: return e.world().lit_ff();
161 case Tag::K_tt: return e.world().lit_tt();
162 case Tag::K_i1: return e.world().lit_i1();
163 case Tag::K_i8: return e.world().lit_i8();
164 case Tag::K_i16: return e.world().lit_i16();
165 case Tag::K_i32: return e.world().lit_i32();
166 case Tag::K_i64: return e.world().lit_i64();
167 case Tag::K_I1: return e.world().type_i1();
168 case Tag::K_I8: return e.world().type_i8();
169 case Tag::K_I16: return e.world().type_i16();
170 case Tag::K_I32: return e.world().type_i32();
171 case Tag::K_I64: return e.world().type_i64();
172 case Tag::T_star: return e.world().type<0>();
173 case Tag::T_box: return e.world().type<1>();
174 default: fe::unreachable();
175 }
176 // clang-format on
177}
178
179const Def* LitExpr::emit_(Emitter& e) const {
180 auto t = type() ? type()->emit(e) : nullptr;
181 // clang-format off
182 switch (tag()) {
183 case Tag::L_f:
184 case Tag::L_s:
185 case Tag::L_u: return t ? e.world().lit(t, tok().lit_u()) : e.world().lit_nat(tok().lit_u());
186 case Tag::L_i: return tok().lit_i();
187 case Tag::L_c: return e.world().lit_i8(tok().lit_c());
188 case Tag::L_str: return e.world().tuple(tok().sym());
189 case Tag::T_bot: return t ? e.world().bot(t) : e.world().type_bot();
190 case Tag::T_top: return t ? e.world().top(t) : e.world().type_top();
191 default: fe::unreachable();
192 }
193 // clang-format on
194}
195
196const Def* DeclExpr::emit_(Emitter& e) const {
197 if (is_where())
198 for (const auto& decl : decls() | std::views::reverse)
199 decl->emit(e);
200 else
201 for (const auto& decl : decls())
202 decl->emit(e);
203 return expr()->emit(e);
204}
205
206const Def* ArrowExpr::emit_decl(Emitter& e, const Def* type) const {
207 return decl_ = e.world().mut_pi(type, false)->set(loc());
208}
209
210void ArrowExpr::emit_body(Emitter& e, const Def*) const {
211 decl_->set_dom(dom()->emit(e));
212 decl_->set_codom(codom()->emit(e)); // TODO try to immutabilize
213}
214
215const Def* ArrowExpr::emit_(Emitter& e) const {
216 auto d = dom()->emit(e);
217 auto c = codom()->emit(e);
218 return e.world().pi(d, c);
219}
220
221const Def* UnionExpr::emit_(Emitter& e) const {
222 DefVec etypes;
223 for (auto& t : types())
224 etypes.emplace_back(t->emit(e));
225 return e.world().join(etypes);
226}
227
228const Def* InjExpr::emit_(Emitter& e) const {
229 auto v = value()->emit(e);
230 auto t = type()->emit(e);
231 return e.world().inj(t, v);
232}
233
235 auto _ = e.world().push(loc());
236 auto dom_t = ptrn()->emit_type(e);
237 auto pi = e.world().pi(dom_t, e.world().mut_hole_type());
238 auto lam = e.world().mut_lam(pi);
239 ptrn()->emit_value(e, lam->var());
240 return lam->set(true, body()->emit(e));
241}
242
243const Def* MatchExpr::emit_(Emitter& e) const {
244 DefVec res;
245 res.emplace_back(scrutinee()->emit(e));
246 for (const auto& arm : arms())
247 res.emplace_back(arm->emit(e));
248 return e.world().match(res);
249}
250
252 pi_ = decl_ ? decl_ : e.world().mut_pi(e.world().type_infer_univ(), is_implicit());
253 auto dom_t = ptrn()->emit_type(e);
254
255 if (ret()) {
256 auto sigma = e.world().mut_sigma(2)->set(loc());
257 auto var = sigma->var()->set(ret()->loc().anew_begin());
258 sigma->set(0, dom_t);
259 ptrn()->emit_value(e, var->proj(2, 0));
260 auto ret_t = e.world().cn(ret()->emit_type(e));
261 sigma->set(1, ret_t);
262
263 if (auto imm = sigma->immutabilize())
264 dom_t = imm;
265 else
266 dom_t = sigma;
267 pi_->set_dom(dom_t);
268 } else {
269 pi_->set_dom(dom_t);
270 ptrn()->emit_value(e, pi_->var());
271 }
272}
273
274const Def* PiExpr::emit_decl(Emitter& e, const Def* type) const {
275 return dom()->decl_ = e.world().mut_pi(type, dom()->is_implicit())->set(loc());
276}
277
278void PiExpr::emit_body(Emitter& e, const Def*) const { emit(e); }
279
280const Def* PiExpr::emit_(Emitter& e) const {
281 dom()->emit_type(e);
282 auto cod = codom() ? codom()->emit(e) : e.world().type_bot();
283 return dom()->pi_->set_codom(cod);
284}
285
286const Def* LamExpr::emit_decl(Emitter& e, const Def*) const { return lam()->emit_decl(e), lam()->def(); }
287void LamExpr::emit_body(Emitter& e, const Def*) const { lam()->emit_body(e); }
288
289const Def* LamExpr::emit_(Emitter& e) const {
290 auto res = emit_decl(e, {});
291 emit_body(e, {});
292 return res;
293}
294
295const Def* AppExpr::emit_(Emitter& e) const {
296 auto c = callee()->emit(e);
297 auto a = arg()->emit(e);
298 return is_explicit() ? e.world().app(c, a) : e.world().implicit_app(c, a);
299}
300
301const Def* RetExpr::emit_(Emitter& e) const {
302 auto c = callee()->emit(e);
303 if (auto cn = Pi::has_ret_pi(c->type())) {
304 auto con = e.world().mut_lam(cn);
305 auto pair = e.world().tuple({arg()->emit(e), con});
306 auto app = e.world().app(c, pair)->set(c->loc() + arg()->loc());
307 ptrn()->emit_value(e, con->var());
308 con->set(false, body()->emit(e));
309 return app;
310 }
311
312 error(c->loc(), "callee of a ret expression must type as a returning continuation but got '{}' of type '{}'", c,
313 c->type());
314}
315
316const Def* SigmaExpr::emit_decl(Emitter& e, const Def* type) const { return ptrn()->emit_decl(e, type); }
317void SigmaExpr::emit_body(Emitter& e, const Def* decl) const { ptrn()->emit_body(e, decl); }
318const Def* SigmaExpr::emit_(Emitter& e) const { return ptrn()->emit_type(e); }
319
320const Def* TupleExpr::emit_(Emitter& e) const {
321 DefVec elems(num_elems(), [&](size_t i) { return elem(i)->emit(e); });
322 return e.world().tuple(elems);
323}
324
325const Def* SeqExpr::emit_(Emitter& e) const {
326 auto s = arity()->emit_type(e);
327 if (auto lit_s = Lit::isa(s); lit_s && *lit_s == 0) return e.world().unit(is_pack());
328
329 if (arity()->dbg().is_anon()) { // immutable
330 auto b = body()->emit(e);
331 return e.world().seq(is_pack(), s, b);
332 }
333
334 auto t = e.world().type_infer_univ();
335 auto a = e.world().mut_arr(t);
336 a->set_arity(s);
337
338 if (is_pack()) {
339 auto p = e.world().mut_pack(a);
340 auto var = p->var();
341 arity()->emit_value(e, var);
342 auto b = body()->emit(e);
343 p->set(b);
344 auto arr_b = b->type();
345 if (auto pvar = var->isa<Var>())
346 // Use array var in array body instead of pack var
347 arr_b = VarRewriter(pvar, a->var()).rewrite(arr_b);
348 a->set_body(arr_b);
349 if (auto imm = p->immutabilize()) return imm;
350 return p;
351 } else {
352 auto var = a->var();
353 arity()->emit_value(e, var);
354 a->set_body(body()->emit(e));
355 if (auto imm = a->immutabilize()) return imm;
356 return a;
357 }
358}
359
361 auto tup = tuple()->emit(e);
362 if (auto dbg = std::get_if<Dbg>(&index())) {
363 if (auto sigma = tup->type()->isa_mut<Sigma>()) {
364 if (auto i = e.sigma2sym2idx.find(sigma); i != e.sigma2sym2idx.end()) {
365 auto sigma = i->first->as_mut<Sigma>();
366 const auto& sym2idx = i->second;
367 if (auto i = sym2idx.find(dbg->sym()); i != sym2idx.end())
368 return e.world().extract(tup, sigma->num_ops(), i->second);
369 }
370 }
371
372 if (decl()) return e.world().extract(tup, decl()->def());
373 error(dbg->loc(), "cannot resolve index '{}' for extraction", *dbg);
374 }
375
376 auto expr = std::get<Ptr<Expr>>(index()).get();
377 auto i = expr->emit(e);
378 return e.world().extract(tup, i);
379}
380
381const Def* InsertExpr::emit_(Emitter& e) const {
382 auto t = tuple()->emit(e);
383 auto i = index()->emit(e);
384 auto v = value()->emit(e);
385 return e.world().insert(t, i, v);
386}
387
388const Def* UniqExpr::emit_(Emitter& e) const { return e.world().uniq(inhabitant()->emit(e)); }
389
390/*
391 * Decl
392 */
393
394void AxmDecl::emit(Emitter& e) const {
395 if (!annex_) return; // Skip emit if binding failed
396 mim_type_ = type()->emit(e);
397 auto& id = annex_->id;
398 auto plugin = annex_->plugin_id();
399
400 std::tie(id.curry, id.trip) = Axm::infer_curry_and_trip(mim_type_);
401 if (curry_) {
402 if (curry_.lit_u() > id.curry)
403 error(curry_.loc(), "curry counter cannot be greater than {}", id.curry);
404 else
405 id.curry = curry_.lit_u();
406 }
407
408 if (trip_) {
409 if (trip_.lit_u() > id.curry)
410 error(trip_.loc(), "trip counter cannot be greater than curry counter '{}'", (int)id.curry);
411 else
412 id.trip = trip_.lit_u();
413 }
414
415 if (num_subs() == 0) {
416 auto norm = e.driver().normalizer(plugin, id.tag, 0);
417 auto axm = e.world().axm(norm, id.curry, id.trip, mim_type_, plugin, id.tag, 0)->set(dbg());
418 def_ = axm;
419 e.world().annexes().attach(plugin, id.tag, 0, dbg().sym(), axm);
420 } else {
421 for (sub_t i = 0, n = num_subs(); i != n; ++i) {
422 sub_t s = i + offset_;
423 auto norm = e.driver().normalizer(plugin, id.tag, s);
424 auto name = e.world().sym(dbg().sym().str() + "."s + sub(i).front()->dbg().sym().str());
425 auto axm = e.world().axm(norm, id.curry, id.trip, mim_type_, plugin, id.tag, s)->set(name);
426 e.world().annexes().attach(plugin, id.tag, s, name, axm);
427
428 for (const auto& alias : sub(i))
429 alias->def_ = axm;
430 }
431 }
432}
433
434void LetDecl::emit(Emitter& e) const {
435 auto v = value()->emit(e);
436 def_ = ptrn()->emit_value(e, v);
437 if (auto id = ptrn()->isa<IdPtrn>()) e.attach(annex_, sub_, id->dbg().sym(), def_);
438}
439
440void RecDecl::emit(Emitter& e) const {
441 for (auto curr = this; curr; curr = curr->next())
442 curr->emit_decl(e);
443 for (auto curr = this; curr; curr = curr->next())
444 curr->emit_body(e);
445}
446
448 auto t = type() ? type()->emit(e) : e.world().type_infer_univ();
449 def_ = body()->emit_decl(e, t);
450 def_->set(dbg());
451}
452
454 body()->emit_body(e, def_);
455 // TODO immutabilize?
456 e.attach(annex_, sub_, dbg().sym(), def_);
457}
458
460 lam_ = e.world().mut_lam(pi_);
461 auto var = lam_->var();
462
463 if (ret()) {
464 ptrn()->emit_value(e, var->proj(2, 0));
465 ret()->emit_value(e, var->proj(2, 1));
466 } else {
467 ptrn()->emit_value(e, var);
468 }
469
470 return lam_;
471}
472
474 auto _ = e.world().push(loc());
475 bool is_cps = tag_ == Tag::K_cn || tag_ == Tag::K_con || tag_ == Tag::K_fn || tag_ == Tag::K_fun;
476
477 // Iterate over all doms: Build a Lam for curr dom, by first building a curried Pi for the remaining doms.
478 for (size_t i = 0, n = num_doms(); i != n; ++i) {
479 for (const auto& dom : doms() | std::views::drop(i))
480 dom->emit_type(e);
481
482 auto cod = codom() ? codom()->emit(e) : is_cps ? e.world().type_bot() : e.world().mut_hole_type();
483 for (const auto& dom : doms() | std::views::drop(i) | std::views::reverse)
484 cod = dom->pi_->set_codom(cod);
485
486 auto cur = dom(i);
487 auto lam = cur->emit_value(e);
488 auto filter = cur->filter() ? cur->filter()->emit(e)
489 : i + 1 == n && is_cps ? e.world().lit_ff()
490 : e.world().lit_tt();
491 lam->set_filter(filter);
492
493 if (i == 0)
494 def_ = lam->set(dbg().sym());
495 else
496 dom(i - 1)->lam_->set_body(lam);
497 }
498}
499
501 auto b = body()->emit(e);
502 doms().back()->lam_->set_body(b);
503
504 // rewrite holes
505 for (size_t i = 0, n = num_doms(); i != n; ++i) {
506 auto rw = VarRewriter(e.world());
507 auto lam = dom(i)->lam_;
508 auto pi = lam->type()->as_mut<Pi>();
509 for (const auto& dom : doms() | std::views::drop(i)) {
510 if (auto var = pi->has_var()) rw.add(dom->lam_->var()->as<Var>(), var);
511 auto cod = pi->codom();
512 if (!cod || !cod->isa_mut<Pi>()) break;
513 pi = cod->as_mut<Pi>();
514 }
515
516 if (auto cod = pi->codom(); cod && cod->has_dep(Dep::Hole)) pi->set(pi->dom(), rw.rewrite(cod));
517 }
518
519 for (const auto& dom : doms() | std::views::reverse) {
520 if (auto imm = dom->pi_->immutabilize()) {
521 auto f = dom->lam_->filter();
522 auto b = dom->lam_->body();
523 dom->lam_->unset()->set_type(imm)->as<Lam>()->set(f, b);
524 }
525 }
526
527 if (is_external()) doms().front()->lam_->externalize();
528 e.attach(annex_, sub_, dbg().sym(), def_);
529}
530
531void CDecl::emit(Emitter& e) const {
532 auto dom_t = dom()->emit_type(e);
533 if (tag() == Tag::K_cfun) {
534 auto ret_t = codom()->emit(e);
535 def_ = e.world().mut_fun(dom_t, ret_t)->set(dbg());
536 } else {
537 def_ = e.world().mut_con(dom_t)->set(dbg());
538 }
539}
540
541void RuleDecl::emit(Emitter& e) const {
542 auto _ = e.world().push(loc());
543 auto meta_t = e.world().reform(var()->emit_type(e));
544 auto rule = e.world().mut_rule(meta_t)->set(dbg());
545 var()->emit_value(e, rule->var());
546 auto l = lhs()->emit(e);
547 auto r = rhs()->emit(e);
548 auto g = guard()->emit(e);
549 rule->set(l, r, g);
550 def_ = rule;
551}
552
553} // namespace mim::ast
static std::pair< u8, u8 > infer_curry_and_trip(const Def *type)
Definition axm.cpp:14
Base class for all Defs.
Definition def.h:246
Def * set(size_t i, const Def *)
Successively set from left to right.
Definition def.cpp:266
T * as_mut() const
Asserts that this is a mutable, casts constness away and performs a static_cast to T.
Definition def.h:502
const Def * var(nat_t a, nat_t i) noexcept
Definition def.h:425
Some "global" variables needed all over the place.
Definition driver.h:19
A function.
Definition lam.h:110
static std::optional< T > isa(const Def *def)
Definition def.h:838
A dependent function type.
Definition lam.h:14
static const Pi * has_ret_pi(const Def *d)
Yields the Pi::ret_pi() of d, if it is in fact a Pi.
Definition lam.h:59
Pi * set(const Def *dom, const Def *codom)
Definition lam.h:76
A dependent tuple type.
Definition tuple.h:20
const Def * immutabilize() final
Tries to make an immutable from a mutable.
Definition def.cpp:198
Sigma * set(size_t i, const Def *def)
Definition tuple.h:32
Extends Rewriter for variable substitution.
Definition rewrite.h:98
const Def * rewrite(const Def *) final
Definition rewrite.cpp:277
A variable introduced by a binder (mutable).
Definition def.h:714
const Def * attach(flags_t, Sym, const Def *)
Definition world.cpp:43
The World represents the whole program and manages creation of MimIR nodes (Defs).
Definition world.h:36
const Driver & driver() const
Definition world.h:93
Annexes & annexes()
Definition world.h:285
World & world()
Definition ast.h:67
const Def * emit_value(Emitter &, const Def *) const override
Definition emit.cpp:68
Dbg dbg() const
Definition ast.h:272
const Def * emit_type(Emitter &) const override
Definition emit.cpp:91
const Ptrn * ptrn() const
Definition ast.h:271
const Def * emit_(Emitter &) const override
Definition emit.cpp:295
bool is_explicit() const
Definition ast.h:666
const Expr * arg() const
Definition ast.h:668
const Expr * callee() const
Definition ast.h:667
void emit_body(Emitter &, const Def *decl) const override
Definition emit.cpp:210
const Def * emit_decl(Emitter &, const Def *type) const override
Definition emit.cpp:206
const Def * emit_(Emitter &) const override
Definition emit.cpp:215
void emit(Emitter &) const override
Definition emit.cpp:394
const Expr * type() const
Definition ast.h:904
Tok trip() const
Definition ast.h:907
size_t num_subs() const
Definition ast.h:902
Tok curry() const
Definition ast.h:906
Dbg dbg() const
Definition ast.h:900
const auto & sub(size_t i) const
Definition ast.h:903
Tok::Tag tag() const
Definition ast.h:1036
const Ptrn * dom() const
Definition ast.h:1037
void emit(Emitter &) const override
Definition emit.cpp:531
const Expr * codom() const
Definition ast.h:1038
Dbg dbg() const
Definition ast.h:1035
const Expr * expr() const
Definition ast.h:416
const Def * emit_(Emitter &) const override
Definition emit.cpp:196
const auto & decls() const
Definition ast.h:414
bool is_where() const
Definition ast.h:415
const Def * def_
Definition ast.h:169
const Def * def() const
Definition ast.h:166
void attach(AnnexInfo *annex, sub_t sub, Sym name, const Def *def)
name is the full syntactic name of this registration (plugin.tag or plugin.tag.sub).
Definition emit.cpp:24
AST & ast() const
Definition emit.cpp:17
World & world()
Definition emit.cpp:18
Emitter(AST &ast)
Definition emit.cpp:14
absl::node_hash_map< Sigma *, fe::SymMap< size_t >, GIDHash< const Def * > > sigma2sym2idx
Definition emit.cpp:28
Driver & driver()
Definition emit.cpp:19
const Def * emit_(Emitter &) const override
Definition emit.cpp:135
const Def * emit_type(Emitter &) const override
Definition emit.cpp:84
const Def * emit_value(Emitter &, const Def *) const override
Definition emit.cpp:59
const Def * emit(Emitter &) const
Definition emit.cpp:130
virtual void emit_body(Emitter &, const Def *) const
Definition ast.h:154
virtual const Def * emit_(Emitter &) const =0
virtual const Def * emit_decl(Emitter &, const Def *) const
Definition ast.h:153
const Decl * decl() const
Definition ast.h:789
const Def * emit_(Emitter &) const override
Definition emit.cpp:360
const auto & index() const
Definition ast.h:788
const Expr * tuple() const
Definition ast.h:787
const Def * emit_type(Emitter &) const override
Definition emit.cpp:93
const Def * emit_value(Emitter &, const Def *) const override
Definition emit.cpp:66
Dbg dbg() const
Definition ast.h:250
const IdPtrn * id() const
Definition ast.h:251
const Def * emit_(Emitter &) const override
Definition emit.cpp:136
const Def * emit_(Emitter &) const override
Definition emit.cpp:138
const Decl * decl() const
Definition ast.h:351
const Def * emit_type(Emitter &) const override
Definition emit.cpp:86
const Def * emit_value(Emitter &, const Def *) const override
Definition emit.cpp:61
Dbg dbg() const
Definition ast.h:220
const Expr * type() const
Definition ast.h:221
void emit(Emitter &) const
Definition emit.cpp:53
const Module * module() const
Definition ast.h:1097
const Def * emit_(Emitter &) const override
Definition emit.cpp:228
const Expr * type() const
Definition ast.h:496
const Expr * value() const
Definition ast.h:495
const Expr * index() const
Definition ast.h:812
const Expr * tuple() const
Definition ast.h:811
const Def * emit_(Emitter &) const override
Definition emit.cpp:381
const Expr * value() const
Definition ast.h:813
Lam * emit_value(Emitter &) const
Definition emit.cpp:459
bool is_external() const
Definition ast.h:1004
const Ptrs< Dom > & doms() const
Definition ast.h:1005
const Expr * codom() const
Definition ast.h:1008
void emit_decl(Emitter &) const override
Definition emit.cpp:473
size_t num_doms() const
Definition ast.h:1007
void emit_body(Emitter &) const override
Definition emit.cpp:500
const Dom * dom(size_t i) const
Definition ast.h:1006
void emit_body(Emitter &, const Def *decl) const override
Definition emit.cpp:287
const Def * emit_(Emitter &) const override
Definition emit.cpp:289
const LamDecl * lam() const
Definition ast.h:644
const Def * emit_decl(Emitter &, const Def *type) const override
Definition emit.cpp:286
const Expr * value() const
Definition ast.h:857
const Ptrn * ptrn() const
Definition ast.h:856
void emit(Emitter &) const override
Definition emit.cpp:434
Tok tok() const
Definition ast.h:391
const Expr * type() const
Definition ast.h:393
const Def * emit_(Emitter &) const override
Definition emit.cpp:179
Tok::Tag tag() const
Definition ast.h:392
Lam * emit(Emitter &) const
Definition emit.cpp:234
const Expr * body() const
Definition ast.h:521
const Ptrn * ptrn() const
Definition ast.h:520
const Def * emit_(Emitter &) const override
Definition emit.cpp:243
const Expr * scrutinee() const
Definition ast.h:537
const Arm * arm(size_t i) const
Definition ast.h:539
const auto & arms() const
Definition ast.h:538
const auto & decls() const
Definition ast.h:1125
void emit(AST &) const
Definition emit.cpp:38
const auto & implicit_imports() const
Definition ast.h:1123
const auto & imports() const
Definition ast.h:1124
Loc loc() const
Definition ast.h:134
virtual void emit_type(Emitter &) const
Definition emit.cpp:251
const IdPtrn * ret() const
Definition ast.h:593
bool is_implicit() const
Definition ast.h:591
const Ptrn * ptrn() const
Definition ast.h:592
const Def * emit_(Emitter &) const override
Definition emit.cpp:280
const Def * emit_decl(Emitter &, const Def *type) const override
Definition emit.cpp:274
void emit_body(Emitter &, const Def *decl) const override
Definition emit.cpp:278
Tok::Tag tag() const
Definition ast.h:372
virtual const Def * emit_value(Emitter &, const Def *) const =0
virtual const Def * emit_type(Emitter &) const =0
void emit(Emitter &) const override
Definition emit.cpp:440
Dbg dbg() const
Definition ast.h:934
virtual void emit_body(Emitter &) const
Definition emit.cpp:453
virtual void emit_decl(Emitter &) const
Definition emit.cpp:447
const Expr * body() const
Definition ast.h:936
const Expr * type() const
Definition ast.h:935
const Ptrn * ptrn() const
Definition ast.h:691
const Expr * arg() const
Definition ast.h:693
const Def * emit_(Emitter &) const override
Definition emit.cpp:301
const Expr * body() const
Definition ast.h:694
const Expr * callee() const
Definition ast.h:692
const Ptrn * var() const
Definition ast.h:1066
const Expr * guard() const
Definition ast.h:1069
const Expr * rhs() const
Definition ast.h:1068
const Expr * lhs() const
Definition ast.h:1067
Dbg dbg() const
Definition ast.h:1065
void emit(Emitter &) const override
Definition emit.cpp:541
const Expr * dom() const
Definition ast.h:454
const Def * emit_(Emitter &) const override
Definition emit.cpp:148
bool is_pack() const
Definition ast.h:760
const Expr * body() const
Definition ast.h:762
const IdPtrn * arity() const
Definition ast.h:761
const Def * emit_(Emitter &) const override
Definition emit.cpp:325
const TuplePtrn * ptrn() const
Definition ast.h:716
const Def * emit_(Emitter &) const override
Definition emit.cpp:318
void emit_body(Emitter &, const Def *decl) const override
Definition emit.cpp:317
const Def * emit_decl(Emitter &, const Def *type) const override
Definition emit.cpp:316
const Lit * lit_i() const
Definition tok.h:219
const Expr * elem(size_t i) const
Definition ast.h:739
const Def * emit_(Emitter &) const override
Definition emit.cpp:320
const auto & elems() const
Definition ast.h:738
size_t num_elems() const
Definition ast.h:740
const Ptrn * ptrn(size_t i) const
Definition ast.h:300
const Def * emit_type(Emitter &) const override
Definition emit.cpp:95
const Def * emit_decl(Emitter &, const Def *type) const
Definition emit.cpp:120
size_t num_ptrns() const
Definition ast.h:301
const Def * emit_value(Emitter &, const Def *) const override
Definition emit.cpp:72
const Def * emit_body(Emitter &, const Def *decl) const
Definition emit.cpp:97
const Def * emit_(Emitter &) const override
Definition emit.cpp:143
const Expr * level() const
Definition ast.h:436
const auto & types() const
Definition ast.h:474
const Def * emit_(Emitter &) const override
Definition emit.cpp:221
const Expr * inhabitant() const
Definition ast.h:833
const Def * emit_(Emitter &) const override
Definition emit.cpp:388
Definition ast.h:14
Tok::Tag Tag
Definition bind.cpp:7
Vector< const Def * > DefVec
Definition def.h:79
u8 sub_t
Definition types.h:42
@ Hole
Definition def.h:122
constexpr decltype(auto) get(Span< T, N > span) noexcept
Definition span.h:115
void error(std::format_string< Args... > fmt, Args &&... args)
Wraps std::format to throw T with a formatted message.
Definition dbg.h:17
struct mim::ast::AnnexInfo::@177100250272201136376142224053244231100060214216 id
plugin_t plugin_id() const
The mangled plugin part of the flags.
Definition ast.h:34