2021-02-01 12:20:35 +00:00
|
|
|
mod block;
|
|
|
|
|
2021-02-09 16:22:57 +00:00
|
|
|
use base_db::{fixture::WithFixture, SourceDatabase};
|
2021-02-01 12:20:35 +00:00
|
|
|
use expect_test::Expect;
|
2020-10-23 17:27:04 +00:00
|
|
|
|
2021-06-13 15:45:38 +00:00
|
|
|
use crate::ModuleDefId;
|
2020-10-23 17:27:04 +00:00
|
|
|
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
fn lower(ra_fixture: &str) -> Arc<Body> {
|
2021-01-21 19:35:36 +00:00
|
|
|
let db = crate::test_db::TestDB::with_files(ra_fixture);
|
2020-10-23 17:27:04 +00:00
|
|
|
|
|
|
|
let krate = db.crate_graph().iter().next().unwrap();
|
|
|
|
let def_map = db.crate_def_map(krate);
|
2021-01-21 19:35:36 +00:00
|
|
|
let mut fn_def = None;
|
|
|
|
'outer: for (_, module) in def_map.modules() {
|
|
|
|
for decl in module.scope.declarations() {
|
2021-06-07 11:59:01 +00:00
|
|
|
if let ModuleDefId::FunctionId(it) = decl {
|
|
|
|
fn_def = Some(it);
|
|
|
|
break 'outer;
|
2021-01-21 19:35:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
db.body(fn_def.unwrap().into())
|
2020-10-23 17:27:04 +00:00
|
|
|
}
|
|
|
|
|
2021-02-04 12:44:54 +00:00
|
|
|
fn block_def_map_at(ra_fixture: &str) -> String {
|
2021-02-01 12:20:35 +00:00
|
|
|
let (db, position) = crate::test_db::TestDB::with_position(ra_fixture);
|
|
|
|
|
2021-02-09 16:22:57 +00:00
|
|
|
let module = db.module_at_position(position);
|
|
|
|
module.def_map(&db).dump(&db)
|
2021-02-01 12:20:35 +00:00
|
|
|
}
|
|
|
|
|
2021-04-21 15:57:45 +00:00
|
|
|
fn check_block_scopes_at(ra_fixture: &str, expect: Expect) {
|
|
|
|
let (db, position) = crate::test_db::TestDB::with_position(ra_fixture);
|
|
|
|
|
|
|
|
let module = db.module_at_position(position);
|
|
|
|
let actual = module.def_map(&db).dump_block_scopes(&db);
|
|
|
|
expect.assert_eq(&actual);
|
|
|
|
}
|
|
|
|
|
2021-02-01 12:20:35 +00:00
|
|
|
fn check_at(ra_fixture: &str, expect: Expect) {
|
2021-02-04 12:44:54 +00:00
|
|
|
let actual = block_def_map_at(ra_fixture);
|
2021-02-01 12:20:35 +00:00
|
|
|
expect.assert_eq(&actual);
|
|
|
|
}
|
|
|
|
|
2020-10-23 17:27:04 +00:00
|
|
|
#[test]
|
|
|
|
fn your_stack_belongs_to_me() {
|
2021-03-08 20:19:44 +00:00
|
|
|
cov_mark::check!(your_stack_belongs_to_me);
|
2020-10-23 17:27:04 +00:00
|
|
|
lower(
|
2021-06-13 15:45:38 +00:00
|
|
|
r#"
|
2020-10-23 17:27:04 +00:00
|
|
|
macro_rules! n_nuple {
|
|
|
|
($e:tt) => ();
|
|
|
|
($($rest:tt)*) => {{
|
|
|
|
(n_nuple!($($rest)*)None,)
|
|
|
|
}};
|
|
|
|
}
|
|
|
|
fn main() { n_nuple!(1,2,3); }
|
2021-06-13 15:45:38 +00:00
|
|
|
"#,
|
2020-10-23 17:27:04 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-27 22:23:09 +00:00
|
|
|
#[test]
|
|
|
|
fn recursion_limit() {
|
|
|
|
cov_mark::check!(your_stack_belongs_to_me);
|
|
|
|
|
|
|
|
lower(
|
|
|
|
r#"
|
|
|
|
#![recursion_limit = "2"]
|
|
|
|
macro_rules! n_nuple {
|
|
|
|
($e:tt) => ();
|
|
|
|
($first:tt $($rest:tt)*) => {{
|
|
|
|
n_nuple!($($rest)*)
|
|
|
|
}};
|
|
|
|
}
|
|
|
|
fn main() { n_nuple!(1,2,3); }
|
|
|
|
"#,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-21 19:35:36 +00:00
|
|
|
#[test]
|
|
|
|
fn macro_resolve() {
|
|
|
|
// Regression test for a path resolution bug introduced with inner item handling.
|
|
|
|
lower(
|
2021-06-13 15:45:38 +00:00
|
|
|
r#"
|
2021-01-21 19:35:36 +00:00
|
|
|
macro_rules! vec {
|
|
|
|
() => { () };
|
|
|
|
($elem:expr; $n:expr) => { () };
|
|
|
|
($($x:expr),+ $(,)?) => { () };
|
|
|
|
}
|
|
|
|
mod m {
|
|
|
|
fn outer() {
|
|
|
|
let _ = vec![FileSet::default(); self.len()];
|
|
|
|
}
|
|
|
|
}
|
2021-06-13 15:45:38 +00:00
|
|
|
"#,
|
2021-01-21 19:35:36 +00:00
|
|
|
);
|
|
|
|
}
|