summaryrefslogtreecommitdiffstats
path: root/src/doc/rustc-dev-guide/src/solve/the-solver.md
blob: 61e6cad1c3c9915b17304a3f80b95d9bdf837ef2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# The solver

Also consider reading the documentation for [the recursive solver in chalk][chalk]
as it is very similar to this implementation and also talks about limitations of this
approach.

[chalk]: https://rust-lang.github.io/chalk/book/recursive.html

The basic structure of the solver is a pure function
`fn evaluate_goal(goal: Goal<'tcx>) -> Response`.
While the actual solver is not fully pure to deal with overflow and cycles, we are
going to defer that for now.

To deal with inference variables and to improve caching, we use
[canonicalization](./canonicalization.md).

TODO: write the remaining code for this as well.