Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | hir_ty: don't pass where clauses of associated types down to chalk (temp. ↵ | cynecx | 2021-05-30 | 2 | -11/+28 |
| | | | | fix #9052) | ||||
* | hir_ty: use async ret type for inference inside async bodies | cynecx | 2021-05-29 | 2 | -1/+56 |
| | |||||
* | Remove fragment kind knowledge from builtin macros | Jonas Schievink | 2021-05-29 | 1 | -0/+18 |
| | |||||
* | Move hir_ty incremental test to its own file | Jonas Schievink | 2021-05-27 | 2 | -44/+52 |
| | |||||
* | Merge #9007 | bors[bot] | 2021-05-26 | 3 | -17/+15 |
|\ | | | | | | | | | | | | | | | 9007: Internal: `clippy::redundant_clone` fixes r=lnicola a=lnicola bors r+ Co-authored-by: Laurențiu Nicola <[email protected]> | ||||
| * | clippy::redundant_clone fixes | Laurențiu Nicola | 2021-05-26 | 3 | -17/+15 |
| | | |||||
* | | Merge #8973 | bors[bot] | 2021-05-25 | 7 | -15/+125 |
|\ \ | | | | | | | | | | | | | | | | | | | | | | 8973: internal: move diagnostics to hir r=matklad a=matklad Co-authored-by: Aleksey Kladov <[email protected]> | ||||
| * | | internal: move diagnostics to hir | Aleksey Kladov | 2021-05-25 | 7 | -15/+125 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The idea here is to eventually get rid of `dyn Diagnostic` and `DiagnosticSink` infrastructure altogether, and just have a `enum hir::Diagnostic` instead. The problem with `dyn Diagnostic` is that it is defined in the lowest level of the stack (hir_expand), but is used by the highest level (ide). As a first step, we free hir_expand and hir_def from `dyn Diagnostic` and kick the can up to `hir_ty`, as an intermediate state. The plan is then to move DiagnosticSink similarly to the hir crate, and, as final third step, remove its usage from the ide. One currently unsolved problem is testing. You can notice that the test which checks precise diagnostic ranges, unresolved_import_in_use_tree, was moved to the ide layer. Logically, only IDE should have the infra to render a specific range. At the same time, the range is determined with the data produced in hir_def and hir crates, so this layering is rather unfortunate. Working on hir_def shouldn't require compiling `ide` for testing. | ||||
* | | | Consider trait to be in scope for trait-impl | Lukas Wirth | 2021-05-25 | 2 | -0/+32 |
| | | | |||||
* | | | Merge #8987 | bors[bot] | 2021-05-25 | 2 | -4/+28 |
|\ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8987: Fix lowering of FnOnce() without return type r=flodiebold a=flodiebold This should result in an implicit `-> ()`, not leaving out the binding. Co-authored-by: Florian Diebold <[email protected]> | ||||
| * | | | Hide `-> ()` in Fn traits | Florian Diebold | 2021-05-25 | 2 | -5/+7 |
| | | | | |||||
| * | | | Fix lowering of FnOnce() without return type | Florian Diebold | 2021-05-25 | 1 | -5/+27 |
| |/ / | | | | | | | | | | This should result in an implicit `-> ()`, not leaving out the binding. | ||||
* / / | Fix type inference not working for new Try trait | Lukas Wirth | 2021-05-25 | 2 | -1/+41 |
|/ / | |||||
* | | Minor test fixes / new tests | Florian Diebold | 2021-05-25 | 1 | -15/+62 |
| | | |||||
* | | Fix type mismatch caused by macros | Florian Diebold | 2021-05-25 | 2 | -1/+45 |
|/ | | | | | | MacroStmts should be completely transparent, but it prevented coercion. (I should maybe give `infer_expr` and `infer_expr_inner` better names.) | ||||
* | internal: rename hypothetical -> speculative | Aleksey Kladov | 2021-05-24 | 1 | -1/+1 |
| | | | | | Lets steal this good naming from Roslyn before I forget about it yet again. | ||||
* | internal: intern `TypeBound`s | Jonas Schievink | 2021-05-24 | 2 | -1/+9 |
| | | | | | Doesn't save much memory (~2 mb), but interning things is generally a good pattern to follow | ||||
* | Record method call substs and use them in call info | Florian Diebold | 2021-05-23 | 5 | -38/+42 |
| | |||||
* | Add test for #8931 and better checking | Florian Diebold | 2021-05-23 | 1 | -11/+83 |
| | |||||
* | Add last remaining module docstring | Florian Diebold | 2021-05-22 | 1 | -1/+3 |
| | |||||
* | Resolve any lifetime variables to 'static after inference | Florian Diebold | 2021-05-22 | 1 | -1/+13 |
| | | | | | | | | Chalk's unification can sometimes create lifetime variables, which we currently don't really deal with, but at least we don't want to leak them outside of inference. Should fix #8919. | ||||
* | Clean up visibilities | Florian Diebold | 2021-05-21 | 1 | -10/+10 |
| | |||||
* | Some remaining cleanups | Florian Diebold | 2021-05-21 | 3 | -18/+13 |
| | |||||
* | Fix test after rebase | Florian Diebold | 2021-05-21 | 1 | -1/+1 |
| | |||||
* | Record type mismatches for failed coercions in match etc. | Florian Diebold | 2021-05-21 | 2 | -15/+21 |
| | |||||
* | Refactor expectation handling | Florian Diebold | 2021-05-21 | 3 | -54/+88 |
| | | | | So as to not use `TyKind::Error` as "no expectation". | ||||
* | Remove TypeVariableTable | Florian Diebold | 2021-05-21 | 2 | -56/+48 |
| | |||||
* | Deal with goals arising from unification | Florian Diebold | 2021-05-21 | 4 | -18/+21 |
| | |||||
* | Get rid of resolve_ty_as_possible | Florian Diebold | 2021-05-21 | 8 | -88/+56 |
| | | | | Instead use shallow resolving where necessary. | ||||
* | Make resolve_ty_shallow return Ty | Florian Diebold | 2021-05-21 | 3 | -14/+7 |
| | |||||
* | Rework obligation handling | Florian Diebold | 2021-05-21 | 10 | -139/+234 |
| | | | | | | | | We can't do the easy hack that we did before anymore, where we kept track of whether any inference variables changed since the last time we rechecked obligations. Instead, we store the obligations in canonicalized form; that way we can easily check the inference variables to see whether they have changed since the goal was canonicalized. | ||||
* | Fix another panic | Florian Diebold | 2021-05-21 | 1 | -17/+15 |
| | |||||
* | Improve debug printing without TLS | Florian Diebold | 2021-05-21 | 2 | -158/+21 |
| | |||||
* | Fix panic | Florian Diebold | 2021-05-21 | 1 | -1/+4 |
| | |||||
* | Fix HIR expecting errors to unify with anything | Florian Diebold | 2021-05-21 | 2 | -2/+62 |
| | |||||
* | Fix if/else coercion | Florian Diebold | 2021-05-21 | 1 | -1/+4 |
| | |||||
* | Make diverging type variables work again | Florian Diebold | 2021-05-21 | 2 | -0/+23 |
| | | | | | Chalk doesn't know about the `diverging` flag, so we need to instead propagate it before fully resolving the variables. | ||||
* | Fix handling of diverging branches in match coercion | Florian Diebold | 2021-05-21 | 2 | -4/+52 |
| | | | | Fixes #7626. | ||||
* | Fix coercion of two closures to a function pointer | Florian Diebold | 2021-05-21 | 4 | -56/+48 |
| | | | | Fixes #8604. | ||||
* | Update tests with expected changes | Florian Diebold | 2021-05-21 | 2 | -40/+34 |
| | |||||
* | Make type resolver a proper folder, make it resolve consts as well | Florian Diebold | 2021-05-21 | 1 | -48/+117 |
| | |||||
* | Fix fallback to bound vars in `unify` | Florian Diebold | 2021-05-21 | 1 | -45/+78 |
| | |||||
* | Better Debug impl for InternedWrapper | Florian Diebold | 2021-05-21 | 1 | -1/+7 |
| | |||||
* | Temporary fix for unknown expectations | Florian Diebold | 2021-05-21 | 2 | -0/+8 |
| | |||||
* | Fix warnings & format | Florian Diebold | 2021-05-21 | 3 | -20/+11 |
| | |||||
* | Rewrite coercion using the new unification | Florian Diebold | 2021-05-21 | 6 | -105/+371 |
| | |||||
* | Remove our unification code, use Chalk's instead | Florian Diebold | 2021-05-21 | 8 | -438/+125 |
| | |||||
* | Check patterns for type match recursively. | Dawer | 2021-05-19 | 2 | -2/+30 |
| | |||||
* | internal: Record mismatches of pattern types. | Dawer | 2021-05-19 | 6 | -11/+93 |
| | |||||
* | Merge #8813 | bors[bot] | 2021-05-16 | 11 | -103/+251 |
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 8813: Get some more array lengths! r=lf- a=lf- This is built on #8799 and thus contains its changes. I'll rebase it onto master when that one gets merged. It adds support for r-a understanding the length of: * `let a: [u8; 2] = ...` * `let a = b"aaa"` * `let a = [0u8; 4]` I have added support for getting the values of byte strings, which was not previously there. I am least confident in the correctness of this part and it probably needs some more tests, as we currently have only one test that exercised that part (!). Fixes #2922. Co-authored-by: Jade <[email protected]> |