Convert tests to text-size

This commit is contained in:
Aleksey Kladov 2020-04-24 23:51:02 +02:00
parent b1d5817dd1
commit 8843588fca
376 changed files with 26489 additions and 26521 deletions

View file

@ -308,8 +308,7 @@ mod tests {
let before = "struct Foo { <|>bar: u32 }";
let (before_cursor_pos, before) = extract_offset(before);
let (db, file_id) = helpers::with_single_file(&before);
let frange =
FileRange { file_id, range: TextRange::offset_len(before_cursor_pos, 0.into()) };
let frange = FileRange { file_id, range: TextRange::empty(before_cursor_pos) };
let assists = resolved_assists(&db, frange);
let mut assists = assists.iter();

View file

@ -194,7 +194,7 @@ mod tests {
let (off, code) = extract_offset(code);
let code = {
let mut buf = String::new();
let off = off.to_usize();
let off: usize = off.into();
buf.push_str(&code[..off]);
buf.push_str("marker");
buf.push_str(&code[off..]);

View file

@ -29,10 +29,10 @@ fn test() {
}
"#),
@r###"
[11; 41) '{ ...4 }; }': ()
[21; 22) 'a': i32
[30; 38) '{ 1i64 }': i64
[32; 36) '1i64': i64
11..41 '{ ...4 }; }': ()
21..22 'a': i32
30..38 '{ 1i64 }': i64
32..36 '1i64': i64
"###);
}
@ -63,50 +63,50 @@ fn test2() {
}
"#),
@r###"
[31; 32) '_': &[T]
[45; 56) '{ loop {} }': T
[47; 54) 'loop {}': !
[52; 54) '{}': ()
[65; 66) '_': S<&[T]>
[82; 93) '{ loop {} }': T
[84; 91) 'loop {}': !
[89; 91) '{}': ()
[122; 133) '{ loop {} }': *mut [T; _]
[124; 131) 'loop {}': !
[129; 131) '{}': ()
[160; 173) '{ gen() }': *mut [U]
[166; 169) 'gen': fn gen<U>() -> *mut [U; _]
[166; 171) 'gen()': *mut [U; _]
[186; 420) '{ ...rr); }': ()
[196; 199) 'arr': &[u8; _]
[212; 216) '&[1]': &[u8; _]
[213; 216) '[1]': [u8; _]
[214; 215) '1': u8
[227; 228) 'a': &[u8]
[237; 240) 'arr': &[u8; _]
[250; 251) 'b': u8
[254; 255) 'f': fn f<u8>(&[u8]) -> u8
[254; 260) 'f(arr)': u8
[256; 259) 'arr': &[u8; _]
[270; 271) 'c': &[u8]
[280; 287) '{ arr }': &[u8]
[282; 285) 'arr': &[u8; _]
[297; 298) 'd': u8
[301; 302) 'g': fn g<u8>(S<&[u8]>) -> u8
[301; 316) 'g(S { a: arr })': u8
[303; 315) 'S { a: arr }': S<&[u8]>
[310; 313) 'arr': &[u8; _]
[326; 327) 'e': [&[u8]; _]
[341; 346) '[arr]': [&[u8]; _]
[342; 345) 'arr': &[u8; _]
[356; 357) 'f': [&[u8]; _]
[371; 379) '[arr; 2]': [&[u8]; _]
[372; 375) 'arr': &[u8; _]
[377; 378) '2': usize
[389; 390) 'g': (&[u8], &[u8])
[407; 417) '(arr, arr)': (&[u8], &[u8])
[408; 411) 'arr': &[u8; _]
[413; 416) 'arr': &[u8; _]
31..32 '_': &[T]
45..56 '{ loop {} }': T
47..54 'loop {}': !
52..54 '{}': ()
65..66 '_': S<&[T]>
82..93 '{ loop {} }': T
84..91 'loop {}': !
89..91 '{}': ()
122..133 '{ loop {} }': *mut [T; _]
124..131 'loop {}': !
129..131 '{}': ()
160..173 '{ gen() }': *mut [U]
166..169 'gen': fn gen<U>() -> *mut [U; _]
166..171 'gen()': *mut [U; _]
186..420 '{ ...rr); }': ()
196..199 'arr': &[u8; _]
212..216 '&[1]': &[u8; _]
213..216 '[1]': [u8; _]
214..215 '1': u8
227..228 'a': &[u8]
237..240 'arr': &[u8; _]
250..251 'b': u8
254..255 'f': fn f<u8>(&[u8]) -> u8
254..260 'f(arr)': u8
256..259 'arr': &[u8; _]
270..271 'c': &[u8]
280..287 '{ arr }': &[u8]
282..285 'arr': &[u8; _]
297..298 'd': u8
301..302 'g': fn g<u8>(S<&[u8]>) -> u8
301..316 'g(S { a: arr })': u8
303..315 'S { a: arr }': S<&[u8]>
310..313 'arr': &[u8; _]
326..327 'e': [&[u8]; _]
341..346 '[arr]': [&[u8]; _]
342..345 'arr': &[u8; _]
356..357 'f': [&[u8]; _]
371..379 '[arr; 2]': [&[u8]; _]
372..375 'arr': &[u8; _]
377..378 '2': usize
389..390 'g': (&[u8], &[u8])
407..417 '(arr, arr)': (&[u8], &[u8])
408..411 'arr': &[u8; _]
413..416 'arr': &[u8; _]
"###
);
}
@ -120,11 +120,11 @@ fn test() {
}
"#),
@r###"
[11; 40) '{ ...[1]; }': ()
[21; 22) 'x': &[i32]
[33; 37) '&[1]': &[i32; _]
[34; 37) '[1]': [i32; _]
[35; 36) '1': i32
11..40 '{ ...[1]; }': ()
21..22 'x': &[i32]
33..37 '&[1]': &[i32; _]
34..37 '[1]': [i32; _]
35..36 '1': i32
"###);
}
@ -150,31 +150,31 @@ fn test(a: A<[u8; 2]>, b: B<[u8; 2]>, c: C<[u8; 2]>) {
}
"#),
@r###"
[258; 259) 'x': A<[T]>
[279; 284) '{ x }': A<[T]>
[281; 282) 'x': A<[T]>
[296; 297) 'x': B<[T]>
[317; 322) '{ x }': B<[T]>
[319; 320) 'x': B<[T]>
[334; 335) 'x': C<[T]>
[355; 360) '{ x }': C<[T]>
[357; 358) 'x': C<[T]>
[370; 371) 'a': A<[u8; _]>
[385; 386) 'b': B<[u8; _]>
[400; 401) 'c': C<[u8; _]>
[415; 481) '{ ...(c); }': ()
[425; 426) 'd': A<[{unknown}]>
[429; 433) 'foo1': fn foo1<{unknown}>(A<[{unknown}]>) -> A<[{unknown}]>
[429; 436) 'foo1(a)': A<[{unknown}]>
[434; 435) 'a': A<[u8; _]>
[446; 447) 'e': B<[u8]>
[450; 454) 'foo2': fn foo2<u8>(B<[u8]>) -> B<[u8]>
[450; 457) 'foo2(b)': B<[u8]>
[455; 456) 'b': B<[u8; _]>
[467; 468) 'f': C<[u8]>
[471; 475) 'foo3': fn foo3<u8>(C<[u8]>) -> C<[u8]>
[471; 478) 'foo3(c)': C<[u8]>
[476; 477) 'c': C<[u8; _]>
258..259 'x': A<[T]>
279..284 '{ x }': A<[T]>
281..282 'x': A<[T]>
296..297 'x': B<[T]>
317..322 '{ x }': B<[T]>
319..320 'x': B<[T]>
334..335 'x': C<[T]>
355..360 '{ x }': C<[T]>
357..358 'x': C<[T]>
370..371 'a': A<[u8; _]>
385..386 'b': B<[u8; _]>
400..401 'c': C<[u8; _]>
415..481 '{ ...(c); }': ()
425..426 'd': A<[{unknown}]>
429..433 'foo1': fn foo1<{unknown}>(A<[{unknown}]>) -> A<[{unknown}]>
429..436 'foo1(a)': A<[{unknown}]>
434..435 'a': A<[u8; _]>
446..447 'e': B<[u8]>
450..454 'foo2': fn foo2<u8>(B<[u8]>) -> B<[u8]>
450..457 'foo2(b)': B<[u8]>
455..456 'b': B<[u8; _]>
467..468 'f': C<[u8]>
471..475 'foo3': fn foo3<u8>(C<[u8]>) -> C<[u8]>
471..478 'foo3(c)': C<[u8]>
476..477 'c': C<[u8; _]>
"###
);
}
@ -193,24 +193,24 @@ fn test() {
}
"#),
@r###"
[11; 12) 'x': &[T]
[28; 39) '{ loop {} }': &[T]
[30; 37) 'loop {}': !
[35; 37) '{}': ()
[50; 126) '{ ... }; }': ()
[60; 61) 'x': &[i32]
[64; 123) 'if tru... }': &[i32]
[67; 71) 'true': bool
[72; 97) '{ ... }': &[i32]
[82; 85) 'foo': fn foo<i32>(&[i32]) -> &[i32]
[82; 91) 'foo(&[1])': &[i32]
[86; 90) '&[1]': &[i32; _]
[87; 90) '[1]': [i32; _]
[88; 89) '1': i32
[103; 123) '{ ... }': &[i32; _]
[113; 117) '&[1]': &[i32; _]
[114; 117) '[1]': [i32; _]
[115; 116) '1': i32
11..12 'x': &[T]
28..39 '{ loop {} }': &[T]
30..37 'loop {}': !
35..37 '{}': ()
50..126 '{ ... }; }': ()
60..61 'x': &[i32]
64..123 'if tru... }': &[i32]
67..71 'true': bool
72..97 '{ ... }': &[i32]
82..85 'foo': fn foo<i32>(&[i32]) -> &[i32]
82..91 'foo(&[1])': &[i32]
86..90 '&[1]': &[i32; _]
87..90 '[1]': [i32; _]
88..89 '1': i32
103..123 '{ ... }': &[i32; _]
113..117 '&[1]': &[i32; _]
114..117 '[1]': [i32; _]
115..116 '1': i32
"###
);
}
@ -229,24 +229,24 @@ fn test() {
}
"#),
@r###"
[11; 12) 'x': &[T]
[28; 39) '{ loop {} }': &[T]
[30; 37) 'loop {}': !
[35; 37) '{}': ()
[50; 126) '{ ... }; }': ()
[60; 61) 'x': &[i32]
[64; 123) 'if tru... }': &[i32]
[67; 71) 'true': bool
[72; 92) '{ ... }': &[i32; _]
[82; 86) '&[1]': &[i32; _]
[83; 86) '[1]': [i32; _]
[84; 85) '1': i32
[98; 123) '{ ... }': &[i32]
[108; 111) 'foo': fn foo<i32>(&[i32]) -> &[i32]
[108; 117) 'foo(&[1])': &[i32]
[112; 116) '&[1]': &[i32; _]
[113; 116) '[1]': [i32; _]
[114; 115) '1': i32
11..12 'x': &[T]
28..39 '{ loop {} }': &[T]
30..37 'loop {}': !
35..37 '{}': ()
50..126 '{ ... }; }': ()
60..61 'x': &[i32]
64..123 'if tru... }': &[i32]
67..71 'true': bool
72..92 '{ ... }': &[i32; _]
82..86 '&[1]': &[i32; _]
83..86 '[1]': [i32; _]
84..85 '1': i32
98..123 '{ ... }': &[i32]
108..111 'foo': fn foo<i32>(&[i32]) -> &[i32]
108..117 'foo(&[1])': &[i32]
112..116 '&[1]': &[i32; _]
113..116 '[1]': [i32; _]
114..115 '1': i32
"###
);
}
@ -265,31 +265,31 @@ fn test(i: i32) {
}
"#),
@r###"
[11; 12) 'x': &[T]
[28; 39) '{ loop {} }': &[T]
[30; 37) 'loop {}': !
[35; 37) '{}': ()
[48; 49) 'i': i32
[56; 150) '{ ... }; }': ()
[66; 67) 'x': &[i32]
[70; 147) 'match ... }': &[i32]
[76; 77) 'i': i32
[88; 89) '2': i32
[88; 89) '2': i32
[93; 96) 'foo': fn foo<i32>(&[i32]) -> &[i32]
[93; 102) 'foo(&[2])': &[i32]
[97; 101) '&[2]': &[i32; _]
[98; 101) '[2]': [i32; _]
[99; 100) '2': i32
[112; 113) '1': i32
[112; 113) '1': i32
[117; 121) '&[1]': &[i32; _]
[118; 121) '[1]': [i32; _]
[119; 120) '1': i32
[131; 132) '_': i32
[136; 140) '&[3]': &[i32; _]
[137; 140) '[3]': [i32; _]
[138; 139) '3': i32
11..12 'x': &[T]
28..39 '{ loop {} }': &[T]
30..37 'loop {}': !
35..37 '{}': ()
48..49 'i': i32
56..150 '{ ... }; }': ()
66..67 'x': &[i32]
70..147 'match ... }': &[i32]
76..77 'i': i32
88..89 '2': i32
88..89 '2': i32
93..96 'foo': fn foo<i32>(&[i32]) -> &[i32]
93..102 'foo(&[2])': &[i32]
97..101 '&[2]': &[i32; _]
98..101 '[2]': [i32; _]
99..100 '2': i32
112..113 '1': i32
112..113 '1': i32
117..121 '&[1]': &[i32; _]
118..121 '[1]': [i32; _]
119..120 '1': i32
131..132 '_': i32
136..140 '&[3]': &[i32; _]
137..140 '[3]': [i32; _]
138..139 '3': i32
"###
);
}
@ -308,31 +308,31 @@ fn test(i: i32) {
}
"#),
@r###"
[11; 12) 'x': &[T]
[28; 39) '{ loop {} }': &[T]
[30; 37) 'loop {}': !
[35; 37) '{}': ()
[48; 49) 'i': i32
[56; 150) '{ ... }; }': ()
[66; 67) 'x': &[i32]
[70; 147) 'match ... }': &[i32]
[76; 77) 'i': i32
[88; 89) '1': i32
[88; 89) '1': i32
[93; 97) '&[1]': &[i32; _]
[94; 97) '[1]': [i32; _]
[95; 96) '1': i32
[107; 108) '2': i32
[107; 108) '2': i32
[112; 115) 'foo': fn foo<i32>(&[i32]) -> &[i32]
[112; 121) 'foo(&[2])': &[i32]
[116; 120) '&[2]': &[i32; _]
[117; 120) '[2]': [i32; _]
[118; 119) '2': i32
[131; 132) '_': i32
[136; 140) '&[3]': &[i32; _]
[137; 140) '[3]': [i32; _]
[138; 139) '3': i32
11..12 'x': &[T]
28..39 '{ loop {} }': &[T]
30..37 'loop {}': !
35..37 '{}': ()
48..49 'i': i32
56..150 '{ ... }; }': ()
66..67 'x': &[i32]
70..147 'match ... }': &[i32]
76..77 'i': i32
88..89 '1': i32
88..89 '1': i32
93..97 '&[1]': &[i32; _]
94..97 '[1]': [i32; _]
95..96 '1': i32
107..108 '2': i32
107..108 '2': i32
112..115 'foo': fn foo<i32>(&[i32]) -> &[i32]
112..121 'foo(&[2])': &[i32]
116..120 '&[2]': &[i32; _]
117..120 '[2]': [i32; _]
118..119 '2': i32
131..132 '_': i32
136..140 '&[3]': &[i32; _]
137..140 '[3]': [i32; _]
138..139 '3': i32
"###
);
}
@ -353,24 +353,24 @@ fn test() {
}
"#),
@r###"
[11; 145) '{ ... }; }': ()
[21; 22) 't': &mut i32
[25; 31) '&mut 1': &mut i32
[30; 31) '1': i32
[41; 42) 'x': *const i32
[45; 142) 'match ... }': *const i32
[51; 52) '1': i32
[63; 64) '1': i32
[63; 64) '1': i32
[68; 69) 't': &mut i32
[68; 81) 't as *mut i32': *mut i32
[91; 92) '2': i32
[91; 92) '2': i32
[96; 97) 't': &mut i32
[96; 105) 't as &i32': &i32
[115; 116) '_': i32
[120; 121) 't': &mut i32
[120; 135) 't as *const i32': *const i32
11..145 '{ ... }; }': ()
21..22 't': &mut i32
25..31 '&mut 1': &mut i32
30..31 '1': i32
41..42 'x': *const i32
45..142 'match ... }': *const i32
51..52 '1': i32
63..64 '1': i32
63..64 '1': i32
68..69 't': &mut i32
68..81 't as *mut i32': *mut i32
91..92 '2': i32
91..92 '2': i32
96..97 't': &mut i32
96..105 't as &i32': &i32
115..116 '_': i32
120..121 't': &mut i32
120..135 't as *const i32': *const i32
"###
);
}
@ -384,9 +384,9 @@ fn foo() -> u32 {
}
"#, true),
@r###"
[17; 40) '{ ...own; }': !
[23; 37) 'return unknown': !
[30; 37) 'unknown': u32
17..40 '{ ...own; }': !
23..37 'return unknown': !
30..37 'unknown': u32
"###
);
}
@ -404,24 +404,24 @@ fn test() {
}
"#, true),
@r###"
[30; 31) 'x': &Foo
[39; 41) '{}': ()
[52; 133) '{ ...oo); }': ()
[58; 71) 'takes_ref_foo': fn takes_ref_foo(&Foo)
[58; 77) 'takes_...(&Foo)': ()
[72; 76) '&Foo': &Foo
[73; 76) 'Foo': Foo
[83; 96) 'takes_ref_foo': fn takes_ref_foo(&Foo)
[83; 103) 'takes_...&&Foo)': ()
[97; 102) '&&Foo': &&Foo
[98; 102) '&Foo': &Foo
[99; 102) 'Foo': Foo
[109; 122) 'takes_ref_foo': fn takes_ref_foo(&Foo)
[109; 130) 'takes_...&&Foo)': ()
[123; 129) '&&&Foo': &&&Foo
[124; 129) '&&Foo': &&Foo
[125; 129) '&Foo': &Foo
[126; 129) 'Foo': Foo
30..31 'x': &Foo
39..41 '{}': ()
52..133 '{ ...oo); }': ()
58..71 'takes_ref_foo': fn takes_ref_foo(&Foo)
58..77 'takes_...(&Foo)': ()
72..76 '&Foo': &Foo
73..76 'Foo': Foo
83..96 'takes_ref_foo': fn takes_ref_foo(&Foo)
83..103 'takes_...&&Foo)': ()
97..102 '&&Foo': &&Foo
98..102 '&Foo': &Foo
99..102 'Foo': Foo
109..122 'takes_ref_foo': fn takes_ref_foo(&Foo)
109..130 'takes_...&&Foo)': ()
123..129 '&&&Foo': &&&Foo
124..129 '&&Foo': &&Foo
125..129 '&Foo': &Foo
126..129 'Foo': Foo
"###
);
}
@ -439,26 +439,26 @@ fn test() {
}
"#, true),
@r###"
[29; 30) 'x': &T
[41; 47) '{ *x }': T
[43; 45) '*x': T
[44; 45) 'x': &T
[58; 127) '{ ...oo); }': ()
[64; 73) 'takes_ref': fn takes_ref<Foo>(&Foo) -> Foo
[64; 79) 'takes_ref(&Foo)': Foo
[74; 78) '&Foo': &Foo
[75; 78) 'Foo': Foo
[85; 94) 'takes_ref': fn takes_ref<&Foo>(&&Foo) -> &Foo
[85; 101) 'takes_...&&Foo)': &Foo
[95; 100) '&&Foo': &&Foo
[96; 100) '&Foo': &Foo
[97; 100) 'Foo': Foo
[107; 116) 'takes_ref': fn takes_ref<&&Foo>(&&&Foo) -> &&Foo
[107; 124) 'takes_...&&Foo)': &&Foo
[117; 123) '&&&Foo': &&&Foo
[118; 123) '&&Foo': &&Foo
[119; 123) '&Foo': &Foo
[120; 123) 'Foo': Foo
29..30 'x': &T
41..47 '{ *x }': T
43..45 '*x': T
44..45 'x': &T
58..127 '{ ...oo); }': ()
64..73 'takes_ref': fn takes_ref<Foo>(&Foo) -> Foo
64..79 'takes_ref(&Foo)': Foo
74..78 '&Foo': &Foo
75..78 'Foo': Foo
85..94 'takes_ref': fn takes_ref<&Foo>(&&Foo) -> &Foo
85..101 'takes_...&&Foo)': &Foo
95..100 '&&Foo': &&Foo
96..100 '&Foo': &Foo
97..100 'Foo': Foo
107..116 'takes_ref': fn takes_ref<&&Foo>(&&&Foo) -> &&Foo
107..124 'takes_...&&Foo)': &&Foo
117..123 '&&&Foo': &&&Foo
118..123 '&&Foo': &&Foo
119..123 '&Foo': &Foo
120..123 'Foo': Foo
"###
);
}
@ -478,18 +478,18 @@ fn test() {
}
"#, true),
@r###"
[127; 128) 'x': &str
[136; 138) '{}': ()
[169; 180) '{ loop {} }': String
[171; 178) 'loop {}': !
[176; 178) '{}': ()
[191; 236) '{ ... }); }': ()
[197; 210) 'takes_ref_str': fn takes_ref_str(&str)
[197; 233) 'takes_...g() })': ()
[211; 232) '&{ ret...ng() }': &String
[212; 232) '{ retu...ng() }': String
[214; 228) 'returns_string': fn returns_string() -> String
[214; 230) 'return...ring()': String
127..128 'x': &str
136..138 '{}': ()
169..180 '{ loop {} }': String
171..178 'loop {}': !
176..178 '{}': ()
191..236 '{ ... }); }': ()
197..210 'takes_ref_str': fn takes_ref_str(&str)
197..233 'takes_...g() })': ()
211..232 '&{ ret...ng() }': &String
212..232 '{ retu...ng() }': String
214..228 'returns_string': fn returns_string() -> String
214..230 'return...ring()': String
"###
);
}
@ -508,19 +508,19 @@ fn foo() {
}
"#, true),
@r###"
[10; 106) '{ ... }; }': ()
[20; 21) 'x': || -> &u32
[24; 103) '|| { ... }': || -> &u32
[27; 103) '{ ... }': &u32
[37; 82) 'if tru... }': ()
[40; 44) 'true': bool
[45; 82) '{ ... }': !
[59; 71) 'return &1u32': !
[66; 71) '&1u32': &u32
[67; 71) '1u32': u32
[91; 97) '&&1u32': &&u32
[92; 97) '&1u32': &u32
[93; 97) '1u32': u32
10..106 '{ ... }; }': ()
20..21 'x': || -> &u32
24..103 '|| { ... }': || -> &u32
27..103 '{ ... }': &u32
37..82 'if tru... }': ()
40..44 'true': bool
45..82 '{ ... }': !
59..71 'return &1u32': !
66..71 '&1u32': &u32
67..71 '1u32': u32
91..97 '&&1u32': &&u32
92..97 '&1u32': &u32
93..97 '1u32': u32
"###
);
}
@ -535,12 +535,12 @@ fn test() {
}
"#, true),
@r###"
[8; 9) 'x': u32
[25; 30) '{ 1 }': isize
[27; 28) '1': isize
[41; 79) '{ ...foo; }': ()
[51; 52) 'f': fn(u32) -> isize
[73; 76) 'foo': fn foo(u32) -> isize
8..9 'x': u32
25..30 '{ 1 }': isize
27..28 '1': isize
41..79 '{ ...foo; }': ()
51..52 'f': fn(u32) -> isize
73..76 'foo': fn foo(u32) -> isize
"###
);
}
@ -554,12 +554,12 @@ fn test() {
}
"#, true),
@r###"
[11; 55) '{ ...1 }; }': ()
[21; 22) 'f': fn(u32) -> isize
[43; 52) '|x| { 1 }': |u32| -> isize
[44; 45) 'x': u32
[47; 52) '{ 1 }': isize
[49; 50) '1': isize
11..55 '{ ...1 }; }': ()
21..22 'f': fn(u32) -> isize
43..52 '|x| { 1 }': |u32| -> isize
44..45 'x': u32
47..52 '{ 1 }': isize
49..50 '1': isize
"###
);
}
@ -577,11 +577,11 @@ impl<TT> S<TT> {
}
"#, true),
@r###"
[51; 55) 'self': &S<TT>
[64; 87) '{ ... }': &TT
[74; 81) '&self.t': &TT
[75; 79) 'self': &S<TT>
[75; 81) 'self.t': TT
51..55 'self': &S<TT>
64..87 '{ ... }': &TT
74..81 '&self.t': &TT
75..79 'self': &S<TT>
75..81 'self.t': TT
"###
);
}
@ -602,13 +602,13 @@ fn test() {
}
"#, true),
@r###"
[162; 199) '{ ... 3]; }': ()
[172; 173) 'f': &[usize]
[186; 196) '&[1, 2, 3]': &[usize; _]
[187; 196) '[1, 2, 3]': [usize; _]
[188; 189) '1': usize
[191; 192) '2': usize
[194; 195) '3': usize
162..199 '{ ... 3]; }': ()
172..173 'f': &[usize]
186..196 '&[1, 2, 3]': &[usize; _]
187..196 '[1, 2, 3]': [usize; _]
188..189 '1': usize
191..192 '2': usize
194..195 '3': usize
"###
);
}
@ -642,19 +642,19 @@ fn test() {
}
"#, true),
@r###"
[388; 573) '{ ...bj2; }': ()
[398; 401) 'obj': &dyn Baz<i8, i16>
[423; 425) '&S': &S<i8, i16>
[424; 425) 'S': S<i8, i16>
[435; 438) 'obj': &dyn Bar<usize, i8, i16>
[460; 463) 'obj': &dyn Baz<i8, i16>
[473; 476) 'obj': &dyn Foo<i8, usize>
[495; 498) 'obj': &dyn Bar<usize, i8, i16>
[508; 512) 'obj2': &dyn Baz<i8, i16>
[534; 536) '&S': &S<i8, i16>
[535; 536) 'S': S<i8, i16>
[546; 547) '_': &dyn Foo<i8, usize>
[566; 570) 'obj2': &dyn Baz<i8, i16>
388..573 '{ ...bj2; }': ()
398..401 'obj': &dyn Baz<i8, i16>
423..425 '&S': &S<i8, i16>
424..425 'S': S<i8, i16>
435..438 'obj': &dyn Bar<usize, i8, i16>
460..463 'obj': &dyn Baz<i8, i16>
473..476 'obj': &dyn Foo<i8, usize>
495..498 'obj': &dyn Bar<usize, i8, i16>
508..512 'obj2': &dyn Baz<i8, i16>
534..536 '&S': &S<i8, i16>
535..536 'S': S<i8, i16>
546..547 '_': &dyn Foo<i8, usize>
566..570 'obj2': &dyn Baz<i8, i16>
"###
);
}
@ -687,12 +687,12 @@ fn test() {
}
"#, true),
@r###"
[292; 348) '{ ...obj; }': ()
[302; 305) 'obj': &dyn D
[316; 318) '&S': &S
[317; 318) 'S': S
[328; 331) 'obj': &dyn A
[342; 345) 'obj': &dyn D
292..348 '{ ...obj; }': ()
302..305 'obj': &dyn D
316..318 '&S': &S
317..318 'S': S
328..331 'obj': &dyn A
342..345 'obj': &dyn D
"###
);
}

View file

@ -67,12 +67,12 @@ fn main() {
}
"#),
@r###"
![0; 17) '{Foo(v...,2,])}': Foo
![1; 4) 'Foo': Foo({unknown}) -> Foo
![1; 16) 'Foo(vec![1,2,])': Foo
![5; 15) 'vec![1,2,]': {unknown}
[156; 182) '{ ...,2); }': ()
[166; 167) 'x': Foo
!0..17 '{Foo(v...,2,])}': Foo
!1..4 'Foo': Foo({unknown}) -> Foo
!1..16 'Foo(vec![1,2,])': Foo
!5..15 'vec![1,2,]': {unknown}
156..182 '{ ...,2); }': ()
166..167 'x': Foo
"###
);
}
@ -100,14 +100,14 @@ fn main() {
}
"#),
@r###"
![0; 17) '{Foo(v...,2,])}': Foo
![1; 4) 'Foo': Foo({unknown}) -> Foo
![1; 16) 'Foo(vec![1,2,])': Foo
![5; 15) 'vec![1,2,]': {unknown}
[195; 251) '{ ...,2); }': ()
[205; 206) 'x': Foo
[228; 229) 'y': {unknown}
[232; 248) 'crate:...!(1,2)': {unknown}
!0..17 '{Foo(v...,2,])}': Foo
!1..4 'Foo': Foo({unknown}) -> Foo
!1..16 'Foo(vec![1,2,])': Foo
!5..15 'vec![1,2,]': {unknown}
195..251 '{ ...,2); }': ()
205..206 'x': Foo
228..229 'y': {unknown}
232..248 'crate:...!(1,2)': {unknown}
"###
);
}
@ -131,11 +131,11 @@ fn main() {
}
"#),
@r###"
![0; 5) '42i32': i32
![0; 5) '42i32': i32
[111; 164) '{ ...!(); }': ()
[121; 122) 'x': i32
[148; 149) 'y': i32
!0..5 '42i32': i32
!0..5 '42i32': i32
111..164 '{ ...!(); }': ()
121..122 'x': i32
148..149 'y': i32
"###
);
}
@ -172,51 +172,51 @@ fn spam() {
}
"#),
@r###"
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
![0; 6) '1isize': isize
[54; 457) '{ ...!(); }': !
[88; 109) 'spam!(...am!())': {unknown}
[115; 134) 'for _ ...!() {}': ()
[119; 120) '_': {unknown}
[132; 134) '{}': ()
[139; 149) '|| spam!()': || -> isize
[155; 171) 'while ...!() {}': ()
[169; 171) '{}': ()
[176; 189) 'break spam!()': !
[195; 209) 'return spam!()': !
[215; 269) 'match ... }': isize
[239; 240) '_': isize
[274; 290) 'spam!(...am!())': {unknown}
[296; 318) 'Spam {...m!() }': {unknown}
[324; 340) 'spam!(...am!()]': {unknown}
[365; 381) 'spam!(... usize': usize
[387; 395) '&spam!()': &isize
[401; 409) '-spam!()': isize
[415; 431) 'spam!(...pam!()': {unknown}
[437; 454) 'spam!(...pam!()': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
!0..6 '1isize': isize
54..457 '{ ...!(); }': !
88..109 'spam!(...am!())': {unknown}
115..134 'for _ ...!() {}': ()
119..120 '_': {unknown}
132..134 '{}': ()
139..149 '|| spam!()': || -> isize
155..171 'while ...!() {}': ()
169..171 '{}': ()
176..189 'break spam!()': !
195..209 'return spam!()': !
215..269 'match ... }': isize
239..240 '_': isize
274..290 'spam!(...am!())': {unknown}
296..318 'Spam {...m!() }': {unknown}
324..340 'spam!(...am!()]': {unknown}
365..381 'spam!(... usize': usize
387..395 '&spam!()': &isize
401..409 '-spam!()': isize
415..431 'spam!(...pam!()': {unknown}
437..454 'spam!(...pam!()': isize
"###
);
}
@ -244,9 +244,9 @@ fn foo() {
}
"#),
@r###"
![0; 5) '42i32': i32
[171; 206) '{ ...32); }': ()
[181; 184) 'foo': i32
!0..5 '42i32': i32
171..206 '{ ...32); }': ()
181..184 'foo': i32
"###
);
}
@ -357,12 +357,12 @@ fn main() {
}
"#),
@r###"
[159; 164) '{ 0 }': u64
[161; 162) '0': u64
[175; 197) '{ ...f(); }': ()
[185; 187) '_a': u64
[191; 192) 'f': fn f() -> u64
[191; 194) 'f()': u64
159..164 '{ 0 }': u64
161..162 '0': u64
175..197 '{ ...f(); }': ()
185..187 '_a': u64
191..192 'f': fn f() -> u64
191..194 'f()': u64
"###
);
}
@ -379,10 +379,10 @@ fn main() {
}
"#),
@r###"
![0; 6) '1usize': usize
[11; 90) '{ ...!(); }': ()
[17; 66) 'macro_... }': {unknown}
[75; 77) '_a': usize
!0..6 '1usize': usize
11..90 '{ ...!(); }': ()
17..66 'macro_... }': {unknown}
75..77 '_a': usize
"###
);
}
@ -399,9 +399,9 @@ fn main() {
}
"#),
@r###"
![0; 1) '0': i32
[64; 88) '{ ...!(); }': ()
[74; 75) 'x': i32
!0..1 '0': i32
64..88 '{ ...!(); }': ()
74..75 'x': i32
"###
);
}
@ -418,9 +418,9 @@ fn main() {
}
"#),
@r###"
![0; 2) '""': &str
[64; 88) '{ ...!(); }': ()
[74; 75) 'x': &str
!0..2 '""': &str
64..88 '{ ...!(); }': ()
74..75 'x': &str
"###
);
}
@ -437,9 +437,9 @@ fn main() {
}
"#),
@r###"
![0; 1) '0': i32
[66; 92) '{ ...!(); }': ()
[76; 77) 'x': i32
!0..1 '0': i32
66..92 '{ ...!(); }': ()
76..77 'x': i32
"###
);
}
@ -456,9 +456,9 @@ fn main() {
}
"#),
@r###"
![0; 13) '"helloworld!"': &str
[66; 122) '{ ...")); }': ()
[76; 77) 'x': &str
!0..13 '"helloworld!"': &str
66..122 '{ ...")); }': ()
76..77 'x': &str
"###
);
}
@ -591,9 +591,9 @@ fn main() {
}
"#),
@r###"
![0; 13) '"helloworld!"': &str
[104; 161) '{ ...")); }': ()
[114; 115) 'x': &str
!0..13 '"helloworld!"': &str
104..161 '{ ...")); }': ()
114..115 'x': &str
"###
);
}
@ -611,9 +611,9 @@ fn main() {
}
"#),
@r###"
![0; 5) '"bar"': &str
[88; 116) '{ ...o"); }': ()
[98; 99) 'x': &str
!0..5 '"bar"': &str
88..116 '{ ...o"); }': ()
98..99 'x': &str
"###
);
}
@ -703,12 +703,12 @@ fn main() {
}
"#),
@r###"
[52; 111) '{ ... }; }': ()
[62; 63) 'x': u32
[66; 108) 'match ... }': u32
[72; 74) '()': ()
[85; 92) 'unit!()': ()
[96; 101) '92u32': u32
52..111 '{ ... }; }': ()
62..63 'x': u32
66..108 'match ... }': u32
72..74 '()': ()
85..92 'unit!()': ()
96..101 '92u32': u32
"###
);
}

View file

@ -22,14 +22,14 @@ fn test() {
}
"#),
@r###"
[45; 49) 'self': &[T]
[56; 79) '{ ... }': T
[66; 73) 'loop {}': !
[71; 73) '{}': ()
[133; 160) '{ ...o"); }': ()
[139; 149) '<[_]>::foo': fn foo<u8>(&[u8]) -> u8
[139; 157) '<[_]>:..."foo")': u8
[150; 156) 'b"foo"': &[u8]
45..49 'self': &[T]
56..79 '{ ... }': T
66..73 'loop {}': !
71..73 '{}': ()
133..160 '{ ...o"); }': ()
139..149 '<[_]>::foo': fn foo<u8>(&[u8]) -> u8
139..157 '<[_]>:..."foo")': u8
150..156 'b"foo"': &[u8]
"###
);
}
@ -51,15 +51,15 @@ fn test() {
}
"#),
@r###"
[49; 75) '{ ... }': A
[59; 69) 'A { x: 0 }': A
[66; 67) '0': u32
[88; 122) '{ ...a.x; }': ()
[98; 99) 'a': A
[102; 108) 'A::new': fn new() -> A
[102; 110) 'A::new()': A
[116; 117) 'a': A
[116; 119) 'a.x': u32
49..75 '{ ... }': A
59..69 'A { x: 0 }': A
66..67 '0': u32
88..122 '{ ...a.x; }': ()
98..99 'a': A
102..108 'A::new': fn new() -> A
102..110 'A::new()': A
116..117 'a': A
116..119 'a.x': u32
"###
);
}
@ -86,19 +86,19 @@ fn test() {
}
"#),
@r###"
[47; 67) '{ ... }': A
[57; 61) 'A::B': A
[88; 108) '{ ... }': A
[98; 102) 'A::C': A
[121; 178) '{ ... c; }': ()
[131; 132) 'a': A
[135; 139) 'A::b': fn b() -> A
[135; 141) 'A::b()': A
[147; 148) 'a': A
[158; 159) 'c': A
[162; 166) 'A::c': fn c() -> A
[162; 168) 'A::c()': A
[174; 175) 'c': A
47..67 '{ ... }': A
57..61 'A::B': A
88..108 '{ ... }': A
98..102 'A::C': A
121..178 '{ ... c; }': ()
131..132 'a': A
135..139 'A::b': fn b() -> A
135..141 'A::b()': A
147..148 'a': A
158..159 'c': A
162..166 'A::c': fn c() -> A
162..168 'A::c()': A
174..175 'c': A
"###
);
}
@ -130,22 +130,22 @@ fn test() {
}
"#),
@r###"
[56; 64) '{ A {} }': A
[58; 62) 'A {}': A
[126; 132) '{ 99 }': u32
[128; 130) '99': u32
[202; 210) '{ C {} }': C
[204; 208) 'C {}': C
[241; 325) '{ ...g(); }': ()
[251; 252) 'x': A
[255; 266) 'a::A::thing': fn thing() -> A
[255; 268) 'a::A::thing()': A
[278; 279) 'y': u32
[282; 293) 'b::B::thing': fn thing() -> u32
[282; 295) 'b::B::thing()': u32
[305; 306) 'z': C
[309; 320) 'c::C::thing': fn thing() -> C
[309; 322) 'c::C::thing()': C
56..64 '{ A {} }': A
58..62 'A {}': A
126..132 '{ 99 }': u32
128..130 '99': u32
202..210 '{ C {} }': C
204..208 'C {}': C
241..325 '{ ...g(); }': ()
251..252 'x': A
255..266 'a::A::thing': fn thing() -> A
255..268 'a::A::thing()': A
278..279 'y': u32
282..293 'b::B::thing': fn thing() -> u32
282..295 'b::B::thing()': u32
305..306 'z': C
309..320 'c::C::thing': fn thing() -> C
309..322 'c::C::thing()': C
"###
);
}
@ -169,15 +169,15 @@ fn test() {
}
"#),
@r###"
[64; 67) 'val': T
[82; 109) '{ ... }': Gen<T>
[92; 103) 'Gen { val }': Gen<T>
[98; 101) 'val': T
[123; 155) '{ ...32); }': ()
[133; 134) 'a': Gen<u32>
[137; 146) 'Gen::make': fn make<u32>(u32) -> Gen<u32>
[137; 152) 'Gen::make(0u32)': Gen<u32>
[147; 151) '0u32': u32
64..67 'val': T
82..109 '{ ... }': Gen<T>
92..103 'Gen { val }': Gen<T>
98..101 'val': T
123..155 '{ ...32); }': ()
133..134 'a': Gen<u32>
137..146 'Gen::make': fn make<u32>(u32) -> Gen<u32>
137..152 'Gen::make(0u32)': Gen<u32>
147..151 '0u32': u32
"###
);
}
@ -201,13 +201,13 @@ fn test() {
}
"#),
@r###"
[80; 104) '{ ... }': Gen<T>
[90; 98) 'loop { }': !
[95; 98) '{ }': ()
[118; 146) '{ ...e(); }': ()
[128; 129) 'a': Gen<u32>
[132; 141) 'Gen::make': fn make<u32>() -> Gen<u32>
[132; 143) 'Gen::make()': Gen<u32>
80..104 '{ ... }': Gen<T>
90..98 'loop { }': !
95..98 '{ }': ()
118..146 '{ ...e(); }': ()
128..129 'a': Gen<u32>
132..141 'Gen::make': fn make<u32>() -> Gen<u32>
132..143 'Gen::make()': Gen<u32>
"###
);
}
@ -255,13 +255,13 @@ fn test() {
}
"#),
@r###"
[76; 100) '{ ... }': Gen<T>
[86; 94) 'loop { }': !
[91; 94) '{ }': ()
[114; 149) '{ ...e(); }': ()
[124; 125) 'a': Gen<u32>
[128; 144) 'Gen::<...::make': fn make<u32>() -> Gen<u32>
[128; 146) 'Gen::<...make()': Gen<u32>
76..100 '{ ... }': Gen<T>
86..94 'loop { }': !
91..94 '{ }': ()
114..149 '{ ...e(); }': ()
124..125 'a': Gen<u32>
128..144 'Gen::<...::make': fn make<u32>() -> Gen<u32>
128..146 'Gen::<...make()': Gen<u32>
"###
);
}
@ -286,13 +286,13 @@ fn test() {
}
"#),
@r###"
[102; 126) '{ ... }': Gen<u32, T>
[112; 120) 'loop { }': !
[117; 120) '{ }': ()
[140; 180) '{ ...e(); }': ()
[150; 151) 'a': Gen<u32, u64>
[154; 175) 'Gen::<...::make': fn make<u64>() -> Gen<u32, u64>
[154; 177) 'Gen::<...make()': Gen<u32, u64>
102..126 '{ ... }': Gen<u32, T>
112..120 'loop { }': !
117..120 '{ }': ()
140..180 '{ ...e(); }': ()
150..151 'a': Gen<u32, u64>
154..175 'Gen::<...::make': fn make<u64>() -> Gen<u32, u64>
154..177 'Gen::<...make()': Gen<u32, u64>
"###
);
}
@ -340,13 +340,13 @@ fn test() {
}
"#),
@r###"
[31; 35) 'self': &Self
[110; 114) 'self': &Self
[170; 228) '{ ...i128 }': ()
[176; 178) 'S1': S1
[176; 187) 'S1.method()': u32
[203; 205) 'S2': S2
[203; 214) 'S2.method()': i128
31..35 'self': &Self
110..114 'self': &Self
170..228 '{ ...i128 }': ()
176..178 'S1': S1
176..187 'S1.method()': u32
203..205 'S2': S2
203..214 'S2.method()': i128
"###
);
}
@ -387,14 +387,14 @@ mod bar_test {
}
"#),
@r###"
[63; 67) 'self': &Self
[169; 173) 'self': &Self
[300; 337) '{ ... }': ()
[310; 311) 'S': S
[310; 320) 'S.method()': u32
[416; 454) '{ ... }': ()
[426; 427) 'S': S
[426; 436) 'S.method()': i128
63..67 'self': &Self
169..173 'self': &Self
300..337 '{ ... }': ()
310..311 'S': S
310..320 'S.method()': u32
416..454 '{ ... }': ()
426..427 'S': S
426..436 'S.method()': i128
"###
);
}
@ -414,10 +414,10 @@ fn test() {
}
"#),
@r###"
[33; 37) 'self': &Self
[92; 111) '{ ...d(); }': ()
[98; 99) 'S': S
[98; 108) 'S.method()': u32
33..37 'self': &Self
92..111 '{ ...d(); }': ()
98..99 'S': S
98..108 'S.method()': u32
"###
);
}
@ -443,17 +443,17 @@ fn test() {
}
"#),
@r###"
[43; 47) 'self': &Self
[82; 86) 'self': &Self
[210; 361) '{ ..., i8 }': ()
[216; 218) 'S1': S1
[216; 228) 'S1.method1()': (u8, u16, u32)
[250; 252) 'S1': S1
[250; 262) 'S1.method2()': (u32, u16, u8)
[284; 286) 'S2': S2
[284; 296) 'S2.method1()': (i8, i16, {unknown})
[324; 326) 'S2': S2
[324; 336) 'S2.method2()': ({unknown}, i16, i8)
43..47 'self': &Self
82..86 'self': &Self
210..361 '{ ..., i8 }': ()
216..218 'S1': S1
216..228 'S1.method1()': (u8, u16, u32)
250..252 'S1': S1
250..262 'S1.method2()': (u32, u16, u8)
284..286 'S2': S2
284..296 'S2.method1()': (i8, i16, {unknown})
324..326 'S2': S2
324..336 'S2.method2()': ({unknown}, i16, i8)
"###
);
}
@ -473,12 +473,12 @@ fn test() {
}
"#),
@r###"
[33; 37) 'self': &Self
[102; 127) '{ ...d(); }': ()
[108; 109) 'S': S<u32>(u32) -> S<u32>
[108; 115) 'S(1u32)': S<u32>
[108; 124) 'S(1u32...thod()': u32
[110; 114) '1u32': u32
33..37 'self': &Self
102..127 '{ ...d(); }': ()
108..109 'S': S<u32>(u32) -> S<u32>
108..115 'S(1u32)': S<u32>
108..124 'S(1u32...thod()': u32
110..114 '1u32': u32
"###
);
}
@ -499,16 +499,16 @@ fn test() {
}
"#),
@r###"
[87; 193) '{ ...t(); }': ()
[97; 99) 's1': S
[105; 121) 'Defaul...efault': fn default<S>() -> S
[105; 123) 'Defaul...ault()': S
[133; 135) 's2': S
[138; 148) 'S::default': fn default<S>() -> S
[138; 150) 'S::default()': S
[160; 162) 's3': S
[165; 188) '<S as ...efault': fn default<S>() -> S
[165; 190) '<S as ...ault()': S
87..193 '{ ...t(); }': ()
97..99 's1': S
105..121 'Defaul...efault': fn default<S>() -> S
105..123 'Defaul...ault()': S
133..135 's2': S
138..148 'S::default': fn default<S>() -> S
138..150 'S::default()': S
160..162 's3': S
165..188 '<S as ...efault': fn default<S>() -> S
165..190 '<S as ...ault()': S
"###
);
}
@ -531,16 +531,16 @@ fn test() {
}
"#),
@r###"
[127; 211) '{ ...e(); }': ()
[137; 138) 'a': u32
[141; 148) 'S::make': fn make<S, u32>() -> u32
[141; 150) 'S::make()': u32
[160; 161) 'b': u64
[164; 178) 'G::<u64>::make': fn make<G<u64>, u64>() -> u64
[164; 180) 'G::<u6...make()': u64
[190; 191) 'c': f64
[199; 206) 'G::make': fn make<G<f64>, f64>() -> f64
[199; 208) 'G::make()': f64
127..211 '{ ...e(); }': ()
137..138 'a': u32
141..148 'S::make': fn make<S, u32>() -> u32
141..150 'S::make()': u32
160..161 'b': u64
164..178 'G::<u64>::make': fn make<G<u64>, u64>() -> u64
164..180 'G::<u6...make()': u64
190..191 'c': f64
199..206 'G::make': fn make<G<f64>, f64>() -> f64
199..208 'G::make()': f64
"###
);
}
@ -565,22 +565,22 @@ fn test() {
}
"#),
@r###"
[135; 313) '{ ...e(); }': ()
[145; 146) 'a': (u32, i64)
[149; 163) 'S::make::<i64>': fn make<S, u32, i64>() -> (u32, i64)
[149; 165) 'S::mak...i64>()': (u32, i64)
[175; 176) 'b': (u32, i64)
[189; 196) 'S::make': fn make<S, u32, i64>() -> (u32, i64)
[189; 198) 'S::make()': (u32, i64)
[208; 209) 'c': (u32, i64)
[212; 233) 'G::<u3...:<i64>': fn make<G<u32>, u32, i64>() -> (u32, i64)
[212; 235) 'G::<u3...i64>()': (u32, i64)
[245; 246) 'd': (u32, i64)
[259; 273) 'G::make::<i64>': fn make<G<u32>, u32, i64>() -> (u32, i64)
[259; 275) 'G::mak...i64>()': (u32, i64)
[285; 286) 'e': (u32, i64)
[301; 308) 'G::make': fn make<G<u32>, u32, i64>() -> (u32, i64)
[301; 310) 'G::make()': (u32, i64)
135..313 '{ ...e(); }': ()
145..146 'a': (u32, i64)
149..163 'S::make::<i64>': fn make<S, u32, i64>() -> (u32, i64)
149..165 'S::mak...i64>()': (u32, i64)
175..176 'b': (u32, i64)
189..196 'S::make': fn make<S, u32, i64>() -> (u32, i64)
189..198 'S::make()': (u32, i64)
208..209 'c': (u32, i64)
212..233 'G::<u3...:<i64>': fn make<G<u32>, u32, i64>() -> (u32, i64)
212..235 'G::<u3...i64>()': (u32, i64)
245..246 'd': (u32, i64)
259..273 'G::make::<i64>': fn make<G<u32>, u32, i64>() -> (u32, i64)
259..275 'G::mak...i64>()': (u32, i64)
285..286 'e': (u32, i64)
301..308 'G::make': fn make<G<u32>, u32, i64>() -> (u32, i64)
301..310 'G::make()': (u32, i64)
"###
);
}
@ -599,10 +599,10 @@ fn test() {
}
"#),
@r###"
[101; 127) '{ ...e(); }': ()
[111; 112) 'a': (S<i32>, i64)
[115; 122) 'S::make': fn make<S<i32>, i64>() -> (S<i32>, i64)
[115; 124) 'S::make()': (S<i32>, i64)
101..127 '{ ...e(); }': ()
111..112 'a': (S<i32>, i64)
115..122 'S::make': fn make<S<i32>, i64>() -> (S<i32>, i64)
115..124 'S::make()': (S<i32>, i64)
"###
);
}
@ -623,13 +623,13 @@ fn test() {
}
"#),
@r###"
[131; 203) '{ ...e(); }': ()
[141; 142) 'a': (S<u64>, i64)
[158; 165) 'S::make': fn make<S<u64>, i64>() -> (S<u64>, i64)
[158; 167) 'S::make()': (S<u64>, i64)
[177; 178) 'b': (S<u32>, i32)
[191; 198) 'S::make': fn make<S<u32>, i32>() -> (S<u32>, i32)
[191; 200) 'S::make()': (S<u32>, i32)
131..203 '{ ...e(); }': ()
141..142 'a': (S<u64>, i64)
158..165 'S::make': fn make<S<u64>, i64>() -> (S<u64>, i64)
158..167 'S::make()': (S<u64>, i64)
177..178 'b': (S<u32>, i32)
191..198 'S::make': fn make<S<u32>, i32>() -> (S<u32>, i32)
191..200 'S::make()': (S<u32>, i32)
"###
);
}
@ -649,13 +649,13 @@ fn test() {
}
"#),
@r###"
[107; 211) '{ ...>(); }': ()
[117; 118) 'a': (S<u64>, i64, u8)
[121; 150) '<S as ...::<u8>': fn make<S<u64>, i64, u8>() -> (S<u64>, i64, u8)
[121; 152) '<S as ...<u8>()': (S<u64>, i64, u8)
[162; 163) 'b': (S<u64>, i64, u8)
[182; 206) 'Trait:...::<u8>': fn make<S<u64>, i64, u8>() -> (S<u64>, i64, u8)
[182; 208) 'Trait:...<u8>()': (S<u64>, i64, u8)
107..211 '{ ...>(); }': ()
117..118 'a': (S<u64>, i64, u8)
121..150 '<S as ...::<u8>': fn make<S<u64>, i64, u8>() -> (S<u64>, i64, u8)
121..152 '<S as ...<u8>()': (S<u64>, i64, u8)
162..163 'b': (S<u64>, i64, u8)
182..206 'Trait:...::<u8>': fn make<S<u64>, i64, u8>() -> (S<u64>, i64, u8)
182..208 'Trait:...<u8>()': (S<u64>, i64, u8)
"###
);
}
@ -672,11 +672,11 @@ fn test<T: Trait>(t: T) {
}
"#),
@r###"
[30; 34) 'self': &Self
[64; 65) 't': T
[70; 89) '{ ...d(); }': ()
[76; 77) 't': T
[76; 86) 't.method()': u32
30..34 'self': &Self
64..65 't': T
70..89 '{ ...d(); }': ()
76..77 't': T
76..86 't.method()': u32
"###
);
}
@ -693,11 +693,11 @@ fn test<U, T: Trait<U>>(t: T) {
}
"#),
@r###"
[33; 37) 'self': &Self
[71; 72) 't': T
[77; 96) '{ ...d(); }': ()
[83; 84) 't': T
[83; 93) 't.method()': U
33..37 'self': &Self
71..72 't': T
77..96 '{ ...d(); }': ()
83..84 't': T
83..93 't.method()': U
"###
);
}
@ -719,18 +719,18 @@ fn test() {
}
"#),
@r###"
[29; 33) 'self': Self
[111; 202) '{ ...(S); }': ()
[121; 122) 'x': u32
[130; 131) 'S': S
[130; 138) 'S.into()': u32
[148; 149) 'y': u64
[157; 158) 'S': S
[157; 165) 'S.into()': u64
[175; 176) 'z': u64
[179; 196) 'Into::...::into': fn into<S, u64>(S) -> u64
[179; 199) 'Into::...nto(S)': u64
[197; 198) 'S': S
29..33 'self': Self
111..202 '{ ...(S); }': ()
121..122 'x': u32
130..131 'S': S
130..138 'S.into()': u32
148..149 'y': u64
157..158 'S': S
157..165 'S.into()': u64
175..176 'z': u64
179..196 'Into::...::into': fn into<S, u64>(S) -> u64
179..199 'Into::...nto(S)': u64
197..198 'S': S
"###
);
}

View file

@ -30,54 +30,54 @@ fn test(x: &i32) {
}
"#),
@r###"
[9; 10) 'x': &i32
[18; 369) '{ ...o_x; }': ()
[28; 29) 'y': &i32
[32; 33) 'x': &i32
[43; 45) '&z': &i32
[44; 45) 'z': i32
[48; 49) 'x': &i32
[59; 60) 'a': i32
[63; 64) 'z': i32
[74; 80) '(c, d)': (i32, &str)
[75; 76) 'c': i32
[78; 79) 'd': &str
[83; 95) '(1, "hello")': (i32, &str)
[84; 85) '1': i32
[87; 94) '"hello"': &str
[102; 152) 'for (e... }': ()
[106; 112) '(e, f)': ({unknown}, {unknown})
[107; 108) 'e': {unknown}
[110; 111) 'f': {unknown}
[116; 125) 'some_iter': {unknown}
[126; 152) '{ ... }': ()
[140; 141) 'g': {unknown}
[144; 145) 'e': {unknown}
[158; 205) 'if let... }': ()
[165; 170) '[val]': [{unknown}]
[166; 169) 'val': {unknown}
[173; 176) 'opt': [{unknown}]
[177; 205) '{ ... }': ()
[191; 192) 'h': {unknown}
[195; 198) 'val': {unknown}
[215; 221) 'lambda': |u64, u64, i32| -> i32
[224; 256) '|a: u6...b; c }': |u64, u64, i32| -> i32
[225; 226) 'a': u64
[233; 234) 'b': u64
[236; 237) 'c': i32
[244; 256) '{ a + b; c }': i32
[246; 247) 'a': u64
[246; 251) 'a + b': u64
[250; 251) 'b': u64
[253; 254) 'c': i32
[267; 279) 'ref ref_to_x': &&i32
[282; 283) 'x': &i32
[293; 302) 'mut mut_x': &i32
[305; 306) 'x': &i32
[316; 336) 'ref mu...f_to_x': &mut &i32
[339; 340) 'x': &i32
[350; 351) 'k': &mut &i32
[354; 366) 'mut_ref_to_x': &mut &i32
9..10 'x': &i32
18..369 '{ ...o_x; }': ()
28..29 'y': &i32
32..33 'x': &i32
43..45 '&z': &i32
44..45 'z': i32
48..49 'x': &i32
59..60 'a': i32
63..64 'z': i32
74..80 '(c, d)': (i32, &str)
75..76 'c': i32
78..79 'd': &str
83..95 '(1, "hello")': (i32, &str)
84..85 '1': i32
87..94 '"hello"': &str
102..152 'for (e... }': ()
106..112 '(e, f)': ({unknown}, {unknown})
107..108 'e': {unknown}
110..111 'f': {unknown}
116..125 'some_iter': {unknown}
126..152 '{ ... }': ()
140..141 'g': {unknown}
144..145 'e': {unknown}
158..205 'if let... }': ()
165..170 '[val]': [{unknown}]
166..169 'val': {unknown}
173..176 'opt': [{unknown}]
177..205 '{ ... }': ()
191..192 'h': {unknown}
195..198 'val': {unknown}
215..221 'lambda': |u64, u64, i32| -> i32
224..256 '|a: u6...b; c }': |u64, u64, i32| -> i32
225..226 'a': u64
233..234 'b': u64
236..237 'c': i32
244..256 '{ a + b; c }': i32
246..247 'a': u64
246..251 'a + b': u64
250..251 'b': u64
253..254 'c': i32
267..279 'ref ref_to_x': &&i32
282..283 'x': &i32
293..302 'mut mut_x': &i32
305..306 'x': &i32
316..336 'ref mu...f_to_x': &mut &i32
339..340 'x': &i32
350..351 'k': &mut &i32
354..366 'mut_ref_to_x': &mut &i32
"###
);
}
@ -97,47 +97,47 @@ fn test(x: &i32) {
}
"#, true),
@r###"
[18; 29) '{ loop {} }': T
[20; 27) 'loop {}': !
[25; 27) '{}': ()
[38; 39) 'x': &i32
[47; 209) '{ ...) {} }': ()
[53; 76) 'if let...y() {}': ()
[60; 65) '"foo"': &str
[60; 65) '"foo"': &str
[68; 71) 'any': fn any<&str>() -> &str
[68; 73) 'any()': &str
[74; 76) '{}': ()
[81; 100) 'if let...y() {}': ()
[88; 89) '1': i32
[88; 89) '1': i32
[92; 95) 'any': fn any<i32>() -> i32
[92; 97) 'any()': i32
[98; 100) '{}': ()
[105; 127) 'if let...y() {}': ()
[112; 116) '1u32': u32
[112; 116) '1u32': u32
[119; 122) 'any': fn any<u32>() -> u32
[119; 124) 'any()': u32
[125; 127) '{}': ()
[132; 154) 'if let...y() {}': ()
[139; 143) '1f32': f32
[139; 143) '1f32': f32
[146; 149) 'any': fn any<f32>() -> f32
[146; 151) 'any()': f32
[152; 154) '{}': ()
[159; 180) 'if let...y() {}': ()
[166; 169) '1.0': f64
[166; 169) '1.0': f64
[172; 175) 'any': fn any<f64>() -> f64
[172; 177) 'any()': f64
[178; 180) '{}': ()
[185; 207) 'if let...y() {}': ()
[192; 196) 'true': bool
[192; 196) 'true': bool
[199; 202) 'any': fn any<bool>() -> bool
[199; 204) 'any()': bool
[205; 207) '{}': ()
18..29 '{ loop {} }': T
20..27 'loop {}': !
25..27 '{}': ()
38..39 'x': &i32
47..209 '{ ...) {} }': ()
53..76 'if let...y() {}': ()
60..65 '"foo"': &str
60..65 '"foo"': &str
68..71 'any': fn any<&str>() -> &str
68..73 'any()': &str
74..76 '{}': ()
81..100 'if let...y() {}': ()
88..89 '1': i32
88..89 '1': i32
92..95 'any': fn any<i32>() -> i32
92..97 'any()': i32
98..100 '{}': ()
105..127 'if let...y() {}': ()
112..116 '1u32': u32
112..116 '1u32': u32
119..122 'any': fn any<u32>() -> u32
119..124 'any()': u32
125..127 '{}': ()
132..154 'if let...y() {}': ()
139..143 '1f32': f32
139..143 '1f32': f32
146..149 'any': fn any<f32>() -> f32
146..151 'any()': f32
152..154 '{}': ()
159..180 'if let...y() {}': ()
166..169 '1.0': f64
166..169 '1.0': f64
172..175 'any': fn any<f64>() -> f64
172..177 'any()': f64
178..180 '{}': ()
185..207 'if let...y() {}': ()
192..196 'true': bool
192..196 'true': bool
199..202 'any': fn any<bool>() -> bool
199..204 'any()': bool
205..207 '{}': ()
"###
);
}
@ -152,16 +152,16 @@ fn test(x: &i32) {
}
"#, true),
@r###"
[9; 10) 'x': &i32
[18; 76) '{ ...2 {} }': ()
[24; 46) 'if let...u32 {}': ()
[31; 36) '1..76': u32
[39; 43) '2u32': u32
[44; 46) '{}': ()
[51; 74) 'if let...u32 {}': ()
[58; 64) '1..=76': u32
[67; 71) '2u32': u32
[72; 74) '{}': ()
9..10 'x': &i32
18..76 '{ ...2 {} }': ()
24..46 'if let...u32 {}': ()
31..36 '1..76': u32
39..43 '2u32': u32
44..46 '{}': ()
51..74 'if let...u32 {}': ()
58..64 '1..=76': u32
67..71 '2u32': u32
72..74 '{}': ()
"###
);
}
@ -178,19 +178,19 @@ fn test() {
}
"#),
@r###"
[28; 79) '{ ...(1); }': ()
[38; 42) 'A(n)': A<i32>
[40; 41) 'n': &i32
[45; 50) '&A(1)': &A<i32>
[46; 47) 'A': A<i32>(i32) -> A<i32>
[46; 50) 'A(1)': A<i32>
[48; 49) '1': i32
[60; 64) 'A(n)': A<i32>
[62; 63) 'n': &mut i32
[67; 76) '&mut A(1)': &mut A<i32>
[72; 73) 'A': A<i32>(i32) -> A<i32>
[72; 76) 'A(1)': A<i32>
[74; 75) '1': i32
28..79 '{ ...(1); }': ()
38..42 'A(n)': A<i32>
40..41 'n': &i32
45..50 '&A(1)': &A<i32>
46..47 'A': A<i32>(i32) -> A<i32>
46..50 'A(1)': A<i32>
48..49 '1': i32
60..64 'A(n)': A<i32>
62..63 'n': &mut i32
67..76 '&mut A(1)': &mut A<i32>
72..73 'A': A<i32>(i32) -> A<i32>
72..76 'A(1)': A<i32>
74..75 '1': i32
"###
);
}
@ -206,18 +206,18 @@ fn test() {
}
"#),
@r###"
[11; 57) '{ ...= v; }': ()
[21; 22) 'v': &(i32, &i32)
[25; 33) '&(1, &2)': &(i32, &i32)
[26; 33) '(1, &2)': (i32, &i32)
[27; 28) '1': i32
[30; 32) '&2': &i32
[31; 32) '2': i32
[43; 50) '(_, &w)': (i32, &i32)
[44; 45) '_': i32
[47; 49) '&w': &i32
[48; 49) 'w': i32
[53; 54) 'v': &(i32, &i32)
11..57 '{ ...= v; }': ()
21..22 'v': &(i32, &i32)
25..33 '&(1, &2)': &(i32, &i32)
26..33 '(1, &2)': (i32, &i32)
27..28 '1': i32
30..32 '&2': &i32
31..32 '2': i32
43..50 '(_, &w)': (i32, &i32)
44..45 '_': i32
47..49 '&w': &i32
48..49 'w': i32
53..54 'v': &(i32, &i32)
"###
);
}
@ -242,30 +242,30 @@ fn test() {
}
"#),
@r###"
[11; 210) '{ ... } }': ()
[21; 26) 'slice': &[f64]
[37; 43) '&[0.0]': &[f64; _]
[38; 43) '[0.0]': [f64; _]
[39; 42) '0.0': f64
[49; 208) 'match ... }': ()
[55; 60) 'slice': &[f64]
[71; 74) '&[]': &[f64]
[72; 74) '[]': [f64]
[78; 80) '{}': ()
[90; 94) '&[a]': &[f64]
[91; 94) '[a]': [f64]
[92; 93) 'a': f64
[98; 124) '{ ... }': ()
[112; 113) 'a': f64
[134; 141) '&[b, c]': &[f64]
[135; 141) '[b, c]': [f64]
[136; 137) 'b': f64
[139; 140) 'c': f64
[145; 186) '{ ... }': ()
[159; 160) 'b': f64
[174; 175) 'c': f64
[195; 196) '_': &[f64]
[200; 202) '{}': ()
11..210 '{ ... } }': ()
21..26 'slice': &[f64]
37..43 '&[0.0]': &[f64; _]
38..43 '[0.0]': [f64; _]
39..42 '0.0': f64
49..208 'match ... }': ()
55..60 'slice': &[f64]
71..74 '&[]': &[f64]
72..74 '[]': [f64]
78..80 '{}': ()
90..94 '&[a]': &[f64]
91..94 '[a]': [f64]
92..93 'a': f64
98..124 '{ ... }': ()
112..113 'a': f64
134..141 '&[b, c]': &[f64]
135..141 '[b, c]': [f64]
136..137 'b': f64
139..140 'c': f64
145..186 '{ ... }': ()
159..160 'b': f64
174..175 'c': f64
195..196 '_': &[f64]
200..202 '{}': ()
"###
);
}
@ -288,25 +288,25 @@ fn test() {
}
"#),
@r###"
[11; 180) '{ ... } }': ()
[21; 24) 'arr': [f64; _]
[37; 47) '[0.0, 1.0]': [f64; _]
[38; 41) '0.0': f64
[43; 46) '1.0': f64
[53; 178) 'match ... }': ()
[59; 62) 'arr': [f64; _]
[73; 81) '[1.0, a]': [f64; _]
[74; 77) '1.0': f64
[74; 77) '1.0': f64
[79; 80) 'a': f64
[85; 111) '{ ... }': ()
[99; 100) 'a': f64
[121; 127) '[b, c]': [f64; _]
[122; 123) 'b': f64
[125; 126) 'c': f64
[131; 172) '{ ... }': ()
[145; 146) 'b': f64
[160; 161) 'c': f64
11..180 '{ ... } }': ()
21..24 'arr': [f64; _]
37..47 '[0.0, 1.0]': [f64; _]
38..41 '0.0': f64
43..46 '1.0': f64
53..178 'match ... }': ()
59..62 'arr': [f64; _]
73..81 '[1.0, a]': [f64; _]
74..77 '1.0': f64
74..77 '1.0': f64
79..80 'a': f64
85..111 '{ ... }': ()
99..100 'a': f64
121..127 '[b, c]': [f64; _]
122..123 'b': f64
125..126 'c': f64
131..172 '{ ... }': ()
145..146 'b': f64
160..161 'c': f64
"###
);
}
@ -339,31 +339,31 @@ fn test() {
}
"#),
@r###"
[68; 289) '{ ... d; }': ()
[78; 79) 'e': E
[82; 95) 'E::A { x: 3 }': E
[92; 93) '3': usize
[106; 113) 'S(y, z)': S
[108; 109) 'y': u32
[111; 112) 'z': E
[116; 119) 'foo': S
[129; 148) 'E::A {..._var }': E
[139; 146) 'new_var': usize
[151; 152) 'e': E
[159; 245) 'match ... }': usize
[165; 166) 'e': E
[177; 187) 'E::A { x }': E
[184; 185) 'x': usize
[191; 192) 'x': usize
[202; 206) 'E::B': E
[210; 213) 'foo': bool
[217; 218) '1': usize
[228; 232) 'E::B': E
[236; 238) '10': usize
[256; 275) 'ref d ...{ .. }': &E
[264; 275) 'E::A { .. }': E
[278; 279) 'e': E
[285; 286) 'd': &E
68..289 '{ ... d; }': ()
78..79 'e': E
82..95 'E::A { x: 3 }': E
92..93 '3': usize
106..113 'S(y, z)': S
108..109 'y': u32
111..112 'z': E
116..119 'foo': S
129..148 'E::A {..._var }': E
139..146 'new_var': usize
151..152 'e': E
159..245 'match ... }': usize
165..166 'e': E
177..187 'E::A { x }': E
184..185 'x': usize
191..192 'x': usize
202..206 'E::B': E
210..213 'foo': bool
217..218 '1': usize
228..232 'E::B': E
236..238 '10': usize
256..275 'ref d ...{ .. }': &E
264..275 'E::A { .. }': E
278..279 'e': E
285..286 'd': &E
"###
);
}
@ -391,23 +391,23 @@ fn test(a1: A<u32>, o: Option<u64>) {
}
"#),
@r###"
[79; 81) 'a1': A<u32>
[91; 92) 'o': Option<u64>
[107; 244) '{ ... }; }': ()
[117; 128) 'A { x: x2 }': A<u32>
[124; 126) 'x2': u32
[131; 133) 'a1': A<u32>
[143; 161) 'A::<i6...: x3 }': A<i64>
[157; 159) 'x3': i64
[164; 174) 'A { x: 1 }': A<i64>
[171; 172) '1': i64
[180; 241) 'match ... }': u64
[186; 187) 'o': Option<u64>
[198; 213) 'Option::Some(t)': Option<u64>
[211; 212) 't': u64
[217; 218) 't': u64
[228; 229) '_': Option<u64>
[233; 234) '1': u64
79..81 'a1': A<u32>
91..92 'o': Option<u64>
107..244 '{ ... }; }': ()
117..128 'A { x: x2 }': A<u32>
124..126 'x2': u32
131..133 'a1': A<u32>
143..161 'A::<i6...: x3 }': A<i64>
157..159 'x3': i64
164..174 'A { x: 1 }': A<i64>
171..172 '1': i64
180..241 'match ... }': u64
186..187 'o': Option<u64>
198..213 'Option::Some(t)': Option<u64>
211..212 't': u64
217..218 't': u64
228..229 '_': Option<u64>
233..234 '1': u64
"###
);
}
@ -431,27 +431,27 @@ fn test() {
}
"#, true),
@r###"
[74; 75) '1': usize
[88; 310) '{ ...atch }': ()
[98; 99) 'a': Option<u32>
[115; 119) 'None': Option<u32>
[129; 130) 'b': Option<i64>
[146; 183) 'match ... }': Option<i64>
[152; 153) 'a': Option<u32>
[164; 168) 'None': Option<u32>
[172; 176) 'None': Option<i64>
[193; 194) '_': ()
[201; 224) 'match ... Foo }': Foo
[207; 209) '()': ()
[212; 215) 'Foo': Foo
[219; 222) 'Foo': Foo
[255; 256) '_': ()
[263; 286) 'match ... Bar }': usize
[269; 271) '()': ()
[274; 277) 'Bar': usize
[281; 284) 'Bar': usize
[201; 224): expected (), got Foo
[263; 286): expected (), got usize
74..75 '1': usize
88..310 '{ ...atch }': ()
98..99 'a': Option<u32>
115..119 'None': Option<u32>
129..130 'b': Option<i64>
146..183 'match ... }': Option<i64>
152..153 'a': Option<u32>
164..168 'None': Option<u32>
172..176 'None': Option<i64>
193..194 '_': ()
201..224 'match ... Foo }': Foo
207..209 '()': ()
212..215 'Foo': Foo
219..222 'Foo': Foo
255..256 '_': ()
263..286 'match ... Bar }': usize
269..271 '()': ()
274..277 'Bar': usize
281..284 'Bar': usize
201..224: expected (), got Foo
263..286: expected (), got usize
"###
);
}
@ -469,15 +469,15 @@ fn main() {
}
}
"#), @"
[28; 32) 'self': &S
[42; 51) '{ false }': bool
[44; 49) 'false': bool
[65; 116) '{ ... } }': ()
[71; 114) 'match ... }': ()
[77; 78) 'S': S
[89; 90) 's': S
[94; 95) 's': S
[94; 101) 's.foo()': bool
[105; 107) '()': ()
28..32 'self': &S
42..51 '{ false }': bool
44..49 'false': bool
65..116 '{ ... } }': ()
71..114 'match ... }': ()
77..78 'S': S
89..90 's': S
94..95 's': S
94..101 's.foo()': bool
105..107 '()': ()
")
}

View file

@ -14,11 +14,11 @@ fn test() {
}
"#),
@r###"
[11; 37) '{ l... {}; }': ()
[20; 21) 'x': ()
[24; 34) 'if true {}': ()
[27; 31) 'true': bool
[32; 34) '{}': ()
11..37 '{ l... {}; }': ()
20..21 'x': ()
24..34 'if true {}': ()
27..31 'true': bool
32..34 '{}': ()
"###
);
}
@ -34,10 +34,10 @@ fn test(x: X) {
}
"#),
@r###"
[20; 21) 'x': X
[26; 47) '{ ...eld; }': ()
[32; 33) 'x': X
[32; 44) 'x.some_field': {unknown}
20..21 'x': X
26..47 '{ ...eld; }': ()
32..33 'x': X
32..44 'x.some_field': {unknown}
"###
);
}
@ -55,14 +55,14 @@ fn test() {
}
"#),
@r###"
[11; 89) '{ ... } }': ()
[17; 21) 'X {}': {unknown}
[27; 87) 'match ... }': ()
[33; 34) 'x': {unknown}
[45; 52) 'A::B {}': {unknown}
[56; 58) '()': ()
[68; 74) 'A::Y()': {unknown}
[78; 80) '()': ()
11..89 '{ ... } }': ()
17..21 'X {}': {unknown}
27..87 'match ... }': ()
33..34 'x': {unknown}
45..52 'A::B {}': {unknown}
56..58 '()': ()
68..74 'A::Y()': {unknown}
78..80 '()': ()
"###
);
}
@ -77,12 +77,12 @@ fn quux() {
}
"#),
@r###"
[11; 41) '{ ...+ y; }': ()
[21; 22) 'y': i32
[25; 27) '92': i32
[33; 34) '1': i32
[33; 38) '1 + y': i32
[37; 38) 'y': i32
11..41 '{ ...+ y; }': ()
21..22 'y': i32
25..27 '92': i32
33..34 '1': i32
33..38 '1 + y': i32
37..38 'y': i32
"###
);
}
@ -99,13 +99,13 @@ fn test() {
}
"#),
@r###"
[11; 48) '{ ...&y]; }': ()
[21; 22) 'y': &{unknown}
[25; 32) 'unknown': &{unknown}
[38; 45) '[y, &y]': [&&{unknown}; _]
[39; 40) 'y': &{unknown}
[42; 44) '&y': &&{unknown}
[43; 44) 'y': &{unknown}
11..48 '{ ...&y]; }': ()
21..22 'y': &{unknown}
25..32 'unknown': &{unknown}
38..45 '[y, &y]': [&&{unknown}; _]
39..40 'y': &{unknown}
42..44 '&y': &&{unknown}
43..44 'y': &{unknown}
"###
);
}
@ -123,20 +123,20 @@ fn test() {
}
"#),
@r###"
[11; 80) '{ ...x)]; }': ()
[21; 22) 'x': &&{unknown}
[25; 32) 'unknown': &&{unknown}
[42; 43) 'y': &&{unknown}
[46; 53) 'unknown': &&{unknown}
[59; 77) '[(x, y..., &x)]': [(&&&{unknown}, &&&{unknown}); _]
[60; 66) '(x, y)': (&&&{unknown}, &&&{unknown})
[61; 62) 'x': &&{unknown}
[64; 65) 'y': &&{unknown}
[68; 76) '(&y, &x)': (&&&{unknown}, &&&{unknown})
[69; 71) '&y': &&&{unknown}
[70; 71) 'y': &&{unknown}
[73; 75) '&x': &&&{unknown}
[74; 75) 'x': &&{unknown}
11..80 '{ ...x)]; }': ()
21..22 'x': &&{unknown}
25..32 'unknown': &&{unknown}
42..43 'y': &&{unknown}
46..53 'unknown': &&{unknown}
59..77 '[(x, y..., &x)]': [(&&&{unknown}, &&&{unknown}); _]
60..66 '(x, y)': (&&&{unknown}, &&&{unknown})
61..62 'x': &&{unknown}
64..65 'y': &&{unknown}
68..76 '(&y, &x)': (&&&{unknown}, &&&{unknown})
69..71 '&y': &&&{unknown}
70..71 'y': &&{unknown}
73..75 '&x': &&&{unknown}
74..75 'x': &&{unknown}
"###
);
}
@ -158,12 +158,12 @@ fn write() {
}
"#),
@r###"
[54; 139) '{ ... } }': ()
[60; 137) 'match ... }': ()
[66; 83) 'someth...nknown': Maybe<{unknown}>
[94; 124) 'Maybe:...thing)': Maybe<{unknown}>
[106; 123) 'ref mu...ething': &mut {unknown}
[128; 130) '()': ()
54..139 '{ ... } }': ()
60..137 'match ... }': ()
66..83 'someth...nknown': Maybe<{unknown}>
94..124 'Maybe:...thing)': Maybe<{unknown}>
106..123 'ref mu...ething': &mut {unknown}
128..130 '()': ()
"###
);
}
@ -179,13 +179,13 @@ fn test_line_buffer() {
}
"#),
@r###"
[23; 53) '{ ...n']; }': ()
[29; 50) '&[0, b...b'\n']': &[u8; _]
[30; 50) '[0, b'...b'\n']': [u8; _]
[31; 32) '0': u8
[34; 39) 'b'\n'': u8
[41; 42) '1': u8
[44; 49) 'b'\n'': u8
23..53 '{ ...n']; }': ()
29..50 '&[0, b...b'\n']': &[u8; _]
30..50 '[0, b'...b'\n']': [u8; _]
31..32 '0': u8
34..39 'b'\n'': u8
41..42 '1': u8
44..49 'b'\n'': u8
"###
);
}
@ -202,14 +202,14 @@ pub fn compute() {
}
"#),
@r###"
[18; 108) '{ ... } }': ()
[24; 106) 'match ... }': ()
[30; 37) 'nope!()': {unknown}
[48; 94) 'SizeSk...tail }': {unknown}
[82; 86) 'true': bool
[82; 86) 'true': bool
[88; 92) 'tail': {unknown}
[98; 100) '{}': ()
18..108 '{ ... } }': ()
24..106 'match ... }': ()
30..37 'nope!()': {unknown}
48..94 'SizeSk...tail }': {unknown}
82..86 'true': bool
82..86 'true': bool
88..92 'tail': {unknown}
98..100 '{}': ()
"###
);
}
@ -226,14 +226,14 @@ pub fn primitive_type() {
}
"#),
@r###"
[25; 106) '{ ... } }': ()
[31; 104) 'match ... }': ()
[37; 42) '*self': {unknown}
[38; 42) 'self': {unknown}
[53; 91) 'Borrow...), ..}': {unknown}
[74; 86) 'Primitive(p)': {unknown}
[84; 85) 'p': {unknown}
[95; 97) '{}': ()
25..106 '{ ... } }': ()
31..104 'match ... }': ()
37..42 '*self': {unknown}
38..42 'self': {unknown}
53..91 'Borrow...), ..}': {unknown}
74..86 'Primitive(p)': {unknown}
84..85 'p': {unknown}
95..97 '{}': ()
"###
);
}
@ -260,29 +260,29 @@ fn extra_compiler_flags() {
}
"#),
@r###"
[27; 323) '{ ... } }': ()
[33; 321) 'for co... }': ()
[37; 44) 'content': &{unknown}
[48; 61) 'doesnt_matter': {unknown}
[62; 321) '{ ... }': ()
[76; 80) 'name': &&{unknown}
[83; 167) 'if doe... }': &&{unknown}
[86; 99) 'doesnt_matter': bool
[100; 129) '{ ... }': &&{unknown}
[114; 119) 'first': &&{unknown}
[135; 167) '{ ... }': &&{unknown}
[149; 157) '&content': &&{unknown}
[150; 157) 'content': &{unknown}
[182; 189) 'content': &{unknown}
[192; 314) 'if ICE... }': &{unknown}
[195; 232) 'ICE_RE..._VALUE': {unknown}
[195; 248) 'ICE_RE...&name)': bool
[242; 247) '&name': &&&{unknown}
[243; 247) 'name': &&{unknown}
[249; 277) '{ ... }': &&{unknown}
[263; 267) 'name': &&{unknown}
[283; 314) '{ ... }': &{unknown}
[297; 304) 'content': &{unknown}
27..323 '{ ... } }': ()
33..321 'for co... }': ()
37..44 'content': &{unknown}
48..61 'doesnt_matter': {unknown}
62..321 '{ ... }': ()
76..80 'name': &&{unknown}
83..167 'if doe... }': &&{unknown}
86..99 'doesnt_matter': bool
100..129 '{ ... }': &&{unknown}
114..119 'first': &&{unknown}
135..167 '{ ... }': &&{unknown}
149..157 '&content': &&{unknown}
150..157 'content': &{unknown}
182..189 'content': &{unknown}
192..314 'if ICE... }': &{unknown}
195..232 'ICE_RE..._VALUE': {unknown}
195..248 'ICE_RE...&name)': bool
242..247 '&name': &&&{unknown}
243..247 'name': &&{unknown}
249..277 '{ ... }': &&{unknown}
263..267 'name': &&{unknown}
283..314 '{ ... }': &{unknown}
297..304 'content': &{unknown}
"###
);
}
@ -303,11 +303,11 @@ fn test<R>(query_response: Canonical<QueryResponse<R>>) {
}
"#),
@r###"
[92; 106) 'query_response': Canonical<QueryResponse<R>>
[137; 167) '{ ...lue; }': ()
[143; 164) '&query....value': &QueryResponse<R>
[144; 158) 'query_response': Canonical<QueryResponse<R>>
[144; 164) 'query_....value': QueryResponse<R>
92..106 'query_response': Canonical<QueryResponse<R>>
137..167 '{ ...lue; }': ()
143..164 '&query....value': &QueryResponse<R>
144..158 'query_response': Canonical<QueryResponse<R>>
144..164 'query_....value': QueryResponse<R>
"###
);
}
@ -322,9 +322,9 @@ fn test() {
}
"#),
@r###"
![0; 4) '0u32': u32
[45; 70) '{ ...()); }': ()
[55; 56) 'a': u32
!0..4 '0u32': u32
45..70 '{ ...()); }': ()
55..56 'a': u32
"###
);
}
@ -345,10 +345,10 @@ pub fn main_loop() {
}
"#),
@r###"
[144; 146) '{}': ()
[169; 198) '{ ...t(); }': ()
[175; 193) 'FxHash...efault': fn default<{unknown}, FxHasher>() -> HashSet<{unknown}, FxHasher>
[175; 195) 'FxHash...ault()': HashSet<{unknown}, FxHasher>
144..146 '{}': ()
169..198 '{ ...t(); }': ()
175..193 'FxHash...efault': fn default<{unknown}, FxHasher>() -> HashSet<{unknown}, FxHasher>
175..195 'FxHash...ault()': HashSet<{unknown}, FxHasher>
"###
);
}
@ -375,13 +375,13 @@ fn issue_2669() {
}"#
),
@r###"
[147; 262) '{ ... }': ()
[161; 164) 'end': fn end<{unknown}>()
[161; 166) 'end()': ()
[199; 252) '{ ... }': ()
[221; 223) '_x': !
[230; 237) 'loop {}': !
[235; 237) '{}': ()
147..262 '{ ... }': ()
161..164 'end': fn end<{unknown}>()
161..166 'end()': ()
199..252 '{ ... }': ()
221..223 '_x': !
230..237 'loop {}': !
235..237 '{}': ()
"###
)
}
@ -396,9 +396,9 @@ fn test() {
}
"#),
@r###"
[26; 53) '{ ...oo() }': ()
[32; 49) '<Trait...>::foo': {unknown}
[32; 51) '<Trait...:foo()': ()
26..53 '{ ...oo() }': ()
32..49 '<Trait...>::foo': {unknown}
32..51 '<Trait...:foo()': ()
"###
);
}
@ -496,13 +496,13 @@ fn foo(params: &[usize]) {
}
"#),
@r###"
[8; 14) 'params': &[usize]
[26; 81) '{ ... } }': ()
[32; 79) 'match ... }': ()
[38; 44) 'params': &[usize]
[55; 67) '[ps @ .., _]': [usize]
[65; 66) '_': usize
[71; 73) '{}': ()
8..14 'params': &[usize]
26..81 '{ ... } }': ()
32..79 'match ... }': ()
38..44 'params': &[usize]
55..67 '[ps @ .., _]': [usize]
65..66 '_': usize
71..73 '{}': ()
"###
);
}
@ -523,13 +523,13 @@ fn foo(b: Bar) {
}
"#),
@r###"
[36; 37) 'b': Bar
[44; 96) '{ ... } }': ()
[50; 94) 'match ... }': ()
[56; 57) 'b': Bar
[68; 81) 'Bar { a: .. }': Bar
[77; 79) '..': bool
[85; 87) '{}': ()
36..37 'b': Bar
44..96 '{ ... } }': ()
50..94 'match ... }': ()
56..57 'b': Bar
68..81 'Bar { a: .. }': Bar
77..79 '..': bool
85..87 '{}': ()
"###
);
}
@ -564,13 +564,13 @@ where
}
"#),
@r###"
[66; 70) 'self': Self
[268; 272) 'self': Self
[467; 471) 'self': SelectStatement<F, S, D, W, O, LOf, {unknown}, {unknown}>
[489; 523) '{ ... }': ()
[499; 503) 'self': SelectStatement<F, S, D, W, O, LOf, {unknown}, {unknown}>
[499; 509) 'self.order': O
[499; 516) 'self.o...into()': dyn QueryFragment<DB>
66..70 'self': Self
268..272 'self': Self
467..471 'self': SelectStatement<F, S, D, W, O, LOf, {unknown}, {unknown}>
489..523 '{ ... }': ()
499..503 'self': SelectStatement<F, S, D, W, O, LOf, {unknown}, {unknown}>
499..509 'self.order': O
499..516 'self.o...into()': dyn QueryFragment<DB>
"###
);
}

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -183,8 +183,8 @@ mod tests {
call<|>ee();
}
"#,
"callee FN_DEF FileId(1) [0; 14) [3; 9)",
&["caller FN_DEF FileId(1) [15; 44) [18; 24) : [[33; 39)]"],
"callee FN_DEF FileId(1) 0..14 3..9",
&["caller FN_DEF FileId(1) 15..44 18..24 : [33..39]"],
&[],
);
}
@ -199,8 +199,8 @@ mod tests {
callee();
}
"#,
"callee FN_DEF FileId(1) [0; 14) [3; 9)",
&["caller FN_DEF FileId(1) [15; 44) [18; 24) : [[33; 39)]"],
"callee FN_DEF FileId(1) 0..14 3..9",
&["caller FN_DEF FileId(1) 15..44 18..24 : [33..39]"],
&[],
);
}
@ -216,8 +216,8 @@ mod tests {
callee();
}
"#,
"callee FN_DEF FileId(1) [0; 14) [3; 9)",
&["caller FN_DEF FileId(1) [15; 58) [18; 24) : [[33; 39), [47; 53)]"],
"callee FN_DEF FileId(1) 0..14 3..9",
&["caller FN_DEF FileId(1) 15..58 18..24 : [33..39, 47..53]"],
&[],
);
}
@ -236,10 +236,10 @@ mod tests {
callee();
}
"#,
"callee FN_DEF FileId(1) [0; 14) [3; 9)",
"callee FN_DEF FileId(1) 0..14 3..9",
&[
"caller1 FN_DEF FileId(1) [15; 45) [18; 25) : [[34; 40)]",
"caller2 FN_DEF FileId(1) [46; 76) [49; 56) : [[65; 71)]",
"caller1 FN_DEF FileId(1) 15..45 18..25 : [34..40]",
"caller2 FN_DEF FileId(1) 46..76 49..56 : [65..71]",
],
&[],
);
@ -260,8 +260,8 @@ mod tests {
//- /foo/mod.rs
pub fn callee() {}
"#,
"callee FN_DEF FileId(2) [0; 18) [7; 13)",
&["caller FN_DEF FileId(1) [26; 55) [29; 35) : [[44; 50)]"],
"callee FN_DEF FileId(2) 0..18 7..13",
&["caller FN_DEF FileId(1) 26..55 29..35 : [44..50]"],
&[],
);
}
@ -277,9 +277,9 @@ mod tests {
callee();
}
"#,
"caller FN_DEF FileId(1) [15; 58) [18; 24)",
"caller FN_DEF FileId(1) 15..58 18..24",
&[],
&["callee FN_DEF FileId(1) [0; 14) [3; 9) : [[33; 39), [47; 53)]"],
&["callee FN_DEF FileId(1) 0..14 3..9 : [33..39, 47..53]"],
);
}
@ -298,9 +298,9 @@ mod tests {
//- /foo/mod.rs
pub fn callee() {}
"#,
"caller FN_DEF FileId(1) [26; 55) [29; 35)",
"caller FN_DEF FileId(1) 26..55 29..35",
&[],
&["callee FN_DEF FileId(2) [0; 18) [7; 13) : [[44; 50)]"],
&["callee FN_DEF FileId(2) 0..18 7..13 : [44..50]"],
);
}
@ -321,9 +321,9 @@ mod tests {
}
"#,
"caller2 FN_DEF FileId(1) [32; 63) [35; 42)",
&["caller1 FN_DEF FileId(1) [0; 31) [3; 10) : [[19; 26)]"],
&["caller3 FN_DEF FileId(1) [64; 80) [67; 74) : [[51; 58)]"],
"caller2 FN_DEF FileId(1) 32..63 35..42",
&["caller1 FN_DEF FileId(1) 0..31 3..10 : [19..26]"],
&["caller3 FN_DEF FileId(1) 64..80 67..74 : [51..58]"],
);
}
}

View file

@ -147,190 +147,190 @@ mod tests {
[
CompletionItem {
label: "allow",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "allow(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "cfg",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "cfg(${0:predicate})",
kind: Attribute,
},
CompletionItem {
label: "cfg_attr",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "cfg_attr(${1:predicate}, ${0:attr})",
kind: Attribute,
},
CompletionItem {
label: "deny",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "deny(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "deprecated",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "deprecated = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "derive",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "derive(${0:Debug})",
kind: Attribute,
},
CompletionItem {
label: "doc",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "doc = \"${0:docs}\"",
kind: Attribute,
},
CompletionItem {
label: "forbid",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "forbid(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "ignore",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "ignore(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "inline",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "inline(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "link",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "link",
kind: Attribute,
},
CompletionItem {
label: "link_name",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "link_name = \"${0:symbol_name}\"",
kind: Attribute,
},
CompletionItem {
label: "macro_export",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "macro_export",
kind: Attribute,
},
CompletionItem {
label: "macro_use",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "macro_use",
kind: Attribute,
},
CompletionItem {
label: "must_use",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "must_use = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "no_mangle",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "no_mangle",
kind: Attribute,
},
CompletionItem {
label: "non_exhaustive",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "non_exhaustive",
kind: Attribute,
},
CompletionItem {
label: "path",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "path =\"${0:path}\"",
kind: Attribute,
},
CompletionItem {
label: "proc_macro",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "proc_macro",
kind: Attribute,
},
CompletionItem {
label: "proc_macro_attribute",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "proc_macro_attribute",
kind: Attribute,
},
CompletionItem {
label: "proc_macro_derive",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "proc_macro_derive(${0:Trait})",
kind: Attribute,
},
CompletionItem {
label: "repr",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "repr(${0:C})",
kind: Attribute,
},
CompletionItem {
label: "should_panic",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "expected = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "target_feature",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "target_feature = \"${0:feature}\"",
kind: Attribute,
},
CompletionItem {
label: "test",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "test",
kind: Attribute,
},
CompletionItem {
label: "used",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "used",
kind: Attribute,
},
CompletionItem {
label: "warn",
source_range: [19; 19),
delete: [19; 19),
source_range: 19..19,
delete: 19..19,
insert: "warn(${0:lint})",
kind: Attribute,
},
@ -351,232 +351,232 @@ mod tests {
[
CompletionItem {
label: "allow",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "allow(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "cfg",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "cfg(${0:predicate})",
kind: Attribute,
},
CompletionItem {
label: "cfg_attr",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "cfg_attr(${1:predicate}, ${0:attr})",
kind: Attribute,
},
CompletionItem {
label: "deny",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "deny(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "deprecated",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "deprecated = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "derive",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "derive(${0:Debug})",
kind: Attribute,
},
CompletionItem {
label: "doc",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "doc = \"${0:docs}\"",
kind: Attribute,
},
CompletionItem {
label: "feature",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "feature(${0:flag})",
kind: Attribute,
},
CompletionItem {
label: "forbid",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "forbid(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "global_allocator",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "global_allocator",
kind: Attribute,
},
CompletionItem {
label: "ignore",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "ignore(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "inline",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "inline(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "link",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "link",
kind: Attribute,
},
CompletionItem {
label: "link_name",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "link_name = \"${0:symbol_name}\"",
kind: Attribute,
},
CompletionItem {
label: "macro_export",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "macro_export",
kind: Attribute,
},
CompletionItem {
label: "macro_use",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "macro_use",
kind: Attribute,
},
CompletionItem {
label: "must_use",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "must_use = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "no_mangle",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "no_mangle",
kind: Attribute,
},
CompletionItem {
label: "no_std",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "no_std",
kind: Attribute,
},
CompletionItem {
label: "non_exhaustive",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "non_exhaustive",
kind: Attribute,
},
CompletionItem {
label: "panic_handler",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "panic_handler",
kind: Attribute,
},
CompletionItem {
label: "path",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "path =\"${0:path}\"",
kind: Attribute,
},
CompletionItem {
label: "proc_macro",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "proc_macro",
kind: Attribute,
},
CompletionItem {
label: "proc_macro_attribute",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "proc_macro_attribute",
kind: Attribute,
},
CompletionItem {
label: "proc_macro_derive",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "proc_macro_derive(${0:Trait})",
kind: Attribute,
},
CompletionItem {
label: "recursion_limit",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "recursion_limit = ${0:128}",
kind: Attribute,
},
CompletionItem {
label: "repr",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "repr(${0:C})",
kind: Attribute,
},
CompletionItem {
label: "should_panic",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "expected = \"${0:reason}\"",
kind: Attribute,
},
CompletionItem {
label: "target_feature",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "target_feature = \"${0:feature}\"",
kind: Attribute,
},
CompletionItem {
label: "test",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "test",
kind: Attribute,
},
CompletionItem {
label: "used",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "used",
kind: Attribute,
},
CompletionItem {
label: "warn",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "warn(${0:lint})",
kind: Attribute,
},
CompletionItem {
label: "windows_subsystem",
source_range: [20; 20),
delete: [20; 20),
source_range: 20..20,
delete: 20..20,
insert: "windows_subsystem = \"${0:subsystem}\"",
kind: Attribute,
},

View file

@ -94,8 +94,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [94; 94),
delete: [94; 94),
source_range: 94..94,
delete: 94..94,
insert: "the_field",
kind: Field,
detail: "u32",
@ -125,8 +125,8 @@ mod tests {
[
CompletionItem {
label: "foo()",
source_range: [187; 187),
delete: [187; 187),
source_range: 187..187,
delete: 187..187,
insert: "foo()$0",
kind: Method,
lookup: "foo",
@ -134,8 +134,8 @@ mod tests {
},
CompletionItem {
label: "the_field",
source_range: [187; 187),
delete: [187; 187),
source_range: 187..187,
delete: 187..187,
insert: "the_field",
kind: Field,
detail: "(u32,)",
@ -165,8 +165,8 @@ mod tests {
[
CompletionItem {
label: "foo()",
source_range: [126; 126),
delete: [126; 126),
source_range: 126..126,
delete: 126..126,
insert: "foo()$0",
kind: Method,
lookup: "foo",
@ -174,8 +174,8 @@ mod tests {
},
CompletionItem {
label: "the_field",
source_range: [126; 126),
delete: [126; 126),
source_range: 126..126,
delete: 126..126,
insert: "the_field",
kind: Field,
detail: "(u32, i32)",
@ -222,24 +222,24 @@ mod tests {
[
CompletionItem {
label: "crate_field",
source_range: [313; 313),
delete: [313; 313),
source_range: 313..313,
delete: 313..313,
insert: "crate_field",
kind: Field,
detail: "u32",
},
CompletionItem {
label: "pub_field",
source_range: [313; 313),
delete: [313; 313),
source_range: 313..313,
delete: 313..313,
insert: "pub_field",
kind: Field,
detail: "u32",
},
CompletionItem {
label: "super_field",
source_range: [313; 313),
delete: [313; 313),
source_range: 313..313,
delete: 313..313,
insert: "super_field",
kind: Field,
detail: "u32",
@ -267,8 +267,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [144; 144),
delete: [144; 144),
source_range: 144..144,
delete: 144..144,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -300,8 +300,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [243; 243),
delete: [243; 243),
source_range: 243..243,
delete: 243..243,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -333,8 +333,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [256; 256),
delete: [256; 256),
source_range: 256..256,
delete: 256..256,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -362,8 +362,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [151; 151),
delete: [151; 151),
source_range: 151..151,
delete: 151..151,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -391,8 +391,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [155; 155),
delete: [155; 155),
source_range: 155..155,
delete: 155..155,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -423,8 +423,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [219; 219),
delete: [219; 219),
source_range: 219..219,
delete: 219..219,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -475,8 +475,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [249; 249),
delete: [249; 249),
source_range: 249..249,
delete: 249..249,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",
@ -502,16 +502,16 @@ mod tests {
[
CompletionItem {
label: "0",
source_range: [75; 75),
delete: [75; 75),
source_range: 75..75,
delete: 75..75,
insert: "0",
kind: Field,
detail: "i32",
},
CompletionItem {
label: "1",
source_range: [75; 75),
delete: [75; 75),
source_range: 75..75,
delete: 75..75,
insert: "1",
kind: Field,
detail: "f64",
@ -545,8 +545,8 @@ mod tests {
[
CompletionItem {
label: "blah()",
source_range: [299; 300),
delete: [299; 300),
source_range: 299..300,
delete: 299..300,
insert: "blah()$0",
kind: Method,
lookup: "blah",
@ -572,8 +572,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [106; 106),
delete: [106; 106),
source_range: 106..106,
delete: 106..106,
insert: "the_field",
kind: Field,
detail: "u32",
@ -606,8 +606,8 @@ mod tests {
[
CompletionItem {
label: "await",
source_range: [74; 74),
delete: [74; 74),
source_range: 74..74,
delete: 74..74,
insert: "await",
detail: "expr.await",
},
@ -638,15 +638,15 @@ mod tests {
[
CompletionItem {
label: "A",
source_range: [217; 217),
delete: [217; 217),
source_range: 217..217,
delete: 217..217,
insert: "A",
kind: Const,
},
CompletionItem {
label: "b",
source_range: [217; 217),
delete: [217; 217),
source_range: 217..217,
delete: 217..217,
insert: "b",
kind: Module,
},
@ -671,8 +671,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [156; 157),
delete: [156; 157),
source_range: 156..157,
delete: 156..157,
insert: "the_field",
kind: Field,
detail: "u32",
@ -698,8 +698,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [156; 157),
delete: [156; 157),
source_range: 156..157,
delete: 156..157,
insert: "the_field",
kind: Field,
detail: "u32",
@ -726,8 +726,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [156; 156),
delete: [156; 156),
source_range: 156..156,
delete: 156..156,
insert: "the_field",
kind: Field,
detail: "u32",
@ -753,8 +753,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [162; 163),
delete: [162; 163),
source_range: 162..163,
delete: 162..163,
insert: "the_field",
kind: Field,
detail: "u32",
@ -790,8 +790,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [552; 552),
delete: [552; 552),
source_range: 552..552,
delete: 552..552,
insert: "the_field",
kind: Field,
detail: "u32",
@ -820,8 +820,8 @@ mod tests {
[
CompletionItem {
label: "the_method()",
source_range: [201; 201),
delete: [201; 201),
source_range: 201..201,
delete: 201..201,
insert: "the_method()$0",
kind: Method,
lookup: "the_method",

View file

@ -75,8 +75,8 @@ mod tests {
[
CompletionItem {
label: "file_id: FileId",
source_range: [110; 114),
delete: [110; 114),
source_range: 110..114,
delete: 110..114,
insert: "file_id: FileId",
lookup: "file_id",
},
@ -99,8 +99,8 @@ mod tests {
[
CompletionItem {
label: "file_id: FileId",
source_range: [110; 114),
delete: [110; 114),
source_range: 110..114,
delete: 110..114,
insert: "file_id: FileId",
lookup: "file_id",
},
@ -126,8 +126,8 @@ mod tests {
[
CompletionItem {
label: "file_id: FileId",
source_range: [289; 293),
delete: [289; 293),
source_range: 289..293,
delete: 289..293,
insert: "file_id: FileId",
lookup: "file_id",
},

View file

@ -140,22 +140,22 @@ mod tests {
[
CompletionItem {
label: "crate",
source_range: [21; 21),
delete: [21; 21),
source_range: 21..21,
delete: 21..21,
insert: "crate::",
kind: Keyword,
},
CompletionItem {
label: "self",
source_range: [21; 21),
delete: [21; 21),
source_range: 21..21,
delete: 21..21,
insert: "self",
kind: Keyword,
},
CompletionItem {
label: "super",
source_range: [21; 21),
delete: [21; 21),
source_range: 21..21,
delete: 21..21,
insert: "super::",
kind: Keyword,
},
@ -173,15 +173,15 @@ mod tests {
[
CompletionItem {
label: "self",
source_range: [24; 24),
delete: [24; 24),
source_range: 24..24,
delete: 24..24,
insert: "self",
kind: Keyword,
},
CompletionItem {
label: "super",
source_range: [24; 24),
delete: [24; 24),
source_range: 24..24,
delete: 24..24,
insert: "super::",
kind: Keyword,
},
@ -199,15 +199,15 @@ mod tests {
[
CompletionItem {
label: "self",
source_range: [28; 28),
delete: [28; 28),
source_range: 28..28,
delete: 28..28,
insert: "self",
kind: Keyword,
},
CompletionItem {
label: "super",
source_range: [28; 28),
delete: [28; 28),
source_range: 28..28,
delete: 28..28,
insert: "super::",
kind: Keyword,
},
@ -230,36 +230,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "return;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "while $0 {}",
kind: Keyword,
},
@ -284,50 +284,50 @@ mod tests {
[
CompletionItem {
label: "else",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "else {$0}",
kind: Keyword,
},
CompletionItem {
label: "else if",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "else if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "if",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "return;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [108; 108),
delete: [108; 108),
source_range: 108..108,
delete: 108..108,
insert: "while $0 {}",
kind: Keyword,
},
@ -351,36 +351,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [56; 56),
delete: [56; 56),
source_range: 56..56,
delete: 56..56,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [56; 56),
delete: [56; 56),
source_range: 56..56,
delete: 56..56,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [56; 56),
delete: [56; 56),
source_range: 56..56,
delete: 56..56,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [56; 56),
delete: [56; 56),
source_range: 56..56,
delete: 56..56,
insert: "return $0;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [56; 56),
delete: [56; 56),
source_range: 56..56,
delete: 56..56,
insert: "while $0 {}",
kind: Keyword,
},
@ -400,36 +400,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "return;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "while $0 {}",
kind: Keyword,
},
@ -454,36 +454,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [97; 97),
delete: [97; 97),
source_range: 97..97,
delete: 97..97,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [97; 97),
delete: [97; 97),
source_range: 97..97,
delete: 97..97,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [97; 97),
delete: [97; 97),
source_range: 97..97,
delete: 97..97,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [97; 97),
delete: [97; 97),
source_range: 97..97,
delete: 97..97,
insert: "return $0",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [97; 97),
delete: [97; 97),
source_range: 97..97,
delete: 97..97,
insert: "while $0 {}",
kind: Keyword,
},
@ -508,36 +508,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "return $0;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "while $0 {}",
kind: Keyword,
},
@ -560,36 +560,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "return $0;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "while $0 {}",
kind: Keyword,
},
@ -612,50 +612,50 @@ mod tests {
[
CompletionItem {
label: "break",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "break;",
kind: Keyword,
},
CompletionItem {
label: "continue",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "continue;",
kind: Keyword,
},
CompletionItem {
label: "if",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "return $0;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [63; 63),
delete: [63; 63),
source_range: 63..63,
delete: 63..63,
insert: "while $0 {}",
kind: Keyword,
},
@ -676,36 +676,36 @@ mod tests {
[
CompletionItem {
label: "if",
source_range: [68; 68),
delete: [68; 68),
source_range: 68..68,
delete: 68..68,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [68; 68),
delete: [68; 68),
source_range: 68..68,
delete: 68..68,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [68; 68),
delete: [68; 68),
source_range: 68..68,
delete: 68..68,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [68; 68),
delete: [68; 68),
source_range: 68..68,
delete: 68..68,
insert: "return $0;",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [68; 68),
delete: [68; 68),
source_range: 68..68,
delete: 68..68,
insert: "while $0 {}",
kind: Keyword,
},
@ -732,50 +732,50 @@ mod tests {
[
CompletionItem {
label: "break",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "break",
kind: Keyword,
},
CompletionItem {
label: "continue",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "continue",
kind: Keyword,
},
CompletionItem {
label: "if",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "if $0 {}",
kind: Keyword,
},
CompletionItem {
label: "loop",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "loop {$0}",
kind: Keyword,
},
CompletionItem {
label: "match",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "match $0 {}",
kind: Keyword,
},
CompletionItem {
label: "return",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "return",
kind: Keyword,
},
CompletionItem {
label: "while",
source_range: [122; 124),
delete: [122; 124),
source_range: 122..124,
delete: 122..124,
insert: "while $0 {}",
kind: Keyword,
},

View file

@ -42,8 +42,8 @@ mod tests {
[
CompletionItem {
label: "foo!(…)",
source_range: [46; 46),
delete: [46; 46),
source_range: 46..46,
delete: 46..46,
insert: "foo!($0)",
kind: Macro,
detail: "macro_rules! foo",
@ -82,8 +82,8 @@ mod tests {
[
CompletionItem {
label: "vec![…]",
source_range: [280; 280),
delete: [280; 280),
source_range: 280..280,
delete: 280..280,
insert: "vec![$0]",
kind: Macro,
detail: "macro_rules! vec",
@ -119,8 +119,8 @@ mod tests {
[
CompletionItem {
label: "foo! {…}",
source_range: [163; 163),
delete: [163; 163),
source_range: 163..163,
delete: 163..163,
insert: "foo! {$0}",
kind: Macro,
detail: "macro_rules! foo",
@ -130,8 +130,8 @@ mod tests {
},
CompletionItem {
label: "main()",
source_range: [163; 163),
delete: [163; 163),
source_range: 163..163,
delete: 163..163,
insert: "main()$0",
kind: Function,
lookup: "main",

View file

@ -63,37 +63,37 @@ mod tests {
[
CompletionItem {
label: "Bar",
source_range: [246; 246),
delete: [246; 246),
source_range: 246..246,
delete: 246..246,
insert: "Bar",
kind: Struct,
},
CompletionItem {
label: "E",
source_range: [246; 246),
delete: [246; 246),
source_range: 246..246,
delete: 246..246,
insert: "E",
kind: Enum,
},
CompletionItem {
label: "X",
source_range: [246; 246),
delete: [246; 246),
source_range: 246..246,
delete: 246..246,
insert: "X",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Z",
source_range: [246; 246),
delete: [246; 246),
source_range: 246..246,
delete: 246..246,
insert: "Z",
kind: Const,
},
CompletionItem {
label: "m",
source_range: [246; 246),
delete: [246; 246),
source_range: 246..246,
delete: 246..246,
insert: "m",
kind: Module,
},
@ -119,15 +119,15 @@ mod tests {
[
CompletionItem {
label: "E",
source_range: [151; 151),
delete: [151; 151),
source_range: 151..151,
delete: 151..151,
insert: "E",
kind: Enum,
},
CompletionItem {
label: "m!(…)",
source_range: [151; 151),
delete: [151; 151),
source_range: 151..151,
delete: 151..151,
insert: "m!($0)",
kind: Macro,
detail: "macro_rules! m",

View file

@ -176,57 +176,57 @@ mod tests {
[
CompletionItem {
label: "box",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "Box::new(bar)",
detail: "Box::new(expr)",
},
CompletionItem {
label: "dbg",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "dbg!(bar)",
detail: "dbg!(expr)",
},
CompletionItem {
label: "if",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "if bar {$0}",
detail: "if expr {}",
},
CompletionItem {
label: "match",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "match bar {\n ${1:_} => {$0\\},\n}",
detail: "match expr {}",
},
CompletionItem {
label: "not",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "!bar",
detail: "!expr",
},
CompletionItem {
label: "ref",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "&bar",
detail: "&expr",
},
CompletionItem {
label: "refm",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "&mut bar",
detail: "&mut expr",
},
CompletionItem {
label: "while",
source_range: [89; 89),
delete: [85; 89),
source_range: 89..89,
delete: 85..89,
insert: "while bar {\n$0\n}",
detail: "while expr {}",
},
@ -250,43 +250,43 @@ mod tests {
[
CompletionItem {
label: "box",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "Box::new(bar)",
detail: "Box::new(expr)",
},
CompletionItem {
label: "dbg",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "dbg!(bar)",
detail: "dbg!(expr)",
},
CompletionItem {
label: "match",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "match bar {\n ${1:_} => {$0\\},\n}",
detail: "match expr {}",
},
CompletionItem {
label: "not",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "!bar",
detail: "!expr",
},
CompletionItem {
label: "ref",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "&bar",
detail: "&expr",
},
CompletionItem {
label: "refm",
source_range: [91; 91),
delete: [87; 91),
source_range: 91..91,
delete: 87..91,
insert: "&mut bar",
detail: "&mut expr",
},
@ -309,43 +309,43 @@ mod tests {
[
CompletionItem {
label: "box",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "Box::new(42)",
detail: "Box::new(expr)",
},
CompletionItem {
label: "dbg",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "dbg!(42)",
detail: "dbg!(expr)",
},
CompletionItem {
label: "match",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "match 42 {\n ${1:_} => {$0\\},\n}",
detail: "match expr {}",
},
CompletionItem {
label: "not",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "!42",
detail: "!expr",
},
CompletionItem {
label: "ref",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "&42",
detail: "&expr",
},
CompletionItem {
label: "refm",
source_range: [52; 52),
delete: [49; 52),
source_range: 52..52,
delete: 49..52,
insert: "&mut 42",
detail: "&mut expr",
},
@ -370,43 +370,43 @@ mod tests {
[
CompletionItem {
label: "box",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "Box::new(bar)",
detail: "Box::new(expr)",
},
CompletionItem {
label: "dbg",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "dbg!(bar)",
detail: "dbg!(expr)",
},
CompletionItem {
label: "match",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "match bar {\n ${1:_} => {$0\\},\n}",
detail: "match expr {}",
},
CompletionItem {
label: "not",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "!bar",
detail: "!expr",
},
CompletionItem {
label: "ref",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "&bar",
detail: "&expr",
},
CompletionItem {
label: "refm",
source_range: [149; 150),
delete: [145; 150),
source_range: 149..150,
delete: 145..150,
insert: "&mut bar",
detail: "&mut expr",
},
@ -429,43 +429,43 @@ mod tests {
[
CompletionItem {
label: "box",
source_range: [56; 56),
delete: [49; 56),
source_range: 56..56,
delete: 49..56,
insert: "Box::new(&&&&42)",
detail: "Box::new(expr)",
},
CompletionItem {
label: "dbg",
source_range: [56; 56),
delete: [49; 56),
source_range: 56..56,
delete: 49..56,
insert: "dbg!(&&&&42)",
detail: "dbg!(expr)",
},
CompletionItem {
label: "match",
source_range: [56; 56),
delete: [49; 56),
source_range: 56..56,
delete: 49..56,
insert: "match &&&&42 {\n ${1:_} => {$0\\},\n}",
detail: "match expr {}",
},
CompletionItem {
label: "not",
source_range: [56; 56),
delete: [53; 56),
source_range: 56..56,
delete: 53..56,
insert: "!42",
detail: "!expr",
},
CompletionItem {
label: "ref",
source_range: [56; 56),
delete: [53; 56),
source_range: 56..56,
delete: 53..56,
insert: "&42",
detail: "&expr",
},
CompletionItem {
label: "refm",
source_range: [56; 56),
delete: [53; 56),
source_range: 56..56,
delete: 53..56,
insert: "&mut 42",
detail: "&mut expr",
},

View file

@ -162,8 +162,8 @@ mod tests {
[
CompletionItem {
label: "my",
source_range: [27; 29),
delete: [27; 29),
source_range: 27..29,
delete: 27..29,
insert: "my",
kind: Module,
documentation: Documentation(
@ -193,15 +193,15 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [31; 31),
delete: [31; 31),
source_range: 31..31,
delete: 31..31,
insert: "Foo",
kind: Struct,
},
CompletionItem {
label: "PublicBar",
source_range: [31; 31),
delete: [31; 31),
source_range: 31..31,
delete: 31..31,
insert: "PublicBar",
kind: Struct,
},
@ -226,8 +226,8 @@ mod tests {
[
CompletionItem {
label: "Bar",
source_range: [30; 30),
delete: [30; 30),
source_range: 30..30,
delete: 30..30,
insert: "Bar",
kind: Struct,
},
@ -252,15 +252,15 @@ mod tests {
[
CompletionItem {
label: "Spam",
source_range: [11; 13),
delete: [11; 13),
source_range: 11..13,
delete: 11..13,
insert: "Spam",
kind: Struct,
},
CompletionItem {
label: "foo",
source_range: [11; 13),
delete: [11; 13),
source_range: 11..13,
delete: 11..13,
insert: "foo",
kind: Module,
},
@ -285,15 +285,15 @@ mod tests {
[
CompletionItem {
label: "Spam",
source_range: [12; 14),
delete: [12; 14),
source_range: 12..14,
delete: 12..14,
insert: "Spam",
kind: Struct,
},
CompletionItem {
label: "foo",
source_range: [12; 14),
delete: [12; 14),
source_range: 12..14,
delete: 12..14,
insert: "foo",
kind: Module,
},
@ -322,8 +322,8 @@ mod tests {
[
CompletionItem {
label: "Spam",
source_range: [23; 25),
delete: [23; 25),
source_range: 23..25,
delete: 23..25,
insert: "Spam",
kind: Struct,
},
@ -352,8 +352,8 @@ mod tests {
[
CompletionItem {
label: "Bar(…)",
source_range: [116; 116),
delete: [116; 116),
source_range: 116..116,
delete: 116..116,
insert: "Bar($0)",
kind: EnumVariant,
lookup: "Bar",
@ -365,8 +365,8 @@ mod tests {
},
CompletionItem {
label: "Foo",
source_range: [116; 116),
delete: [116; 116),
source_range: 116..116,
delete: 116..116,
insert: "Foo",
kind: EnumVariant,
detail: "()",
@ -402,8 +402,8 @@ mod tests {
[
CompletionItem {
label: "Bar(…)",
source_range: [180; 180),
delete: [180; 180),
source_range: 180..180,
delete: 180..180,
insert: "Bar($0)",
kind: EnumVariant,
lookup: "Bar",
@ -415,8 +415,8 @@ mod tests {
},
CompletionItem {
label: "Foo",
source_range: [180; 180),
delete: [180; 180),
source_range: 180..180,
delete: 180..180,
insert: "Foo",
kind: EnumVariant,
detail: "()",
@ -426,8 +426,8 @@ mod tests {
},
CompletionItem {
label: "S(…)",
source_range: [180; 180),
delete: [180; 180),
source_range: 180..180,
delete: 180..180,
insert: "S($0)",
kind: EnumVariant,
lookup: "S",
@ -463,8 +463,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [100; 100),
delete: [100; 100),
source_range: 100..100,
delete: 100..100,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -499,8 +499,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [105; 105),
delete: [105; 105),
source_range: 105..105,
delete: 105..105,
insert: "m()$0",
kind: Method,
lookup: "m",
@ -535,8 +535,8 @@ mod tests {
[
CompletionItem {
label: "C",
source_range: [107; 107),
delete: [107; 107),
source_range: 107..107,
delete: 107..107,
insert: "C",
kind: Const,
detail: "const C: i32 = 42;",
@ -570,8 +570,8 @@ mod tests {
[
CompletionItem {
label: "T",
source_range: [101; 101),
delete: [101; 101),
source_range: 101..101,
delete: 101..101,
insert: "T",
kind: TypeAlias,
detail: "type T = i32;",
@ -610,24 +610,24 @@ mod tests {
[
CompletionItem {
label: "PUBLIC_CONST",
source_range: [302; 302),
delete: [302; 302),
source_range: 302..302,
delete: 302..302,
insert: "PUBLIC_CONST",
kind: Const,
detail: "pub(super) const PUBLIC_CONST: u32 = 1;",
},
CompletionItem {
label: "PublicType",
source_range: [302; 302),
delete: [302; 302),
source_range: 302..302,
delete: 302..302,
insert: "PublicType",
kind: TypeAlias,
detail: "pub(super) type PublicType = u32;",
},
CompletionItem {
label: "public_method()",
source_range: [302; 302),
delete: [302; 302),
source_range: 302..302,
delete: 302..302,
insert: "public_method()$0",
kind: Function,
lookup: "public_method",
@ -659,8 +659,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [100; 100),
delete: [100; 100),
source_range: 100..100,
delete: 100..100,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -695,8 +695,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [101; 101),
delete: [101; 101),
source_range: 101..101,
delete: 101..101,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -728,8 +728,8 @@ mod tests {
[
CompletionItem {
label: "bar",
source_range: [9; 9),
delete: [9; 9),
source_range: 9..9,
delete: 9..9,
insert: "bar",
kind: Module,
},
@ -756,8 +756,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [73; 73),
delete: [73; 73),
source_range: 73..73,
delete: 73..73,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -792,8 +792,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [99; 99),
delete: [99; 99),
source_range: 99..99,
delete: 99..99,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -828,8 +828,8 @@ mod tests {
[
CompletionItem {
label: "m()",
source_range: [110; 110),
delete: [110; 110),
source_range: 110..110,
delete: 110..110,
insert: "m()$0",
kind: Function,
lookup: "m",
@ -862,8 +862,8 @@ mod tests {
[
CompletionItem {
label: "bar()",
source_range: [185; 185),
delete: [185; 185),
source_range: 185..185,
delete: 185..185,
insert: "bar()$0",
kind: Function,
lookup: "bar",
@ -871,8 +871,8 @@ mod tests {
},
CompletionItem {
label: "foo()",
source_range: [185; 185),
delete: [185; 185),
source_range: 185..185,
delete: 185..185,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -902,16 +902,16 @@ mod tests {
[
CompletionItem {
label: "foo!(…)",
source_range: [179; 179),
delete: [179; 179),
source_range: 179..179,
delete: 179..179,
insert: "foo!($0)",
kind: Macro,
detail: "#[macro_export]\nmacro_rules! foo",
},
CompletionItem {
label: "main()",
source_range: [179; 179),
delete: [179; 179),
source_range: 179..179,
delete: 179..179,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -947,22 +947,22 @@ mod tests {
[
CompletionItem {
label: "RIGHT_CONST",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "RIGHT_CONST",
kind: Const,
},
CompletionItem {
label: "RightType",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "RightType",
kind: Struct,
},
CompletionItem {
label: "right_fn()",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "right_fn()$0",
kind: Function,
lookup: "right_fn",
@ -986,8 +986,8 @@ mod tests {
[
CompletionItem {
label: "foo()",
source_range: [93; 94),
delete: [93; 94),
source_range: 93..94,
delete: 93..94,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -995,8 +995,8 @@ mod tests {
},
CompletionItem {
label: "main()",
source_range: [93; 94),
delete: [93; 94),
source_range: 93..94,
delete: 93..94,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -1025,15 +1025,15 @@ mod tests {
[
CompletionItem {
label: "z",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "z",
kind: Module,
},
CompletionItem {
label: "z()",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "z()$0",
kind: Function,
lookup: "z",
@ -1064,8 +1064,8 @@ mod tests {
[
CompletionItem {
label: "new()",
source_range: [292; 292),
delete: [292; 292),
source_range: 292..292,
delete: 292..292,
insert: "new()$0",
kind: Function,
lookup: "new",

View file

@ -44,8 +44,8 @@ mod tests {
[
CompletionItem {
label: "foo",
source_range: [117; 118),
delete: [117; 118),
source_range: 117..118,
delete: 117..118,
insert: "foo",
kind: Field,
detail: "u32",
@ -73,16 +73,16 @@ mod tests {
[
CompletionItem {
label: "bar",
source_range: [161; 161),
delete: [161; 161),
source_range: 161..161,
delete: 161..161,
insert: "bar",
kind: Field,
detail: "()",
},
CompletionItem {
label: "foo",
source_range: [161; 161),
delete: [161; 161),
source_range: 161..161,
delete: 161..161,
insert: "foo",
kind: Field,
detail: "u32",
@ -109,8 +109,8 @@ mod tests {
[
CompletionItem {
label: "foo",
source_range: [171; 172),
delete: [171; 172),
source_range: 171..172,
delete: 171..172,
insert: "foo",
kind: Field,
detail: "u32",
@ -145,16 +145,16 @@ mod tests {
[
CompletionItem {
label: "bar",
source_range: [372; 372),
delete: [372; 372),
source_range: 372..372,
delete: 372..372,
insert: "bar",
kind: Field,
detail: "u32",
},
CompletionItem {
label: "baz",
source_range: [372; 372),
delete: [372; 372),
source_range: 372..372,
delete: 372..372,
insert: "baz",
kind: Field,
detail: "u32",
@ -190,8 +190,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [142; 145),
delete: [142; 145),
source_range: 142..145,
delete: 142..145,
insert: "the_field",
kind: Field,
detail: "u32",
@ -215,8 +215,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [83; 86),
delete: [83; 86),
source_range: 83..86,
delete: 83..86,
insert: "the_field",
kind: Field,
detail: "u32",
@ -241,8 +241,8 @@ mod tests {
[
CompletionItem {
label: "a",
source_range: [119; 119),
delete: [119; 119),
source_range: 119..119,
delete: 119..119,
insert: "a",
kind: Field,
detail: "u32",
@ -267,8 +267,8 @@ mod tests {
[
CompletionItem {
label: "b",
source_range: [119; 119),
delete: [119; 119),
source_range: 119..119,
delete: 119..119,
insert: "b",
kind: Field,
detail: "u32",
@ -292,8 +292,8 @@ mod tests {
[
CompletionItem {
label: "a",
source_range: [93; 93),
delete: [93; 93),
source_range: 93..93,
delete: 93..93,
insert: "a",
kind: Field,
detail: "u32",
@ -317,8 +317,8 @@ mod tests {
[
CompletionItem {
label: "the_field",
source_range: [137; 140),
delete: [137; 140),
source_range: 137..140,
delete: 137..140,
insert: "the_field",
kind: Field,
detail: "u32",
@ -352,16 +352,16 @@ mod tests {
[
CompletionItem {
label: "bar",
source_range: [302; 302),
delete: [302; 302),
source_range: 302..302,
delete: 302..302,
insert: "bar",
kind: Field,
detail: "u32",
},
CompletionItem {
label: "baz",
source_range: [302; 302),
delete: [302; 302),
source_range: 302..302,
delete: 302..302,
insert: "baz",
kind: Field,
detail: "u32",
@ -393,8 +393,8 @@ mod tests {
[
CompletionItem {
label: "foo2",
source_range: [221; 221),
delete: [221; 221),
source_range: 221..221,
delete: 221..221,
insert: "foo2",
kind: Field,
detail: "u32",

View file

@ -67,15 +67,15 @@ mod tests {
[
CompletionItem {
label: "pd",
source_range: [17; 17),
delete: [17; 17),
source_range: 17..17,
delete: 17..17,
insert: "eprintln!(\"$0 = {:?}\", $0);",
kind: Snippet,
},
CompletionItem {
label: "ppd",
source_range: [17; 17),
delete: [17; 17),
source_range: 17..17,
delete: 17..17,
insert: "eprintln!(\"$0 = {:#?}\", $0);",
kind: Snippet,
},
@ -111,23 +111,23 @@ mod tests {
[
CompletionItem {
label: "Test function",
source_range: [78; 78),
delete: [78; 78),
source_range: 78..78,
delete: 78..78,
insert: "#[test]\nfn ${1:feature}() {\n $0\n}",
kind: Snippet,
lookup: "tfn",
},
CompletionItem {
label: "macro_rules",
source_range: [78; 78),
delete: [78; 78),
source_range: 78..78,
delete: 78..78,
insert: "macro_rules! $1 {\n\t($2) => {\n\t\t$0\n\t};\n}",
kind: Snippet,
},
CompletionItem {
label: "pub(crate)",
source_range: [78; 78),
delete: [78; 78),
source_range: 78..78,
delete: 78..78,
insert: "pub(crate) $0",
kind: Snippet,
},

View file

@ -188,8 +188,7 @@ fn add_const_impl(
if let Some(const_name) = const_name {
let snippet = make_const_compl_syntax(&const_.source(ctx.db).value);
let range =
TextRange::new(const_def_node.text_range().start(), ctx.source_range().end());
let range = TextRange::new(const_def_node.text_range().start(), ctx.source_range().end());
CompletionItem::new(CompletionKind::Magic, ctx.source_range(), snippet.clone())
.text_edit(TextEdit::replace(range, snippet))
@ -254,24 +253,24 @@ mod tests {
[
CompletionItem {
label: "const TEST_CONST: u16 = ",
source_range: [209; 210),
delete: [209; 210),
source_range: 209..210,
delete: 209..210,
insert: "const TEST_CONST: u16 = ",
kind: Const,
lookup: "TEST_CONST",
},
CompletionItem {
label: "fn test()",
source_range: [209; 210),
delete: [209; 210),
source_range: 209..210,
delete: 209..210,
insert: "fn test() {\n $0\n}",
kind: Function,
lookup: "test",
},
CompletionItem {
label: "type TestType = ",
source_range: [209; 210),
delete: [209; 210),
source_range: 209..210,
delete: 209..210,
insert: "type TestType = ",
kind: TypeAlias,
lookup: "TestType",
@ -320,8 +319,8 @@ mod tests {
[
CompletionItem {
label: "fn test()",
source_range: [139; 140),
delete: [139; 140),
source_range: 139..140,
delete: 139..140,
insert: "fn test() {\n $0\n}",
kind: Function,
lookup: "test",
@ -349,8 +348,8 @@ mod tests {
[
CompletionItem {
label: "fn foo()",
source_range: [141; 142),
delete: [138; 142),
source_range: 141..142,
delete: 138..142,
insert: "fn foo() {\n $0\n}",
kind: Function,
lookup: "foo",
@ -381,8 +380,8 @@ mod tests {
[
CompletionItem {
label: "fn foo_bar()",
source_range: [200; 201),
delete: [197; 201),
source_range: 200..201,
delete: 197..201,
insert: "fn foo_bar() {\n $0\n}",
kind: Function,
lookup: "foo_bar",
@ -432,8 +431,8 @@ mod tests {
[
CompletionItem {
label: "fn foo()",
source_range: [144; 145),
delete: [141; 145),
source_range: 144..145,
delete: 141..145,
insert: "fn foo<T>() {\n $0\n}",
kind: Function,
lookup: "foo",
@ -461,8 +460,8 @@ mod tests {
[
CompletionItem {
label: "fn foo()",
source_range: [166; 167),
delete: [163; 167),
source_range: 166..167,
delete: 163..167,
insert: "fn foo<T>()\nwhere T: Into<String> {\n $0\n}",
kind: Function,
lookup: "foo",
@ -488,8 +487,8 @@ mod tests {
[
CompletionItem {
label: "type SomeType = ",
source_range: [124; 125),
delete: [119; 125),
source_range: 124..125,
delete: 119..125,
insert: "type SomeType = ",
kind: TypeAlias,
lookup: "SomeType",
@ -515,8 +514,8 @@ mod tests {
[
CompletionItem {
label: "const SOME_CONST: u16 = ",
source_range: [133; 134),
delete: [127; 134),
source_range: 133..134,
delete: 127..134,
insert: "const SOME_CONST: u16 = ",
kind: Const,
lookup: "SOME_CONST",
@ -542,8 +541,8 @@ mod tests {
[
CompletionItem {
label: "const SOME_CONST: u16 = ",
source_range: [138; 139),
delete: [132; 139),
source_range: 138..139,
delete: 132..139,
insert: "const SOME_CONST: u16 = ",
kind: Const,
lookup: "SOME_CONST",

View file

@ -85,8 +85,8 @@ mod tests {
[
CompletionItem {
label: "collections",
source_range: [21; 24),
delete: [21; 24),
source_range: 21..24,
delete: 21..24,
insert: "collections",
},
]
@ -157,8 +157,8 @@ mod tests {
[
CompletionItem {
label: "Enum",
source_range: [231; 233),
delete: [231; 233),
source_range: 231..233,
delete: 231..233,
insert: "Enum",
kind: Enum,
},
@ -183,8 +183,8 @@ mod tests {
[
CompletionItem {
label: "quux(…)",
source_range: [91; 91),
delete: [91; 91),
source_range: 91..91,
delete: 91..91,
insert: "quux(${1:x})$0",
kind: Function,
lookup: "quux",
@ -193,16 +193,16 @@ mod tests {
},
CompletionItem {
label: "x",
source_range: [91; 91),
delete: [91; 91),
source_range: 91..91,
delete: 91..91,
insert: "x",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "y",
source_range: [91; 91),
delete: [91; 91),
source_range: 91..91,
delete: 91..91,
insert: "y",
kind: Binding,
detail: "i32",
@ -232,23 +232,23 @@ mod tests {
[
CompletionItem {
label: "a",
source_range: [242; 242),
delete: [242; 242),
source_range: 242..242,
delete: 242..242,
insert: "a",
kind: Binding,
},
CompletionItem {
label: "b",
source_range: [242; 242),
delete: [242; 242),
source_range: 242..242,
delete: 242..242,
insert: "b",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "quux()",
source_range: [242; 242),
delete: [242; 242),
source_range: 242..242,
delete: 242..242,
insert: "quux()$0",
kind: Function,
lookup: "quux",
@ -275,8 +275,8 @@ mod tests {
[
CompletionItem {
label: "quux()",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "quux()$0",
kind: Function,
lookup: "quux",
@ -284,8 +284,8 @@ mod tests {
},
CompletionItem {
label: "x",
source_range: [95; 95),
delete: [95; 95),
source_range: 95..95,
delete: 95..95,
insert: "x",
kind: Binding,
},
@ -308,15 +308,15 @@ mod tests {
[
CompletionItem {
label: "T",
source_range: [52; 52),
delete: [52; 52),
source_range: 52..52,
delete: 52..52,
insert: "T",
kind: TypeParam,
},
CompletionItem {
label: "quux()",
source_range: [52; 52),
delete: [52; 52),
source_range: 52..52,
delete: 52..52,
insert: "quux()$0",
kind: Function,
lookup: "quux",
@ -341,22 +341,22 @@ mod tests {
[
CompletionItem {
label: "Self",
source_range: [54; 54),
delete: [54; 54),
source_range: 54..54,
delete: 54..54,
insert: "Self",
kind: TypeParam,
},
CompletionItem {
label: "T",
source_range: [54; 54),
delete: [54; 54),
source_range: 54..54,
delete: 54..54,
insert: "T",
kind: TypeParam,
},
CompletionItem {
label: "X<…>",
source_range: [54; 54),
delete: [54; 54),
source_range: 54..54,
delete: 54..54,
insert: "X<$0>",
kind: Struct,
lookup: "X",
@ -380,15 +380,15 @@ mod tests {
[
CompletionItem {
label: "Self",
source_range: [48; 48),
delete: [48; 48),
source_range: 48..48,
delete: 48..48,
insert: "Self",
kind: TypeParam,
},
CompletionItem {
label: "X",
source_range: [48; 48),
delete: [48; 48),
source_range: 48..48,
delete: 48..48,
insert: "X",
kind: Enum,
},
@ -413,22 +413,22 @@ mod tests {
[
CompletionItem {
label: "Baz",
source_range: [105; 105),
delete: [105; 105),
source_range: 105..105,
delete: 105..105,
insert: "Baz",
kind: Enum,
},
CompletionItem {
label: "Foo",
source_range: [105; 105),
delete: [105; 105),
source_range: 105..105,
delete: 105..105,
insert: "Foo",
kind: Struct,
},
CompletionItem {
label: "quux()",
source_range: [105; 105),
delete: [105; 105),
source_range: 105..105,
delete: 105..105,
insert: "quux()$0",
kind: Function,
lookup: "quux",
@ -455,8 +455,8 @@ mod tests {
[
CompletionItem {
label: "other_crate",
source_range: [4; 4),
delete: [4; 4),
source_range: 4..4,
delete: 4..4,
insert: "other_crate",
kind: Module,
},
@ -481,15 +481,15 @@ mod tests {
[
CompletionItem {
label: "Bar",
source_range: [117; 117),
delete: [117; 117),
source_range: 117..117,
delete: 117..117,
insert: "Bar",
kind: Struct,
},
CompletionItem {
label: "quux()",
source_range: [117; 117),
delete: [117; 117),
source_range: 117..117,
delete: 117..117,
insert: "quux()$0",
kind: Function,
lookup: "quux",
@ -513,15 +513,15 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [55; 55),
delete: [55; 55),
source_range: 55..55,
delete: 55..55,
insert: "Foo",
kind: Struct,
},
CompletionItem {
label: "x()",
source_range: [55; 55),
delete: [55; 55),
source_range: 55..55,
delete: 55..55,
insert: "x()$0",
kind: Function,
lookup: "x",
@ -550,16 +550,16 @@ mod tests {
[
CompletionItem {
label: "bar",
source_range: [146; 146),
delete: [146; 146),
source_range: 146..146,
delete: 146..146,
insert: "bar",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "foo()",
source_range: [146; 146),
delete: [146; 146),
source_range: 146..146,
delete: 146..146,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -578,15 +578,15 @@ mod tests {
[
CompletionItem {
label: "Self",
source_range: [25; 25),
delete: [25; 25),
source_range: 25..25,
delete: 25..25,
insert: "Self",
kind: TypeParam,
},
CompletionItem {
label: "self",
source_range: [25; 25),
delete: [25; 25),
source_range: 25..25,
delete: 25..25,
insert: "self",
kind: Binding,
detail: "&{unknown}",
@ -617,15 +617,15 @@ mod tests {
[
CompletionItem {
label: "Option",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "Option",
kind: Struct,
},
CompletionItem {
label: "foo()",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -633,8 +633,8 @@ mod tests {
},
CompletionItem {
label: "std",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "std",
kind: Module,
},
@ -672,22 +672,22 @@ mod tests {
[
CompletionItem {
label: "String",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "String",
kind: Struct,
},
CompletionItem {
label: "core",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "core",
kind: Module,
},
CompletionItem {
label: "foo()",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -695,8 +695,8 @@ mod tests {
},
CompletionItem {
label: "std",
source_range: [18; 18),
delete: [18; 18),
source_range: 18..18,
delete: 18..18,
insert: "std",
kind: Module,
},
@ -742,46 +742,46 @@ mod tests {
[
CompletionItem {
label: "bar!(…)",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "bar!($0)",
kind: Macro,
detail: "macro_rules! bar",
},
CompletionItem {
label: "baz!(…)",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "baz!($0)",
kind: Macro,
detail: "#[macro_export]\nmacro_rules! baz",
},
CompletionItem {
label: "foo!(…)",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "foo!($0)",
kind: Macro,
detail: "macro_rules! foo",
},
CompletionItem {
label: "m1",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "m1",
kind: Module,
},
CompletionItem {
label: "m2",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "m2",
kind: Module,
},
CompletionItem {
label: "main()",
source_range: [252; 252),
delete: [252; 252),
source_range: 252..252,
delete: 252..252,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -811,16 +811,16 @@ mod tests {
[
CompletionItem {
label: "foo!(…)",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "foo!($0)",
kind: Macro,
detail: "macro_rules! foo",
},
CompletionItem {
label: "foo()",
source_range: [49; 49),
delete: [49; 49),
source_range: 49..49,
delete: 49..49,
insert: "foo()$0",
kind: Function,
lookup: "foo",
@ -850,16 +850,16 @@ mod tests {
[
CompletionItem {
label: "foo!(…)",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "foo!($0)",
kind: Macro,
detail: "macro_rules! foo",
},
CompletionItem {
label: "main()",
source_range: [57; 57),
delete: [57; 57),
source_range: 57..57,
delete: 57..57,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -889,16 +889,16 @@ mod tests {
[
CompletionItem {
label: "foo!(…)",
source_range: [50; 50),
delete: [50; 50),
source_range: 50..50,
delete: 50..50,
insert: "foo!($0)",
kind: Macro,
detail: "macro_rules! foo",
},
CompletionItem {
label: "main()",
source_range: [50; 50),
delete: [50; 50),
source_range: 50..50,
delete: 50..50,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -925,8 +925,8 @@ mod tests {
[
CompletionItem {
label: "frobnicate()",
source_range: [23; 24),
delete: [23; 24),
source_range: 23..24,
delete: 23..24,
insert: "frobnicate()$0",
kind: Function,
lookup: "frobnicate",
@ -934,8 +934,8 @@ mod tests {
},
CompletionItem {
label: "main()",
source_range: [23; 24),
delete: [23; 24),
source_range: 23..24,
delete: 23..24,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -962,16 +962,16 @@ mod tests {
[
CompletionItem {
label: "m!(…)",
source_range: [145; 145),
delete: [145; 145),
source_range: 145..145,
delete: 145..145,
insert: "m!($0)",
kind: Macro,
detail: "macro_rules! m",
},
CompletionItem {
label: "quux(…)",
source_range: [145; 145),
delete: [145; 145),
source_range: 145..145,
delete: 145..145,
insert: "quux(${1:x})$0",
kind: Function,
lookup: "quux",
@ -980,16 +980,16 @@ mod tests {
},
CompletionItem {
label: "x",
source_range: [145; 145),
delete: [145; 145),
source_range: 145..145,
delete: 145..145,
insert: "x",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "y",
source_range: [145; 145),
delete: [145; 145),
source_range: 145..145,
delete: 145..145,
insert: "y",
kind: Binding,
detail: "i32",
@ -1015,16 +1015,16 @@ mod tests {
[
CompletionItem {
label: "m!(…)",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "m!($0)",
kind: Macro,
detail: "macro_rules! m",
},
CompletionItem {
label: "quux(…)",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "quux(${1:x})$0",
kind: Function,
lookup: "quux",
@ -1033,16 +1033,16 @@ mod tests {
},
CompletionItem {
label: "x",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "x",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "y",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "y",
kind: Binding,
detail: "i32",
@ -1068,16 +1068,16 @@ mod tests {
[
CompletionItem {
label: "m!(…)",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "m!($0)",
kind: Macro,
detail: "macro_rules! m",
},
CompletionItem {
label: "quux(…)",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "quux(${1:x})$0",
kind: Function,
lookup: "quux",
@ -1086,16 +1086,16 @@ mod tests {
},
CompletionItem {
label: "x",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "x",
kind: Binding,
detail: "i32",
},
CompletionItem {
label: "y",
source_range: [145; 146),
delete: [145; 146),
source_range: 145..146,
delete: 145..146,
insert: "y",
kind: Binding,
detail: "i32",
@ -1121,14 +1121,14 @@ mod tests {
[
CompletionItem {
label: "Quux",
source_range: [82; 82),
delete: [82; 82),
source_range: 82..82,
delete: 82..82,
insert: "Quux",
},
CompletionItem {
label: "main()",
source_range: [82; 82),
delete: [82; 82),
source_range: 82..82,
delete: 82..82,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -1162,31 +1162,31 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [248; 250),
delete: [248; 250),
source_range: 248..250,
delete: 248..250,
insert: "Foo",
kind: Enum,
},
CompletionItem {
label: "Foo::Bar",
source_range: [248; 250),
delete: [248; 250),
source_range: 248..250,
delete: 248..250,
insert: "Foo::Bar",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Baz",
source_range: [248; 250),
delete: [248; 250),
source_range: 248..250,
delete: 248..250,
insert: "Foo::Baz",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Quux",
source_range: [248; 250),
delete: [248; 250),
source_range: 248..250,
delete: 248..250,
insert: "Foo::Quux",
kind: EnumVariant,
detail: "()",
@ -1220,31 +1220,31 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [219; 221),
delete: [219; 221),
source_range: 219..221,
delete: 219..221,
insert: "Foo",
kind: Enum,
},
CompletionItem {
label: "Foo::Bar",
source_range: [219; 221),
delete: [219; 221),
source_range: 219..221,
delete: 219..221,
insert: "Foo::Bar",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Baz",
source_range: [219; 221),
delete: [219; 221),
source_range: 219..221,
delete: 219..221,
insert: "Foo::Baz",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Quux",
source_range: [219; 221),
delete: [219; 221),
source_range: 219..221,
delete: 219..221,
insert: "Foo::Quux",
kind: EnumVariant,
detail: "()",
@ -1274,39 +1274,39 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [185; 186),
delete: [185; 186),
source_range: 185..186,
delete: 185..186,
insert: "Foo",
kind: Enum,
},
CompletionItem {
label: "Foo::Bar",
source_range: [185; 186),
delete: [185; 186),
source_range: 185..186,
delete: 185..186,
insert: "Foo::Bar",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Baz",
source_range: [185; 186),
delete: [185; 186),
source_range: 185..186,
delete: 185..186,
insert: "Foo::Baz",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Foo::Quux",
source_range: [185; 186),
delete: [185; 186),
source_range: 185..186,
delete: 185..186,
insert: "Foo::Quux",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "main()",
source_range: [185; 186),
delete: [185; 186),
source_range: 185..186,
delete: 185..186,
insert: "main()$0",
kind: Function,
lookup: "main",

View file

@ -452,8 +452,8 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [121; 123),
delete: [121; 123),
source_range: 121..123,
delete: 121..123,
insert: "Foo",
kind: EnumVariant,
detail: "{ x: i32, y: i32 }",
@ -478,8 +478,8 @@ mod tests {
[
CompletionItem {
label: "Foo(…)",
source_range: [115; 117),
delete: [115; 117),
source_range: 115..117,
delete: 115..117,
insert: "Foo($0)",
kind: EnumVariant,
lookup: "Foo",
@ -506,8 +506,8 @@ mod tests {
[
CompletionItem {
label: "Foo",
source_range: [104; 106),
delete: [104; 106),
source_range: 104..106,
delete: 104..106,
insert: "Foo",
kind: EnumVariant,
detail: "()",
@ -534,8 +534,8 @@ mod tests {
[
CompletionItem {
label: "main()",
source_range: [203; 206),
delete: [203; 206),
source_range: 203..206,
delete: 203..206,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -543,8 +543,8 @@ mod tests {
},
CompletionItem {
label: "something_deprecated()",
source_range: [203; 206),
delete: [203; 206),
source_range: 203..206,
delete: 203..206,
insert: "something_deprecated()$0",
kind: Function,
lookup: "something_deprecated",
@ -553,8 +553,8 @@ mod tests {
},
CompletionItem {
label: "something_else_deprecated()",
source_range: [203; 206),
delete: [203; 206),
source_range: 203..206,
delete: 203..206,
insert: "something_else_deprecated()$0",
kind: Function,
lookup: "something_else_deprecated",
@ -580,8 +580,8 @@ mod tests {
[
CompletionItem {
label: "main()",
source_range: [61; 64),
delete: [61; 64),
source_range: 61..64,
delete: 61..64,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -589,8 +589,8 @@ mod tests {
},
CompletionItem {
label: "no_args()",
source_range: [61; 64),
delete: [61; 64),
source_range: 61..64,
delete: 61..64,
insert: "no_args()$0",
kind: Function,
lookup: "no_args",
@ -610,8 +610,8 @@ mod tests {
[
CompletionItem {
label: "main()",
source_range: [80; 85),
delete: [80; 85),
source_range: 80..85,
delete: 80..85,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -619,8 +619,8 @@ mod tests {
},
CompletionItem {
label: "with_args(…)",
source_range: [80; 85),
delete: [80; 85),
source_range: 80..85,
delete: 80..85,
insert: "with_args(${1:x}, ${2:y})$0",
kind: Function,
lookup: "with_args",
@ -646,8 +646,8 @@ mod tests {
[
CompletionItem {
label: "foo()",
source_range: [163; 164),
delete: [163; 164),
source_range: 163..164,
delete: 163..164,
insert: "foo()$0",
kind: Method,
lookup: "foo",
@ -674,23 +674,23 @@ mod tests {
[
CompletionItem {
label: "None",
source_range: [144; 147),
delete: [144; 147),
source_range: 144..147,
delete: 144..147,
insert: "None",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Option",
source_range: [144; 147),
delete: [144; 147),
source_range: 144..147,
delete: 144..147,
insert: "Option",
kind: Enum,
},
CompletionItem {
label: "Some(…)",
source_range: [144; 147),
delete: [144; 147),
source_range: 144..147,
delete: 144..147,
insert: "Some($0)",
kind: EnumVariant,
lookup: "Some",
@ -699,8 +699,8 @@ mod tests {
},
CompletionItem {
label: "main()",
source_range: [144; 147),
delete: [144; 147),
source_range: 144..147,
delete: 144..147,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -725,23 +725,23 @@ mod tests {
[
CompletionItem {
label: "None",
source_range: [185; 188),
delete: [185; 188),
source_range: 185..188,
delete: 185..188,
insert: "None",
kind: EnumVariant,
detail: "()",
},
CompletionItem {
label: "Option",
source_range: [185; 188),
delete: [185; 188),
source_range: 185..188,
delete: 185..188,
insert: "Option",
kind: Enum,
},
CompletionItem {
label: "Some(…)",
source_range: [185; 188),
delete: [185; 188),
source_range: 185..188,
delete: 185..188,
insert: "Some($0)",
kind: EnumVariant,
lookup: "Some",
@ -771,8 +771,8 @@ mod tests {
[
CompletionItem {
label: "foo(…)",
source_range: [171; 172),
delete: [171; 172),
source_range: 171..172,
delete: 171..172,
insert: "foo(${1:x})$0",
kind: Method,
lookup: "foo",
@ -806,8 +806,8 @@ mod tests {
[
CompletionItem {
label: "foo(…)",
source_range: [171; 172),
delete: [171; 172),
source_range: 171..172,
delete: 171..172,
insert: "foo($0)",
kind: Method,
lookup: "foo",
@ -833,8 +833,8 @@ mod tests {
[
CompletionItem {
label: "foo",
source_range: [40; 41),
delete: [40; 41),
source_range: 40..41,
delete: 40..41,
insert: "foo",
kind: Function,
detail: "pub fn foo()",
@ -860,16 +860,16 @@ mod tests {
[
CompletionItem {
label: "frobnicate",
source_range: [35; 39),
delete: [35; 39),
source_range: 35..39,
delete: 35..39,
insert: "frobnicate",
kind: Function,
detail: "fn frobnicate()",
},
CompletionItem {
label: "main",
source_range: [35; 39),
delete: [35; 39),
source_range: 35..39,
delete: 35..39,
insert: "main",
kind: Function,
detail: "fn main()",
@ -892,8 +892,8 @@ mod tests {
[
CompletionItem {
label: "new",
source_range: [67; 69),
delete: [67; 69),
source_range: 67..69,
delete: 67..69,
insert: "new",
kind: Function,
detail: "fn new() -> Foo",
@ -917,16 +917,16 @@ mod tests {
[
CompletionItem {
label: "Vec<…>",
source_range: [61; 63),
delete: [61; 63),
source_range: 61..63,
delete: 61..63,
insert: "Vec<$0>",
kind: Struct,
lookup: "Vec",
},
CompletionItem {
label: "foo(…)",
source_range: [61; 63),
delete: [61; 63),
source_range: 61..63,
delete: 61..63,
insert: "foo(${1:xs})$0",
kind: Function,
lookup: "foo",
@ -947,16 +947,16 @@ mod tests {
[
CompletionItem {
label: "Vec<…>",
source_range: [64; 66),
delete: [64; 66),
source_range: 64..66,
delete: 64..66,
insert: "Vec<$0>",
kind: TypeAlias,
lookup: "Vec",
},
CompletionItem {
label: "foo(…)",
source_range: [64; 66),
delete: [64; 66),
source_range: 64..66,
delete: 64..66,
insert: "foo(${1:xs})$0",
kind: Function,
lookup: "foo",
@ -977,15 +977,15 @@ mod tests {
[
CompletionItem {
label: "Vec",
source_range: [68; 70),
delete: [68; 70),
source_range: 68..70,
delete: 68..70,
insert: "Vec",
kind: Struct,
},
CompletionItem {
label: "foo(…)",
source_range: [68; 70),
delete: [68; 70),
source_range: 68..70,
delete: 68..70,
insert: "foo(${1:xs})$0",
kind: Function,
lookup: "foo",
@ -1006,15 +1006,15 @@ mod tests {
[
CompletionItem {
label: "Vec",
source_range: [61; 63),
delete: [61; 63),
source_range: 61..63,
delete: 61..63,
insert: "Vec",
kind: Struct,
},
CompletionItem {
label: "foo(…)",
source_range: [61; 63),
delete: [61; 63),
source_range: 61..63,
delete: 61..63,
insert: "foo(${1:xs})$0",
kind: Function,
lookup: "foo",
@ -1046,8 +1046,8 @@ mod tests {
[
CompletionItem {
label: "frobnicate!",
source_range: [9; 9),
delete: [9; 9),
source_range: 9..9,
delete: 9..9,
insert: "frobnicate",
kind: Macro,
detail: "#[macro_export]\nmacro_rules! frobnicate",
@ -1072,16 +1072,16 @@ mod tests {
[
CompletionItem {
label: "frobnicate!",
source_range: [56; 60),
delete: [56; 60),
source_range: 56..60,
delete: 56..60,
insert: "frobnicate",
kind: Macro,
detail: "macro_rules! frobnicate",
},
CompletionItem {
label: "main()",
source_range: [56; 60),
delete: [56; 60),
source_range: 56..60,
delete: 56..60,
insert: "main()$0",
kind: Function,
lookup: "main",
@ -1109,24 +1109,24 @@ mod tests {
[
CompletionItem {
label: "another_field",
source_range: [201; 201),
delete: [201; 201),
source_range: 201..201,
delete: 201..201,
insert: "another_field",
kind: Field,
detail: "i64",
},
CompletionItem {
label: "my_string",
source_range: [201; 201),
delete: [201; 201),
source_range: 201..201,
delete: 201..201,
insert: "my_string",
kind: Field,
detail: "{unknown}",
},
CompletionItem {
label: "the_field",
source_range: [201; 201),
delete: [201; 201),
source_range: 201..201,
delete: 201..201,
insert: "the_field",
kind: Field,
detail: "u32",
@ -1153,16 +1153,16 @@ mod tests {
[
CompletionItem {
label: "another_field",
source_range: [208; 208),
delete: [208; 208),
source_range: 208..208,
delete: 208..208,
insert: "another_field",
kind: Field,
detail: "i64",
},
CompletionItem {
label: "another_good_type",
source_range: [208; 208),
delete: [208; 208),
source_range: 208..208,
delete: 208..208,
insert: "another_good_type",
kind: Field,
detail: "u32",
@ -1170,8 +1170,8 @@ mod tests {
},
CompletionItem {
label: "the_field",
source_range: [208; 208),
delete: [208; 208),
source_range: 208..208,
delete: 208..208,
insert: "the_field",
kind: Field,
detail: "u32",
@ -1201,16 +1201,16 @@ mod tests {
[
CompletionItem {
label: "another_field",
source_range: [270; 270),
delete: [270; 270),
source_range: 270..270,
delete: 270..270,
insert: "another_field",
kind: Field,
detail: "i64",
},
CompletionItem {
label: "another_good_type",
source_range: [270; 270),
delete: [270; 270),
source_range: 270..270,
delete: 270..270,
insert: "another_good_type",
kind: Field,
detail: "u32",
@ -1218,8 +1218,8 @@ mod tests {
},
CompletionItem {
label: "the_field",
source_range: [270; 270),
delete: [270; 270),
source_range: 270..270,
delete: 270..270,
insert: "the_field",
kind: Field,
detail: "u32",
@ -1249,8 +1249,8 @@ mod tests {
[
CompletionItem {
label: "another_field",
source_range: [336; 336),
delete: [336; 336),
source_range: 336..336,
delete: 336..336,
insert: "another_field",
kind: Field,
detail: "i64",
@ -1258,16 +1258,16 @@ mod tests {
},
CompletionItem {
label: "another_good_type",
source_range: [336; 336),
delete: [336; 336),
source_range: 336..336,
delete: 336..336,
insert: "another_good_type",
kind: Field,
detail: "u32",
},
CompletionItem {
label: "the_field",
source_range: [336; 336),
delete: [336; 336),
source_range: 336..336,
delete: 336..336,
insert: "the_field",
kind: Field,
detail: "u32",
@ -1296,16 +1296,16 @@ mod tests {
[
CompletionItem {
label: "another_field",
source_range: [328; 328),
delete: [328; 328),
source_range: 328..328,
delete: 328..328,
insert: "another_field",
kind: Field,
detail: "i64",
},
CompletionItem {
label: "another_good_type",
source_range: [328; 328),
delete: [328; 328),
source_range: 328..328,
delete: 328..328,
insert: "another_good_type",
kind: Field,
detail: "u32",
@ -1313,8 +1313,8 @@ mod tests {
},
CompletionItem {
label: "the_field",
source_range: [328; 328),
delete: [328; 328),
source_range: 328..328,
delete: 328..328,
insert: "the_field",
kind: Field,
detail: "u32",

View file

@ -277,7 +277,7 @@ mod tests {
assert!(
diagnostic.range.start() <= file_position.offset
&& diagnostic.range.end() >= file_position.offset,
"diagnostic range {} does not touch cursor position {}",
"diagnostic range {:?} does not touch cursor position {:?}",
diagnostic.range,
file_position.offset
);
@ -603,7 +603,7 @@ mod tests {
[
Diagnostic {
message: "unresolved module",
range: [0; 8),
range: 0..8,
fix: Some(
SourceChange {
label: "create module",
@ -652,7 +652,7 @@ mod tests {
[
Diagnostic {
message: "Missing structure fields:\n- b",
range: [224; 233),
range: 224..233,
fix: Some(
SourceChange {
label: "fill struct fields",
@ -664,7 +664,7 @@ mod tests {
edit: TextEdit {
atoms: [
AtomTextEdit {
delete: [3; 9),
delete: 3..9,
insert: "{a:42, b: ()}",
},
],

View file

@ -224,8 +224,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "Foo",
navigation_range: [8; 11),
node_range: [1; 26),
navigation_range: 8..11,
node_range: 1..26,
kind: STRUCT_DEF,
detail: None,
deprecated: false,
@ -235,8 +235,8 @@ fn very_obsolete() {}
0,
),
label: "x",
navigation_range: [18; 19),
node_range: [18; 24),
navigation_range: 18..19,
node_range: 18..24,
kind: RECORD_FIELD_DEF,
detail: Some(
"i32",
@ -246,8 +246,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "m",
navigation_range: [32; 33),
node_range: [28; 158),
navigation_range: 32..33,
node_range: 28..158,
kind: MODULE,
detail: None,
deprecated: false,
@ -257,8 +257,8 @@ fn very_obsolete() {}
2,
),
label: "bar1",
navigation_range: [43; 47),
node_range: [40; 52),
navigation_range: 43..47,
node_range: 40..52,
kind: FN_DEF,
detail: Some(
"fn()",
@ -270,8 +270,8 @@ fn very_obsolete() {}
2,
),
label: "bar2",
navigation_range: [60; 64),
node_range: [57; 81),
navigation_range: 60..64,
node_range: 57..81,
kind: FN_DEF,
detail: Some(
"fn<T>(t: T) -> T",
@ -283,8 +283,8 @@ fn very_obsolete() {}
2,
),
label: "bar3",
navigation_range: [89; 93),
node_range: [86; 156),
navigation_range: 89..93,
node_range: 86..156,
kind: FN_DEF,
detail: Some(
"fn<A, B>(a: A, b: B) -> Vec< u32 >",
@ -294,8 +294,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "E",
navigation_range: [165; 166),
node_range: [160; 180),
navigation_range: 165..166,
node_range: 160..180,
kind: ENUM_DEF,
detail: None,
deprecated: false,
@ -305,8 +305,8 @@ fn very_obsolete() {}
6,
),
label: "X",
navigation_range: [169; 170),
node_range: [169; 170),
navigation_range: 169..170,
node_range: 169..170,
kind: ENUM_VARIANT,
detail: None,
deprecated: false,
@ -316,8 +316,8 @@ fn very_obsolete() {}
6,
),
label: "Y",
navigation_range: [172; 173),
node_range: [172; 178),
navigation_range: 172..173,
node_range: 172..178,
kind: ENUM_VARIANT,
detail: None,
deprecated: false,
@ -325,8 +325,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "T",
navigation_range: [186; 187),
node_range: [181; 193),
navigation_range: 186..187,
node_range: 181..193,
kind: TYPE_ALIAS_DEF,
detail: Some(
"()",
@ -336,8 +336,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "S",
navigation_range: [201; 202),
node_range: [194; 213),
navigation_range: 201..202,
node_range: 194..213,
kind: STATIC_DEF,
detail: Some(
"i32",
@ -347,8 +347,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "C",
navigation_range: [220; 221),
node_range: [214; 232),
navigation_range: 220..221,
node_range: 214..232,
kind: CONST_DEF,
detail: Some(
"i32",
@ -358,8 +358,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "impl E",
navigation_range: [239; 240),
node_range: [234; 243),
navigation_range: 239..240,
node_range: 234..243,
kind: IMPL_DEF,
detail: None,
deprecated: false,
@ -367,8 +367,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "impl fmt::Debug for E",
navigation_range: [265; 266),
node_range: [245; 269),
navigation_range: 265..266,
node_range: 245..269,
kind: IMPL_DEF,
detail: None,
deprecated: false,
@ -376,8 +376,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "mc",
navigation_range: [284; 286),
node_range: [271; 303),
navigation_range: 284..286,
node_range: 271..303,
kind: MACRO_CALL,
detail: None,
deprecated: false,
@ -385,8 +385,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "mcexp",
navigation_range: [334; 339),
node_range: [305; 356),
navigation_range: 334..339,
node_range: 305..356,
kind: MACRO_CALL,
detail: None,
deprecated: false,
@ -394,8 +394,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "mcexp",
navigation_range: [387; 392),
node_range: [358; 409),
navigation_range: 387..392,
node_range: 358..409,
kind: MACRO_CALL,
detail: None,
deprecated: false,
@ -403,8 +403,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "obsolete",
navigation_range: [428; 436),
node_range: [411; 441),
navigation_range: 428..436,
node_range: 411..441,
kind: FN_DEF,
detail: Some(
"fn()",
@ -414,8 +414,8 @@ fn very_obsolete() {}
StructureNode {
parent: None,
label: "very_obsolete",
navigation_range: [481; 494),
node_range: [443; 499),
navigation_range: 481..494,
node_range: 443..499,
kind: FN_DEF,
detail: Some(
"fn()",

View file

@ -316,7 +316,7 @@ mod tests {
fn do_check(before: &str, afters: &[&str]) {
let (cursor, before) = extract_offset(before);
let (analysis, file_id) = single_file(&before);
let range = TextRange::offset_len(cursor, 0.into());
let range = TextRange::empty(cursor);
let mut frange = FileRange { file_id, range };
for &after in afters {

View file

@ -187,10 +187,7 @@ fn contiguous_range_for_comment(
}
if first != last {
Some(TextRange::new(
first.syntax().text_range().start(),
last.syntax().text_range().end(),
))
Some(TextRange::new(first.syntax().text_range().start(), last.syntax().text_range().end()))
} else {
// The group consists of only one element, therefore it cannot be folded
None

View file

@ -140,7 +140,7 @@ mod tests {
struct Foo;
enum E { X(Foo<|>) }
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
"struct Foo;|Foo",
);
}
@ -153,7 +153,7 @@ mod tests {
struct Foo;
enum E { X(<|>Foo) }
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
"struct Foo;|Foo",
);
}
@ -174,7 +174,7 @@ mod tests {
//- /b.rs
struct Foo;
",
"Foo STRUCT_DEF FileId(2) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(2) 0..11 7..10",
"struct Foo;|Foo",
);
}
@ -189,7 +189,7 @@ mod tests {
//- /foo.rs
// empty
",
"foo SOURCE_FILE FileId(2) [0; 10)",
"foo SOURCE_FILE FileId(2) 0..10",
"// empty\n\n",
);
@ -201,7 +201,7 @@ mod tests {
//- /foo/mod.rs
// empty
",
"foo SOURCE_FILE FileId(2) [0; 10)",
"foo SOURCE_FILE FileId(2) 0..10",
"// empty\n\n",
);
}
@ -218,7 +218,7 @@ mod tests {
<|>foo!();
}
",
"foo MACRO_CALL FileId(1) [0; 33) [13; 16)",
"foo MACRO_CALL FileId(1) 0..33 13..16",
"macro_rules! foo { () => { () } }|foo",
);
}
@ -238,7 +238,7 @@ mod tests {
#[macro_export]
macro_rules! foo { () => { () } }
",
"foo MACRO_CALL FileId(2) [0; 49) [29; 32)",
"foo MACRO_CALL FileId(2) 0..49 29..32",
"#[macro_export]\nmacro_rules! foo { () => { () } }|foo",
);
}
@ -254,7 +254,7 @@ mod tests {
#[macro_export]
macro_rules! foo { () => { () } }
",
"foo MACRO_CALL FileId(2) [0; 49) [29; 32)",
"foo MACRO_CALL FileId(2) 0..49 29..32",
"#[macro_export]\nmacro_rules! foo { () => { () } }|foo",
);
}
@ -274,7 +274,7 @@ mod tests {
<|>foo();
}
",
"foo FN_DEF FileId(1) [64; 80) [75; 78)",
"foo FN_DEF FileId(1) 64..80 75..78",
"define_fn!(foo);|foo",
);
}
@ -294,7 +294,7 @@ mod tests {
<|>foo();
}
",
"foo FN_DEF FileId(1) [51; 64) [51; 64)",
"foo FN_DEF FileId(1) 51..64 51..64",
"define_fn!();|define_fn!();",
);
}
@ -312,7 +312,7 @@ mod tests {
}
}
",
"foo MACRO_CALL FileId(1) [0; 28) [13; 16)",
"foo MACRO_CALL FileId(1) 0..28 13..16",
"macro_rules! foo {() => {0}}|foo",
);
}
@ -330,7 +330,7 @@ mod tests {
}
}
",
"foo MACRO_CALL FileId(1) [0; 28) [13; 16)",
"foo MACRO_CALL FileId(1) 0..28 13..16",
"macro_rules! foo {() => {0}}|foo",
);
}
@ -350,7 +350,7 @@ mod tests {
foo.frobnicate<|>();
}
",
"frobnicate FN_DEF FileId(1) [27; 51) [30; 40)",
"frobnicate FN_DEF FileId(1) 27..51 30..40",
"fn frobnicate(&self) { }|frobnicate",
);
}
@ -369,7 +369,7 @@ mod tests {
foo.spam<|>;
}
",
"spam RECORD_FIELD_DEF FileId(1) [17; 26) [17; 21)",
"spam RECORD_FIELD_DEF FileId(1) 17..26 17..21",
"spam: u32|spam",
);
}
@ -390,7 +390,7 @@ mod tests {
}
}
",
"spam RECORD_FIELD_DEF FileId(1) [17; 26) [17; 21)",
"spam RECORD_FIELD_DEF FileId(1) 17..26 17..21",
"spam: u32|spam",
);
}
@ -409,7 +409,7 @@ mod tests {
let Foo { spam<|>: _, } = foo
}
",
"spam RECORD_FIELD_DEF FileId(1) [17; 26) [17; 21)",
"spam RECORD_FIELD_DEF FileId(1) 17..26 17..21",
"spam: u32|spam",
);
}
@ -426,7 +426,7 @@ mod tests {
Foo { spam<|>: m!() }
}
",
"spam RECORD_FIELD_DEF FileId(1) [45; 54) [45; 49)",
"spam RECORD_FIELD_DEF FileId(1) 45..54 45..49",
"spam: u32|spam",
);
}
@ -443,7 +443,7 @@ mod tests {
foo.<|>0;
}
",
"TUPLE_FIELD_DEF FileId(1) [11; 14)",
"TUPLE_FIELD_DEF FileId(1) 11..14",
"u32",
);
}
@ -462,7 +462,7 @@ mod tests {
Foo::frobnicate<|>();
}
",
"frobnicate FN_DEF FileId(1) [27; 46) [30; 40)",
"frobnicate FN_DEF FileId(1) 27..46 30..40",
"fn frobnicate() { }|frobnicate",
);
}
@ -480,7 +480,7 @@ mod tests {
Foo::frobnicate<|>();
}
",
"frobnicate FN_DEF FileId(1) [16; 32) [19; 29)",
"frobnicate FN_DEF FileId(1) 16..32 19..29",
"fn frobnicate();|frobnicate",
);
}
@ -500,7 +500,7 @@ mod tests {
Foo::frobnicate<|>();
}
",
"frobnicate FN_DEF FileId(1) [30; 46) [33; 43)",
"frobnicate FN_DEF FileId(1) 30..46 33..43",
"fn frobnicate();|frobnicate",
);
}
@ -517,7 +517,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [12; 73)",
"impl IMPL_DEF FileId(1) 12..73",
"impl Foo {...}",
);
@ -531,7 +531,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [12; 73)",
"impl IMPL_DEF FileId(1) 12..73",
"impl Foo {...}",
);
@ -545,7 +545,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [15; 75)",
"impl IMPL_DEF FileId(1) 15..75",
"impl Foo {...}",
);
@ -558,7 +558,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [15; 62)",
"impl IMPL_DEF FileId(1) 15..62",
"impl Foo {...}",
);
}
@ -578,7 +578,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [49; 115)",
"impl IMPL_DEF FileId(1) 49..115",
"impl Make for Foo {...}",
);
@ -595,7 +595,7 @@ mod tests {
}
}
",
"impl IMPL_DEF FileId(1) [49; 115)",
"impl IMPL_DEF FileId(1) 49..115",
"impl Make for Foo {...}",
);
}
@ -607,7 +607,7 @@ mod tests {
//- /lib.rs
struct Foo<|> { value: u32 }
",
"Foo STRUCT_DEF FileId(1) [0; 25) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..25 7..10",
"struct Foo { value: u32 }|Foo",
);
@ -618,7 +618,7 @@ mod tests {
field<|>: string,
}
"#,
"field RECORD_FIELD_DEF FileId(1) [17; 30) [17; 22)",
"field RECORD_FIELD_DEF FileId(1) 17..30 17..22",
"field: string|field",
);
@ -627,7 +627,7 @@ mod tests {
//- /lib.rs
fn foo_test<|>() { }
",
"foo_test FN_DEF FileId(1) [0; 17) [3; 11)",
"foo_test FN_DEF FileId(1) 0..17 3..11",
"fn foo_test() { }|foo_test",
);
@ -638,7 +638,7 @@ mod tests {
Variant,
}
",
"Foo ENUM_DEF FileId(1) [0; 25) [5; 8)",
"Foo ENUM_DEF FileId(1) 0..25 5..8",
"enum Foo {...}|Foo",
);
@ -651,7 +651,7 @@ mod tests {
Variant3,
}
",
"Variant2 ENUM_VARIANT FileId(1) [29; 37) [29; 37)",
"Variant2 ENUM_VARIANT FileId(1) 29..37 29..37",
"Variant2|Variant2",
);
@ -660,7 +660,7 @@ mod tests {
//- /lib.rs
static INNER<|>: &str = "";
"#,
"INNER STATIC_DEF FileId(1) [0; 24) [7; 12)",
"INNER STATIC_DEF FileId(1) 0..24 7..12",
"static INNER: &str = \"\";|INNER",
);
@ -669,7 +669,7 @@ mod tests {
//- /lib.rs
const INNER<|>: &str = "";
"#,
"INNER CONST_DEF FileId(1) [0; 23) [6; 11)",
"INNER CONST_DEF FileId(1) 0..23 6..11",
"const INNER: &str = \"\";|INNER",
);
@ -678,7 +678,7 @@ mod tests {
//- /lib.rs
type Thing<|> = Option<()>;
"#,
"Thing TYPE_ALIAS_DEF FileId(1) [0; 24) [5; 10)",
"Thing TYPE_ALIAS_DEF FileId(1) 0..24 5..10",
"type Thing = Option<()>;|Thing",
);
@ -687,7 +687,7 @@ mod tests {
//- /lib.rs
trait Foo<|> { }
"#,
"Foo TRAIT_DEF FileId(1) [0; 13) [6; 9)",
"Foo TRAIT_DEF FileId(1) 0..13 6..9",
"trait Foo { }|Foo",
);
@ -696,7 +696,7 @@ mod tests {
//- /lib.rs
mod bar<|> { }
"#,
"bar MODULE FileId(1) [0; 11) [4; 7)",
"bar MODULE FileId(1) 0..11 4..7",
"mod bar { }|bar",
);
}
@ -717,7 +717,7 @@ mod tests {
}
mod confuse_index { fn foo(); }
",
"foo FN_DEF FileId(1) [52; 63) [55; 58)",
"foo FN_DEF FileId(1) 52..63 55..58",
"fn foo() {}|foo",
);
}
@ -746,7 +746,7 @@ mod tests {
format!(\"{}\", fo<|>o())
}
",
"foo FN_DEF FileId(1) [398; 415) [401; 404)",
"foo FN_DEF FileId(1) 398..415 401..404",
"fn foo() -> i8 {}|foo",
);
}
@ -760,7 +760,7 @@ mod tests {
t: <|>T,
}
",
"T TYPE_PARAM FileId(1) [11; 12)",
"T TYPE_PARAM FileId(1) 11..12",
"T",
);
}
@ -782,7 +782,7 @@ mod tests {
});
}
",
"x BIND_PAT FileId(1) [69; 70)",
"x BIND_PAT FileId(1) 69..70",
"x",
);
@ -801,7 +801,7 @@ mod tests {
});
}
",
"y BIND_PAT FileId(1) [98; 99)",
"y BIND_PAT FileId(1) 98..99",
"y",
);
}
@ -818,7 +818,7 @@ mod tests {
}
}
",
"x BIND_PAT FileId(1) [39; 40)",
"x BIND_PAT FileId(1) 39..40",
"x",
);
}
@ -833,7 +833,7 @@ mod tests {
<|>foo!();
}
",
"foo MACRO_CALL FileId(1) [15; 48) [28; 31)",
"foo MACRO_CALL FileId(1) 15..48 28..31",
"macro_rules! foo { () => { () } }|foo",
);
}
@ -850,7 +850,7 @@ mod tests {
Foo { x<|> };
}
",
"x BIND_PAT FileId(1) [42; 43)",
"x BIND_PAT FileId(1) 42..43",
"x",
)
}

View file

@ -68,7 +68,7 @@ mod tests {
f<|>
}
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
);
}
@ -83,7 +83,7 @@ mod tests {
f<|>
}
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
);
}
@ -102,7 +102,7 @@ mod tests {
}
}
",
"Foo STRUCT_DEF FileId(1) [52; 65) [59; 62)",
"Foo STRUCT_DEF FileId(1) 52..65 59..62",
);
}
@ -114,7 +114,7 @@ mod tests {
struct Foo;
fn foo(<|>f: Foo) {}
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
);
}
@ -130,7 +130,7 @@ mod tests {
bar.<|>0;
}
",
"Foo STRUCT_DEF FileId(1) [0; 11) [7; 10)",
"Foo STRUCT_DEF FileId(1) 0..11 7..10",
);
}
}

View file

@ -86,7 +86,7 @@ mod tests {
struct Foo<|>;
impl Foo {}
",
&["impl IMPL_DEF FileId(1) [12; 23)"],
&["impl IMPL_DEF FileId(1) 12..23"],
);
}
@ -99,7 +99,7 @@ mod tests {
impl Foo {}
impl Foo {}
",
&["impl IMPL_DEF FileId(1) [12; 23)", "impl IMPL_DEF FileId(1) [24; 35)"],
&["impl IMPL_DEF FileId(1) 12..23", "impl IMPL_DEF FileId(1) 24..35"],
);
}
@ -116,7 +116,7 @@ mod tests {
impl super::Foo {}
}
",
&["impl IMPL_DEF FileId(1) [24; 42)", "impl IMPL_DEF FileId(1) [57; 75)"],
&["impl IMPL_DEF FileId(1) 24..42", "impl IMPL_DEF FileId(1) 57..75"],
);
}
@ -133,7 +133,7 @@ mod tests {
//- /b.rs
impl crate::Foo {}
",
&["impl IMPL_DEF FileId(2) [0; 18)", "impl IMPL_DEF FileId(3) [0; 18)"],
&["impl IMPL_DEF FileId(2) 0..18", "impl IMPL_DEF FileId(3) 0..18"],
);
}
@ -146,7 +146,7 @@ mod tests {
struct Foo;
impl T for Foo {}
",
&["impl IMPL_DEF FileId(1) [23; 40)"],
&["impl IMPL_DEF FileId(1) 23..40"],
);
}
@ -164,7 +164,7 @@ mod tests {
//- /b.rs
impl crate::T for crate::Foo {}
",
&["impl IMPL_DEF FileId(2) [0; 31)", "impl IMPL_DEF FileId(3) [0; 31)"],
&["impl IMPL_DEF FileId(2) 0..31", "impl IMPL_DEF FileId(3) 0..31"],
);
}
@ -180,9 +180,9 @@ mod tests {
impl T for &Foo {}
",
&[
"impl IMPL_DEF FileId(1) [23; 34)",
"impl IMPL_DEF FileId(1) [35; 52)",
"impl IMPL_DEF FileId(1) [53; 71)",
"impl IMPL_DEF FileId(1) 23..34",
"impl IMPL_DEF FileId(1) 35..52",
"impl IMPL_DEF FileId(1) 53..71",
],
);
}
@ -195,7 +195,7 @@ mod tests {
#[derive(Copy)]
struct Foo<|>;
",
&["impl IMPL_DEF FileId(1) [0; 15)"],
&["impl IMPL_DEF FileId(1) 0..15"],
);
}
}

View file

@ -322,12 +322,12 @@ mod tests {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig{ parameter_hints: true, type_hints: false, chaining_hints: false, max_length: None}).unwrap(), @r###"
[
InlayHint {
range: [106; 107),
range: 106..107,
kind: ParameterHint,
label: "a",
},
InlayHint {
range: [109; 110),
range: 109..110,
kind: ParameterHint,
label: "b",
},
@ -358,7 +358,7 @@ mod tests {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig{ type_hints: true, parameter_hints: false, chaining_hints: false, max_length: None}).unwrap(), @r###"
[
InlayHint {
range: [97; 99),
range: 97..99,
kind: TypeHint,
label: "i32",
},
@ -382,12 +382,12 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [69; 71),
range: 69..71,
kind: TypeHint,
label: "Test<i32>",
},
InlayHint {
range: [105; 111),
range: 105..111,
kind: TypeHint,
label: "&Test<i32>",
},
@ -439,57 +439,57 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [193; 197),
range: 193..197,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [236; 244),
range: 236..244,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [275; 279),
range: 275..279,
kind: TypeHint,
label: "&str",
},
InlayHint {
range: [539; 543),
range: 539..543,
kind: TypeHint,
label: "(i32, char)",
},
InlayHint {
range: [566; 567),
range: 566..567,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [570; 571),
range: 570..571,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [573; 574),
range: 573..574,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [577; 578),
range: 577..578,
kind: TypeHint,
label: "f64",
},
InlayHint {
range: [580; 581),
range: 580..581,
kind: TypeHint,
label: "f64",
},
InlayHint {
range: [584; 585),
range: 584..585,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [627; 628),
range: 627..628,
kind: TypeHint,
label: "i32",
},
@ -519,47 +519,47 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [21; 30),
range: 21..30,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [57; 66),
range: 57..66,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [115; 123),
range: 115..123,
kind: TypeHint,
label: "|…| -> i32",
},
InlayHint {
range: [127; 128),
range: 127..128,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [130; 131),
range: 130..131,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [133; 134),
range: 133..134,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [136; 137),
range: 136..137,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [201; 213),
range: 201..213,
kind: TypeHint,
label: "&|…| -> i32",
},
InlayHint {
range: [236; 245),
range: 236..245,
kind: TypeHint,
label: "|| -> i32",
},
@ -583,12 +583,12 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [21; 30),
range: 21..30,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [44; 53),
range: 44..53,
kind: TypeHint,
label: "i32",
},
@ -633,57 +633,57 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [188; 192),
range: 188..192,
kind: TypeHint,
label: "CustomOption<Test>",
},
InlayHint {
range: [267; 271),
range: 267..271,
kind: TypeHint,
label: "&CustomOption<Test>",
},
InlayHint {
range: [300; 304),
range: 300..304,
kind: TypeHint,
label: "&Test",
},
InlayHint {
range: [341; 342),
range: 341..342,
kind: TypeHint,
label: "&CustomOption<u32>",
},
InlayHint {
range: [344; 345),
range: 344..345,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [387; 388),
range: 387..388,
kind: TypeHint,
label: "&CustomOption<u32>",
},
InlayHint {
range: [393; 394),
range: 393..394,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [441; 442),
range: 441..442,
kind: TypeHint,
label: "&u32",
},
InlayHint {
range: [448; 449),
range: 448..449,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [500; 501),
range: 500..501,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [543; 544),
range: 543..544,
kind: TypeHint,
label: "&u8",
},
@ -728,57 +728,57 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [188; 192),
range: 188..192,
kind: TypeHint,
label: "CustomOption<Test>",
},
InlayHint {
range: [273; 277),
range: 273..277,
kind: TypeHint,
label: "&CustomOption<Test>",
},
InlayHint {
range: [309; 313),
range: 309..313,
kind: TypeHint,
label: "&Test",
},
InlayHint {
range: [353; 354),
range: 353..354,
kind: TypeHint,
label: "&CustomOption<u32>",
},
InlayHint {
range: [356; 357),
range: 356..357,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [402; 403),
range: 402..403,
kind: TypeHint,
label: "&CustomOption<u32>",
},
InlayHint {
range: [408; 409),
range: 408..409,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [459; 460),
range: 459..460,
kind: TypeHint,
label: "&u32",
},
InlayHint {
range: [466; 467),
range: 466..467,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [521; 522),
range: 521..522,
kind: TypeHint,
label: "&u8",
},
InlayHint {
range: [567; 568),
range: 567..568,
kind: TypeHint,
label: "&u8",
},
@ -823,52 +823,52 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [252; 256),
range: 252..256,
kind: TypeHint,
label: "CustomOption<Test>",
},
InlayHint {
range: [277; 281),
range: 277..281,
kind: TypeHint,
label: "Test",
},
InlayHint {
range: [310; 311),
range: 310..311,
kind: TypeHint,
label: "CustomOption<u32>",
},
InlayHint {
range: [313; 314),
range: 313..314,
kind: TypeHint,
label: "u8",
},
InlayHint {
range: [348; 349),
range: 348..349,
kind: TypeHint,
label: "CustomOption<u32>",
},
InlayHint {
range: [354; 355),
range: 354..355,
kind: TypeHint,
label: "u8",
},
InlayHint {
range: [394; 395),
range: 394..395,
kind: TypeHint,
label: "u32",
},
InlayHint {
range: [401; 402),
range: 401..402,
kind: TypeHint,
label: "u8",
},
InlayHint {
range: [445; 446),
range: 445..446,
kind: TypeHint,
label: "u8",
},
InlayHint {
range: [480; 481),
range: 480..481,
kind: TypeHint,
label: "u8",
},
@ -895,17 +895,17 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig { max_length: Some(8), ..Default::default() }).unwrap(), @r###"
[
InlayHint {
range: [74; 75),
range: 74..75,
kind: TypeHint,
label: "Smol<u32>",
},
InlayHint {
range: [98; 99),
range: 98..99,
kind: TypeHint,
label: "VeryLongOuterName<…>",
},
InlayHint {
range: [137; 138),
range: 137..138,
kind: TypeHint,
label: "Smol<Smol<…>>",
},
@ -983,77 +983,77 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig::default()).unwrap(), @r###"
[
InlayHint {
range: [798; 809),
range: 798..809,
kind: TypeHint,
label: "i32",
},
InlayHint {
range: [842; 843),
range: 842..843,
kind: ParameterHint,
label: "foo",
},
InlayHint {
range: [845; 846),
range: 845..846,
kind: ParameterHint,
label: "bar",
},
InlayHint {
range: [848; 855),
range: 848..855,
kind: ParameterHint,
label: "msg",
},
InlayHint {
range: [860; 871),
range: 860..871,
kind: ParameterHint,
label: "last",
},
InlayHint {
range: [914; 917),
range: 914..917,
kind: ParameterHint,
label: "param",
},
InlayHint {
range: [937; 939),
range: 937..939,
kind: ParameterHint,
label: "&self",
},
InlayHint {
range: [941; 945),
range: 941..945,
kind: ParameterHint,
label: "param",
},
InlayHint {
range: [980; 989),
range: 980..989,
kind: ParameterHint,
label: "file_id",
},
InlayHint {
range: [999; 1012),
range: 999..1012,
kind: ParameterHint,
label: "name",
},
InlayHint {
range: [1022; 1026),
range: 1022..1026,
kind: ParameterHint,
label: "focus_range",
},
InlayHint {
range: [1036; 1048),
range: 1036..1048,
kind: ParameterHint,
label: "full_range",
},
InlayHint {
range: [1058; 1071),
range: 1058..1071,
kind: ParameterHint,
label: "kind",
},
InlayHint {
range: [1081; 1085),
range: 1081..1085,
kind: ParameterHint,
label: "docs",
},
InlayHint {
range: [1095; 1099),
range: 1095..1099,
kind: ParameterHint,
label: "description",
},
@ -1184,12 +1184,12 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig{ parameter_hints: false, type_hints: false, chaining_hints: true, max_length: None}).unwrap(), @r###"
[
InlayHint {
range: [232; 269),
range: 232..269,
kind: ChainingHint,
label: "B",
},
InlayHint {
range: [232; 239),
range: 232..239,
kind: ChainingHint,
label: "A",
},
@ -1238,12 +1238,12 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig{ parameter_hints: false, type_hints: false, chaining_hints: true, max_length: None}).unwrap(), @r###"
[
InlayHint {
range: [252; 323),
range: 252..323,
kind: ChainingHint,
label: "C",
},
InlayHint {
range: [252; 300),
range: 252..300,
kind: ChainingHint,
label: "B",
},
@ -1276,12 +1276,12 @@ fn main() {
assert_debug_snapshot!(analysis.inlay_hints(file_id, &InlayHintsConfig{ parameter_hints: false, type_hints: false, chaining_hints: true, max_length: None}).unwrap(), @r###"
[
InlayHint {
range: [403; 452),
range: 403..452,
kind: ChainingHint,
label: "B<X<i32, bool>>",
},
InlayHint {
range: [403; 422),
range: 403..422,
kind: ChainingHint,
label: "A<X<i32, bool>>",
},

View file

@ -170,7 +170,7 @@ mod tests {
fn check_join_lines(before: &str, after: &str) {
check_action(before, after, |file, offset| {
let range = TextRange::offset_len(offset, 0.into());
let range = TextRange::empty(offset);
let res = join_lines(file, range);
Some(res)
})

View file

@ -76,7 +76,7 @@ mod tests {
",
);
let nav = analysis.parent_module(pos).unwrap().pop().unwrap();
nav.assert_match("foo MODULE FileId(1) [0; 8)");
nav.assert_match("foo MODULE FileId(1) 0..8");
}
#[test]
@ -95,7 +95,7 @@ mod tests {
",
);
let nav = analysis.parent_module(pos).unwrap().pop().unwrap();
nav.assert_match("foo MODULE FileId(1) [0; 8)");
nav.assert_match("foo MODULE FileId(1) 0..8");
}
#[test]
@ -111,7 +111,7 @@ mod tests {
",
);
let nav = analysis.parent_module(pos).unwrap().pop().unwrap();
nav.assert_match("baz MODULE FileId(1) [32; 44)");
nav.assert_match("baz MODULE FileId(1) 32..44");
}
#[test]

View file

@ -214,8 +214,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"Foo STRUCT_DEF FileId(1) [5; 39) [12; 15) Other",
&["FileId(1) [138; 141) StructLiteral"],
"Foo STRUCT_DEF FileId(1) 5..39 12..15 Other",
&["FileId(1) 138..141 StructLiteral"],
);
}
@ -231,8 +231,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"Foo STRUCT_DEF FileId(1) [5; 18) [12; 15) Other",
&["FileId(1) [54; 57) Other", "FileId(1) [71; 74) StructLiteral"],
"Foo STRUCT_DEF FileId(1) 5..18 12..15 Other",
&["FileId(1) 54..57 Other", "FileId(1) 71..74 StructLiteral"],
);
}
@ -248,8 +248,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"Foo STRUCT_DEF FileId(1) [5; 21) [12; 15) Other",
&["FileId(1) [81; 84) StructLiteral"],
"Foo STRUCT_DEF FileId(1) 5..21 12..15 Other",
&["FileId(1) 81..84 StructLiteral"],
);
}
@ -266,8 +266,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"Foo STRUCT_DEF FileId(1) [5; 21) [12; 15) Other",
&["FileId(1) [71; 74) StructLiteral"],
"Foo STRUCT_DEF FileId(1) 5..21 12..15 Other",
&["FileId(1) 71..74 StructLiteral"],
);
}
@ -289,12 +289,12 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"i BIND_PAT FileId(1) [33; 34) Other Write",
"i BIND_PAT FileId(1) 33..34 Other Write",
&[
"FileId(1) [67; 68) Other Write",
"FileId(1) [71; 72) Other Read",
"FileId(1) [101; 102) Other Write",
"FileId(1) [127; 128) Other Write",
"FileId(1) 67..68 Other Write",
"FileId(1) 71..72 Other Read",
"FileId(1) 101..102 Other Write",
"FileId(1) 127..128 Other Write",
],
);
}
@ -315,8 +315,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"spam BIND_PAT FileId(1) [44; 48) Other",
&["FileId(1) [71; 75) Other Read", "FileId(1) [78; 82) Other Read"],
"spam BIND_PAT FileId(1) 44..48 Other",
&["FileId(1) 71..75 Other Read", "FileId(1) 78..82 Other Read"],
);
}
@ -328,11 +328,7 @@ mod tests {
}"#;
let refs = get_all_refs(code);
check_result(
refs,
"i BIND_PAT FileId(1) [12; 13) Other",
&["FileId(1) [38; 39) Other Read"],
);
check_result(refs, "i BIND_PAT FileId(1) 12..13 Other", &["FileId(1) 38..39 Other Read"]);
}
#[test]
@ -343,11 +339,7 @@ mod tests {
}"#;
let refs = get_all_refs(code);
check_result(
refs,
"i BIND_PAT FileId(1) [12; 13) Other",
&["FileId(1) [38; 39) Other Read"],
);
check_result(refs, "i BIND_PAT FileId(1) 12..13 Other", &["FileId(1) 38..39 Other Read"]);
}
#[test]
@ -366,8 +358,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"spam RECORD_FIELD_DEF FileId(1) [66; 79) [70; 74) Other",
&["FileId(1) [152; 156) Other Read"],
"spam RECORD_FIELD_DEF FileId(1) 66..79 70..74 Other",
&["FileId(1) 152..156 Other Read"],
);
}
@ -382,7 +374,7 @@ mod tests {
"#;
let refs = get_all_refs(code);
check_result(refs, "f FN_DEF FileId(1) [88; 104) [91; 92) Other", &[]);
check_result(refs, "f FN_DEF FileId(1) 88..104 91..92 Other", &[]);
}
#[test]
@ -397,7 +389,7 @@ mod tests {
"#;
let refs = get_all_refs(code);
check_result(refs, "B ENUM_VARIANT FileId(1) [83; 84) [83; 84) Other", &[]);
check_result(refs, "B ENUM_VARIANT FileId(1) 83..84 83..84 Other", &[]);
}
#[test]
@ -438,8 +430,8 @@ mod tests {
let refs = analysis.find_all_refs(pos, None).unwrap().unwrap();
check_result(
refs,
"Foo STRUCT_DEF FileId(2) [16; 50) [27; 30) Other",
&["FileId(1) [52; 55) StructLiteral", "FileId(3) [77; 80) StructLiteral"],
"Foo STRUCT_DEF FileId(2) 16..50 27..30 Other",
&["FileId(1) 52..55 StructLiteral", "FileId(3) 77..80 StructLiteral"],
);
}
@ -466,11 +458,7 @@ mod tests {
let (analysis, pos) = analysis_and_position(code);
let refs = analysis.find_all_refs(pos, None).unwrap().unwrap();
check_result(
refs,
"foo SOURCE_FILE FileId(2) [0; 35) Other",
&["FileId(1) [13; 16) Other"],
);
check_result(refs, "foo SOURCE_FILE FileId(2) 0..35 Other", &["FileId(1) 13..16 Other"]);
}
#[test]
@ -497,8 +485,8 @@ mod tests {
let refs = analysis.find_all_refs(pos, None).unwrap().unwrap();
check_result(
refs,
"Foo STRUCT_DEF FileId(3) [0; 41) [18; 21) Other",
&["FileId(2) [20; 23) Other", "FileId(2) [46; 49) StructLiteral"],
"Foo STRUCT_DEF FileId(3) 0..41 18..21 Other",
&["FileId(2) 20..23 Other", "FileId(2) 46..49 StructLiteral"],
);
}
@ -525,16 +513,16 @@ mod tests {
let refs = analysis.find_all_refs(pos, None).unwrap().unwrap();
check_result(
refs,
"quux FN_DEF FileId(1) [18; 34) [25; 29) Other",
&["FileId(2) [16; 20) StructLiteral", "FileId(3) [16; 20) StructLiteral"],
"quux FN_DEF FileId(1) 18..34 25..29 Other",
&["FileId(2) 16..20 StructLiteral", "FileId(3) 16..20 StructLiteral"],
);
let refs =
analysis.find_all_refs(pos, Some(SearchScope::single_file(bar))).unwrap().unwrap();
check_result(
refs,
"quux FN_DEF FileId(1) [18; 34) [25; 29) Other",
&["FileId(3) [16; 20) StructLiteral"],
"quux FN_DEF FileId(1) 18..34 25..29 Other",
&["FileId(3) 16..20 StructLiteral"],
);
}
@ -552,8 +540,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"m1 MACRO_CALL FileId(1) [9; 63) [46; 48) Other",
&["FileId(1) [96; 98) StructLiteral", "FileId(1) [114; 116) StructLiteral"],
"m1 MACRO_CALL FileId(1) 9..63 46..48 Other",
&["FileId(1) 96..98 StructLiteral", "FileId(1) 114..116 StructLiteral"],
);
}
@ -568,8 +556,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"i BIND_PAT FileId(1) [40; 41) Other Write",
&["FileId(1) [59; 60) Other Write", "FileId(1) [63; 64) Other Read"],
"i BIND_PAT FileId(1) 40..41 Other Write",
&["FileId(1) 59..60 Other Write", "FileId(1) 63..64 Other Read"],
);
}
@ -588,8 +576,8 @@ mod tests {
let refs = get_all_refs(code);
check_result(
refs,
"f RECORD_FIELD_DEF FileId(1) [32; 38) [32; 33) Other",
&["FileId(1) [96; 97) Other Read", "FileId(1) [117; 118) Other Write"],
"f RECORD_FIELD_DEF FileId(1) 32..38 32..33 Other",
&["FileId(1) 96..97 Other Read", "FileId(1) 117..118 Other Write"],
);
}
@ -602,11 +590,7 @@ mod tests {
}"#;
let refs = get_all_refs(code);
check_result(
refs,
"i BIND_PAT FileId(1) [36; 37) Other",
&["FileId(1) [51; 52) Other Write"],
);
check_result(refs, "i BIND_PAT FileId(1) 36..37 Other", &["FileId(1) 51..52 Other Write"]);
}
fn get_all_refs(text: &str) -> ReferenceSearchResult {

View file

@ -54,10 +54,7 @@ fn source_edit_from_reference(reference: Reference, new_name: &str) -> SourceFil
ReferenceKind::StructFieldShorthandForField => {
replacement_text.push_str(new_name);
replacement_text.push_str(": ");
TextRange::new(
reference.file_range.range.start(),
reference.file_range.range.start(),
)
TextRange::new(reference.file_range.range.start(), reference.file_range.range.start())
}
ReferenceKind::StructFieldShorthandForLocal => {
replacement_text.push_str(": ");
@ -528,7 +525,7 @@ mod tests {
@r###"
Some(
RangeInfo {
range: [4; 7),
range: 4..7,
info: SourceChange {
label: "rename",
source_file_edits: [
@ -539,7 +536,7 @@ mod tests {
edit: TextEdit {
atoms: [
AtomTextEdit {
delete: [4; 7),
delete: 4..7,
insert: "foo2",
},
],
@ -580,7 +577,7 @@ mod tests {
@r###"
Some(
RangeInfo {
range: [4; 7),
range: 4..7,
info: SourceChange {
label: "rename",
source_file_edits: [
@ -591,7 +588,7 @@ mod tests {
edit: TextEdit {
atoms: [
AtomTextEdit {
delete: [4; 7),
delete: 4..7,
insert: "foo2",
},
],
@ -663,7 +660,7 @@ mod tests {
@r###"
Some(
RangeInfo {
range: [8; 11),
range: 8..11,
info: SourceChange {
label: "rename",
source_file_edits: [
@ -674,7 +671,7 @@ mod tests {
edit: TextEdit {
atoms: [
AtomTextEdit {
delete: [8; 11),
delete: 8..11,
insert: "foo2",
},
],
@ -687,7 +684,7 @@ mod tests {
edit: TextEdit {
atoms: [
AtomTextEdit {
delete: [27; 30),
delete: 27..30,
insert: "foo2",
},
],

View file

@ -164,11 +164,11 @@ mod tests {
@r###"
[
Runnable {
range: [1; 21),
range: 1..21,
kind: Bin,
},
Runnable {
range: [22; 46),
range: 22..46,
kind: Test {
test_id: Path(
"test_foo",
@ -179,7 +179,7 @@ mod tests {
},
},
Runnable {
range: [47; 81),
range: 47..81,
kind: Test {
test_id: Path(
"test_foo",
@ -211,13 +211,13 @@ mod tests {
@r###"
[
Runnable {
range: [1; 59),
range: 1..59,
kind: TestMod {
path: "test_mod",
},
},
Runnable {
range: [28; 57),
range: 28..57,
kind: Test {
test_id: Path(
"test_mod::test_foo1",
@ -251,13 +251,13 @@ mod tests {
@r###"
[
Runnable {
range: [23; 85),
range: 23..85,
kind: TestMod {
path: "foo::test_mod",
},
},
Runnable {
range: [46; 79),
range: 46..79,
kind: Test {
test_id: Path(
"foo::test_mod::test_foo1",
@ -293,13 +293,13 @@ mod tests {
@r###"
[
Runnable {
range: [41; 115),
range: 41..115,
kind: TestMod {
path: "foo::bar::test_mod",
},
},
Runnable {
range: [68; 105),
range: 68..105,
kind: Test {
test_id: Path(
"foo::bar::test_mod::test_foo1",

View file

@ -126,7 +126,7 @@ fn test_ranges() {
// The "x"
let highlights = &analysis
.highlight_range(FileRange { file_id, range: TextRange::offset_len(82.into(), 1.into()) })
.highlight_range(FileRange { file_id, range: TextRange::at(82.into(), 1.into()) })
.unwrap();
assert_eq!(&highlights[0].highlight.to_string(), "field.declaration");

View file

@ -66,11 +66,8 @@ fn syntax_tree_for_token(node: &SyntaxToken, text_range: TextRange) -> Option<St
let len = len.min(node_len);
// Ensure our slice is inside the actual string
let end = if start + len < TextSize::of(&text) {
start + len
} else {
TextSize::of(&text) - start
};
let end =
if start + len < TextSize::of(&text) { start + len } else { TextSize::of(&text) - start };
let text = &text[TextRange::new(start, end)];
@ -112,20 +109,20 @@ mod tests {
assert_eq_text!(
syn.trim(),
r#"
SOURCE_FILE@[0; 11)
FN_DEF@[0; 11)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 6)
IDENT@[3; 6) "foo"
PARAM_LIST@[6; 8)
L_PAREN@[6; 7) "("
R_PAREN@[7; 8) ")"
WHITESPACE@[8; 9) " "
BLOCK_EXPR@[9; 11)
BLOCK@[9; 11)
L_CURLY@[9; 10) "{"
R_CURLY@[10; 11) "}"
SOURCE_FILE@0..11
FN_DEF@0..11
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..6
IDENT@3..6 "foo"
PARAM_LIST@6..8
L_PAREN@6..7 "("
R_PAREN@7..8 ")"
WHITESPACE@8..9 " "
BLOCK_EXPR@9..11
BLOCK@9..11
L_CURLY@9..10 "{"
R_CURLY@10..11 "}"
"#
.trim()
);
@ -145,37 +142,37 @@ fn test() {
assert_eq_text!(
syn.trim(),
r#"
SOURCE_FILE@[0; 60)
FN_DEF@[0; 60)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 7)
IDENT@[3; 7) "test"
PARAM_LIST@[7; 9)
L_PAREN@[7; 8) "("
R_PAREN@[8; 9) ")"
WHITESPACE@[9; 10) " "
BLOCK_EXPR@[10; 60)
BLOCK@[10; 60)
L_CURLY@[10; 11) "{"
WHITESPACE@[11; 16) "\n "
EXPR_STMT@[16; 58)
MACRO_CALL@[16; 57)
PATH@[16; 22)
PATH_SEGMENT@[16; 22)
NAME_REF@[16; 22)
IDENT@[16; 22) "assert"
BANG@[22; 23) "!"
TOKEN_TREE@[23; 57)
L_PAREN@[23; 24) "("
STRING@[24; 52) "\"\n fn foo() {\n ..."
COMMA@[52; 53) ","
WHITESPACE@[53; 54) " "
STRING@[54; 56) "\"\""
R_PAREN@[56; 57) ")"
SEMICOLON@[57; 58) ";"
WHITESPACE@[58; 59) "\n"
R_CURLY@[59; 60) "}"
SOURCE_FILE@0..60
FN_DEF@0..60
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..7
IDENT@3..7 "test"
PARAM_LIST@7..9
L_PAREN@7..8 "("
R_PAREN@8..9 ")"
WHITESPACE@9..10 " "
BLOCK_EXPR@10..60
BLOCK@10..60
L_CURLY@10..11 "{"
WHITESPACE@11..16 "\n "
EXPR_STMT@16..58
MACRO_CALL@16..57
PATH@16..22
PATH_SEGMENT@16..22
NAME_REF@16..22
IDENT@16..22 "assert"
BANG@22..23 "!"
TOKEN_TREE@23..57
L_PAREN@23..24 "("
STRING@24..52 "\"\n fn foo() {\n ..."
COMMA@52..53 ","
WHITESPACE@53..54 " "
STRING@54..56 "\"\""
R_PAREN@56..57 ")"
SEMICOLON@57..58 ";"
WHITESPACE@58..59 "\n"
R_CURLY@59..60 "}"
"#
.trim()
);
@ -189,19 +186,19 @@ SOURCE_FILE@[0; 60)
assert_eq_text!(
syn.trim(),
r#"
FN_DEF@[0; 11)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 6)
IDENT@[3; 6) "foo"
PARAM_LIST@[6; 8)
L_PAREN@[6; 7) "("
R_PAREN@[7; 8) ")"
WHITESPACE@[8; 9) " "
BLOCK_EXPR@[9; 11)
BLOCK@[9; 11)
L_CURLY@[9; 10) "{"
R_CURLY@[10; 11) "}"
FN_DEF@0..11
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..6
IDENT@3..6 "foo"
PARAM_LIST@6..8
L_PAREN@6..7 "("
R_PAREN@7..8 ")"
WHITESPACE@8..9 " "
BLOCK_EXPR@9..11
BLOCK@9..11
L_CURLY@9..10 "{"
R_CURLY@10..11 "}"
"#
.trim()
);
@ -220,21 +217,21 @@ FN_DEF@[0; 11)
assert_eq_text!(
syn.trim(),
r#"
EXPR_STMT@[16; 58)
MACRO_CALL@[16; 57)
PATH@[16; 22)
PATH_SEGMENT@[16; 22)
NAME_REF@[16; 22)
IDENT@[16; 22) "assert"
BANG@[22; 23) "!"
TOKEN_TREE@[23; 57)
L_PAREN@[23; 24) "("
STRING@[24; 52) "\"\n fn foo() {\n ..."
COMMA@[52; 53) ","
WHITESPACE@[53; 54) " "
STRING@[54; 56) "\"\""
R_PAREN@[56; 57) ")"
SEMICOLON@[57; 58) ";"
EXPR_STMT@16..58
MACRO_CALL@16..57
PATH@16..22
PATH_SEGMENT@16..22
NAME_REF@16..22
IDENT@16..22 "assert"
BANG@22..23 "!"
TOKEN_TREE@23..57
L_PAREN@23..24 "("
STRING@24..52 "\"\n fn foo() {\n ..."
COMMA@52..53 ","
WHITESPACE@53..54 " "
STRING@54..56 "\"\""
R_PAREN@56..57 ")"
SEMICOLON@57..58 ";"
"#
.trim()
);
@ -257,21 +254,21 @@ fn bar() {
assert_eq_text!(
syn.trim(),
r#"
SOURCE_FILE@[0; 12)
FN_DEF@[0; 12)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 6)
IDENT@[3; 6) "foo"
PARAM_LIST@[6; 8)
L_PAREN@[6; 7) "("
R_PAREN@[7; 8) ")"
WHITESPACE@[8; 9) " "
BLOCK_EXPR@[9; 12)
BLOCK@[9; 12)
L_CURLY@[9; 10) "{"
WHITESPACE@[10; 11) "\n"
R_CURLY@[11; 12) "}"
SOURCE_FILE@0..12
FN_DEF@0..12
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..6
IDENT@3..6 "foo"
PARAM_LIST@6..8
L_PAREN@6..7 "("
R_PAREN@7..8 ")"
WHITESPACE@8..9 " "
BLOCK_EXPR@9..12
BLOCK@9..12
L_CURLY@9..10 "{"
WHITESPACE@10..11 "\n"
R_CURLY@11..12 "}"
"#
.trim()
);
@ -292,21 +289,21 @@ fn bar() {
assert_eq_text!(
syn.trim(),
r#"
SOURCE_FILE@[0; 12)
FN_DEF@[0; 12)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 6)
IDENT@[3; 6) "foo"
PARAM_LIST@[6; 8)
L_PAREN@[6; 7) "("
R_PAREN@[7; 8) ")"
WHITESPACE@[8; 9) " "
BLOCK_EXPR@[9; 12)
BLOCK@[9; 12)
L_CURLY@[9; 10) "{"
WHITESPACE@[10; 11) "\n"
R_CURLY@[11; 12) "}"
SOURCE_FILE@0..12
FN_DEF@0..12
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..6
IDENT@3..6 "foo"
PARAM_LIST@6..8
L_PAREN@6..7 "("
R_PAREN@7..8 ")"
WHITESPACE@8..9 " "
BLOCK_EXPR@9..12
BLOCK@9..12
L_CURLY@9..10 "{"
WHITESPACE@10..11 "\n"
R_CURLY@11..12 "}"
"#
.trim()
);
@ -326,36 +323,36 @@ fn bar() {
assert_eq_text!(
syn.trim(),
r#"
SOURCE_FILE@[0; 25)
FN_DEF@[0; 12)
FN_KW@[0; 2) "fn"
WHITESPACE@[2; 3) " "
NAME@[3; 6)
IDENT@[3; 6) "foo"
PARAM_LIST@[6; 8)
L_PAREN@[6; 7) "("
R_PAREN@[7; 8) ")"
WHITESPACE@[8; 9) " "
BLOCK_EXPR@[9; 12)
BLOCK@[9; 12)
L_CURLY@[9; 10) "{"
WHITESPACE@[10; 11) "\n"
R_CURLY@[11; 12) "}"
WHITESPACE@[12; 13) "\n"
FN_DEF@[13; 25)
FN_KW@[13; 15) "fn"
WHITESPACE@[15; 16) " "
NAME@[16; 19)
IDENT@[16; 19) "bar"
PARAM_LIST@[19; 21)
L_PAREN@[19; 20) "("
R_PAREN@[20; 21) ")"
WHITESPACE@[21; 22) " "
BLOCK_EXPR@[22; 25)
BLOCK@[22; 25)
L_CURLY@[22; 23) "{"
WHITESPACE@[23; 24) "\n"
R_CURLY@[24; 25) "}"
SOURCE_FILE@0..25
FN_DEF@0..12
FN_KW@0..2 "fn"
WHITESPACE@2..3 " "
NAME@3..6
IDENT@3..6 "foo"
PARAM_LIST@6..8
L_PAREN@6..7 "("
R_PAREN@7..8 ")"
WHITESPACE@8..9 " "
BLOCK_EXPR@9..12
BLOCK@9..12
L_CURLY@9..10 "{"
WHITESPACE@10..11 "\n"
R_CURLY@11..12 "}"
WHITESPACE@12..13 "\n"
FN_DEF@13..25
FN_KW@13..15 "fn"
WHITESPACE@15..16 " "
NAME@16..19
IDENT@16..19 "bar"
PARAM_LIST@19..21
L_PAREN@19..20 "("
R_PAREN@20..21 ")"
WHITESPACE@21..22 " "
BLOCK_EXPR@22..25
BLOCK@22..25
L_CURLY@22..23 "{"
WHITESPACE@23..24 "\n"
R_CURLY@24..25 "}"
"#
.trim()
);

View file

@ -109,13 +109,8 @@ fn on_dot_typed(file: &SourceFile, offset: TextSize) -> Option<SingleFileChange>
Some(SingleFileChange {
label: "reindent dot".to_string(),
edit: TextEdit::replace(
TextRange::new(offset - current_indent_len, offset),
target_indent,
),
cursor_position: Some(
offset + target_indent_len - current_indent_len + TextSize::of('.'),
),
edit: TextEdit::replace(TextRange::new(offset - current_indent_len, offset), target_indent),
cursor_position: Some(offset + target_indent_len - current_indent_len + TextSize::of('.')),
})
}

View file

@ -257,30 +257,30 @@ fn test_expr_order() {
let dump = format!("{:#?}", expanded);
assert_eq_text!(
dump.trim(),
r#"MACRO_ITEMS@[0; 15)
FN_DEF@[0; 15)
FN_KW@[0; 2) "fn"
NAME@[2; 5)
IDENT@[2; 5) "bar"
PARAM_LIST@[5; 7)
L_PAREN@[5; 6) "("
R_PAREN@[6; 7) ")"
BLOCK_EXPR@[7; 15)
BLOCK@[7; 15)
L_CURLY@[7; 8) "{"
EXPR_STMT@[8; 14)
BIN_EXPR@[8; 13)
BIN_EXPR@[8; 11)
LITERAL@[8; 9)
INT_NUMBER@[8; 9) "1"
PLUS@[9; 10) "+"
LITERAL@[10; 11)
INT_NUMBER@[10; 11) "1"
STAR@[11; 12) "*"
LITERAL@[12; 13)
INT_NUMBER@[12; 13) "2"
SEMICOLON@[13; 14) ";"
R_CURLY@[14; 15) "}""#,
r#"MACRO_ITEMS@0..15
FN_DEF@0..15
FN_KW@0..2 "fn"
NAME@2..5
IDENT@2..5 "bar"
PARAM_LIST@5..7
L_PAREN@5..6 "("
R_PAREN@6..7 ")"
BLOCK_EXPR@7..15
BLOCK@7..15
L_CURLY@7..8 "{"
EXPR_STMT@8..14
BIN_EXPR@8..13
BIN_EXPR@8..11
LITERAL@8..9
INT_NUMBER@8..9 "1"
PLUS@9..10 "+"
LITERAL@10..11
INT_NUMBER@10..11 "1"
STAR@11..12 "*"
LITERAL@12..13
INT_NUMBER@12..13 "2"
SEMICOLON@13..14 ";"
R_CURLY@14..15 "}""#,
);
}
@ -490,39 +490,39 @@ fn test_expand_to_item_list() {
assert_eq!(
format!("{:#?}", tree).trim(),
r#"
MACRO_ITEMS@[0; 40)
STRUCT_DEF@[0; 20)
STRUCT_KW@[0; 6) "struct"
NAME@[6; 9)
IDENT@[6; 9) "Foo"
RECORD_FIELD_DEF_LIST@[9; 20)
L_CURLY@[9; 10) "{"
RECORD_FIELD_DEF@[10; 19)
NAME@[10; 15)
IDENT@[10; 15) "field"
COLON@[15; 16) ":"
PATH_TYPE@[16; 19)
PATH@[16; 19)
PATH_SEGMENT@[16; 19)
NAME_REF@[16; 19)
IDENT@[16; 19) "u32"
R_CURLY@[19; 20) "}"
STRUCT_DEF@[20; 40)
STRUCT_KW@[20; 26) "struct"
NAME@[26; 29)
IDENT@[26; 29) "Bar"
RECORD_FIELD_DEF_LIST@[29; 40)
L_CURLY@[29; 30) "{"
RECORD_FIELD_DEF@[30; 39)
NAME@[30; 35)
IDENT@[30; 35) "field"
COLON@[35; 36) ":"
PATH_TYPE@[36; 39)
PATH@[36; 39)
PATH_SEGMENT@[36; 39)
NAME_REF@[36; 39)
IDENT@[36; 39) "u32"
R_CURLY@[39; 40) "}""#
MACRO_ITEMS@0..40
STRUCT_DEF@0..20
STRUCT_KW@0..6 "struct"
NAME@6..9
IDENT@6..9 "Foo"
RECORD_FIELD_DEF_LIST@9..20
L_CURLY@9..10 "{"
RECORD_FIELD_DEF@10..19
NAME@10..15
IDENT@10..15 "field"
COLON@15..16 ":"
PATH_TYPE@16..19
PATH@16..19
PATH_SEGMENT@16..19
NAME_REF@16..19
IDENT@16..19 "u32"
R_CURLY@19..20 "}"
STRUCT_DEF@20..40
STRUCT_KW@20..26 "struct"
NAME@26..29
IDENT@26..29 "Bar"
RECORD_FIELD_DEF_LIST@29..40
L_CURLY@29..30 "{"
RECORD_FIELD_DEF@30..39
NAME@30..35
IDENT@30..35 "field"
COLON@35..36 ":"
PATH_TYPE@36..39
PATH@36..39
PATH_SEGMENT@36..39
NAME_REF@36..39
IDENT@36..39 "u32"
R_CURLY@39..40 "}""#
.trim()
);
}
@ -623,37 +623,37 @@ fn test_tt_to_stmts() {
assert_eq!(
format!("{:#?}", stmts).trim(),
r#"MACRO_STMTS@[0; 15)
LET_STMT@[0; 7)
LET_KW@[0; 3) "let"
BIND_PAT@[3; 4)
NAME@[3; 4)
IDENT@[3; 4) "a"
EQ@[4; 5) "="
LITERAL@[5; 6)
INT_NUMBER@[5; 6) "0"
SEMICOLON@[6; 7) ";"
EXPR_STMT@[7; 14)
BIN_EXPR@[7; 13)
PATH_EXPR@[7; 8)
PATH@[7; 8)
PATH_SEGMENT@[7; 8)
NAME_REF@[7; 8)
IDENT@[7; 8) "a"
EQ@[8; 9) "="
BIN_EXPR@[9; 13)
LITERAL@[9; 11)
INT_NUMBER@[9; 11) "10"
PLUS@[11; 12) "+"
LITERAL@[12; 13)
INT_NUMBER@[12; 13) "1"
SEMICOLON@[13; 14) ";"
EXPR_STMT@[14; 15)
PATH_EXPR@[14; 15)
PATH@[14; 15)
PATH_SEGMENT@[14; 15)
NAME_REF@[14; 15)
IDENT@[14; 15) "a""#,
r#"MACRO_STMTS@0..15
LET_STMT@0..7
LET_KW@0..3 "let"
BIND_PAT@3..4
NAME@3..4
IDENT@3..4 "a"
EQ@4..5 "="
LITERAL@5..6
INT_NUMBER@5..6 "0"
SEMICOLON@6..7 ";"
EXPR_STMT@7..14
BIN_EXPR@7..13
PATH_EXPR@7..8
PATH@7..8
PATH_SEGMENT@7..8
NAME_REF@7..8
IDENT@7..8 "a"
EQ@8..9 "="
BIN_EXPR@9..13
LITERAL@9..11
INT_NUMBER@9..11 "10"
PLUS@11..12 "+"
LITERAL@12..13
INT_NUMBER@12..13 "1"
SEMICOLON@13..14 ";"
EXPR_STMT@14..15
PATH_EXPR@14..15
PATH@14..15
PATH_SEGMENT@14..15
NAME_REF@14..15
IDENT@14..15 "a""#,
);
}
@ -974,20 +974,20 @@ fn test_tt_composite2() {
let res = format!("{:#?}", &node);
assert_eq_text!(
res.trim(),
r###"MACRO_ITEMS@[0; 10)
MACRO_CALL@[0; 10)
PATH@[0; 3)
PATH_SEGMENT@[0; 3)
NAME_REF@[0; 3)
IDENT@[0; 3) "abs"
BANG@[3; 4) "!"
TOKEN_TREE@[4; 10)
L_PAREN@[4; 5) "("
EQ@[5; 6) "="
R_ANGLE@[6; 7) ">"
WHITESPACE@[7; 8) " "
POUND@[8; 9) "#"
R_PAREN@[9; 10) ")""###
r###"MACRO_ITEMS@0..10
MACRO_CALL@0..10
PATH@0..3
PATH_SEGMENT@0..3
NAME_REF@0..3
IDENT@0..3 "abs"
BANG@3..4 "!"
TOKEN_TREE@4..10
L_PAREN@4..5 "("
EQ@5..6 "="
R_ANGLE@6..7 ">"
WHITESPACE@7..8 " "
POUND@8..9 "#"
R_PAREN@9..10 ")""###
);
}
@ -1113,69 +1113,69 @@ fn test_vec() {
assert_eq!(
format!("{:#?}", tree).trim(),
r#"BLOCK_EXPR@[0; 45)
BLOCK@[0; 45)
L_CURLY@[0; 1) "{"
LET_STMT@[1; 20)
LET_KW@[1; 4) "let"
BIND_PAT@[4; 8)
MUT_KW@[4; 7) "mut"
NAME@[7; 8)
IDENT@[7; 8) "v"
EQ@[8; 9) "="
CALL_EXPR@[9; 19)
PATH_EXPR@[9; 17)
PATH@[9; 17)
PATH@[9; 12)
PATH_SEGMENT@[9; 12)
NAME_REF@[9; 12)
IDENT@[9; 12) "Vec"
COLON2@[12; 14) "::"
PATH_SEGMENT@[14; 17)
NAME_REF@[14; 17)
IDENT@[14; 17) "new"
ARG_LIST@[17; 19)
L_PAREN@[17; 18) "("
R_PAREN@[18; 19) ")"
SEMICOLON@[19; 20) ";"
EXPR_STMT@[20; 33)
METHOD_CALL_EXPR@[20; 32)
PATH_EXPR@[20; 21)
PATH@[20; 21)
PATH_SEGMENT@[20; 21)
NAME_REF@[20; 21)
IDENT@[20; 21) "v"
DOT@[21; 22) "."
NAME_REF@[22; 26)
IDENT@[22; 26) "push"
ARG_LIST@[26; 32)
L_PAREN@[26; 27) "("
LITERAL@[27; 31)
INT_NUMBER@[27; 31) "1u32"
R_PAREN@[31; 32) ")"
SEMICOLON@[32; 33) ";"
EXPR_STMT@[33; 43)
METHOD_CALL_EXPR@[33; 42)
PATH_EXPR@[33; 34)
PATH@[33; 34)
PATH_SEGMENT@[33; 34)
NAME_REF@[33; 34)
IDENT@[33; 34) "v"
DOT@[34; 35) "."
NAME_REF@[35; 39)
IDENT@[35; 39) "push"
ARG_LIST@[39; 42)
L_PAREN@[39; 40) "("
LITERAL@[40; 41)
INT_NUMBER@[40; 41) "2"
R_PAREN@[41; 42) ")"
SEMICOLON@[42; 43) ";"
PATH_EXPR@[43; 44)
PATH@[43; 44)
PATH_SEGMENT@[43; 44)
NAME_REF@[43; 44)
IDENT@[43; 44) "v"
R_CURLY@[44; 45) "}""#
r#"BLOCK_EXPR@0..45
BLOCK@0..45
L_CURLY@0..1 "{"
LET_STMT@1..20
LET_KW@1..4 "let"
BIND_PAT@4..8
MUT_KW@4..7 "mut"
NAME@7..8
IDENT@7..8 "v"
EQ@8..9 "="
CALL_EXPR@9..19
PATH_EXPR@9..17
PATH@9..17
PATH@9..12
PATH_SEGMENT@9..12
NAME_REF@9..12
IDENT@9..12 "Vec"
COLON2@12..14 "::"
PATH_SEGMENT@14..17
NAME_REF@14..17
IDENT@14..17 "new"
ARG_LIST@17..19
L_PAREN@17..18 "("
R_PAREN@18..19 ")"
SEMICOLON@19..20 ";"
EXPR_STMT@20..33
METHOD_CALL_EXPR@20..32
PATH_EXPR@20..21
PATH@20..21
PATH_SEGMENT@20..21
NAME_REF@20..21
IDENT@20..21 "v"
DOT@21..22 "."
NAME_REF@22..26
IDENT@22..26 "push"
ARG_LIST@26..32
L_PAREN@26..27 "("
LITERAL@27..31
INT_NUMBER@27..31 "1u32"
R_PAREN@31..32 ")"
SEMICOLON@32..33 ";"
EXPR_STMT@33..43
METHOD_CALL_EXPR@33..42
PATH_EXPR@33..34
PATH@33..34
PATH_SEGMENT@33..34
NAME_REF@33..34
IDENT@33..34 "v"
DOT@34..35 "."
NAME_REF@35..39
IDENT@35..39 "push"
ARG_LIST@39..42
L_PAREN@39..40 "("
LITERAL@40..41
INT_NUMBER@40..41 "2"
R_PAREN@41..42 ")"
SEMICOLON@42..43 ";"
PATH_EXPR@43..44
PATH@43..44
PATH_SEGMENT@43..44
NAME_REF@43..44
IDENT@43..44 "v"
R_CURLY@44..45 "}""#
);
}
@ -1798,45 +1798,45 @@ fn test_no_space_after_semi_colon() {
let dump = format!("{:#?}", expanded);
assert_eq_text!(
dump.trim(),
r###"MACRO_ITEMS@[0; 52)
MODULE@[0; 26)
ATTR@[0; 21)
POUND@[0; 1) "#"
L_BRACK@[1; 2) "["
PATH@[2; 5)
PATH_SEGMENT@[2; 5)
NAME_REF@[2; 5)
IDENT@[2; 5) "cfg"
TOKEN_TREE@[5; 20)
L_PAREN@[5; 6) "("
IDENT@[6; 13) "feature"
EQ@[13; 14) "="
STRING@[14; 19) "\"std\""
R_PAREN@[19; 20) ")"
R_BRACK@[20; 21) "]"
MOD_KW@[21; 24) "mod"
NAME@[24; 25)
IDENT@[24; 25) "m"
SEMICOLON@[25; 26) ";"
MODULE@[26; 52)
ATTR@[26; 47)
POUND@[26; 27) "#"
L_BRACK@[27; 28) "["
PATH@[28; 31)
PATH_SEGMENT@[28; 31)
NAME_REF@[28; 31)
IDENT@[28; 31) "cfg"
TOKEN_TREE@[31; 46)
L_PAREN@[31; 32) "("
IDENT@[32; 39) "feature"
EQ@[39; 40) "="
STRING@[40; 45) "\"std\""
R_PAREN@[45; 46) ")"
R_BRACK@[46; 47) "]"
MOD_KW@[47; 50) "mod"
NAME@[50; 51)
IDENT@[50; 51) "f"
SEMICOLON@[51; 52) ";""###,
r###"MACRO_ITEMS@0..52
MODULE@0..26
ATTR@0..21
POUND@0..1 "#"
L_BRACK@1..2 "["
PATH@2..5
PATH_SEGMENT@2..5
NAME_REF@2..5
IDENT@2..5 "cfg"
TOKEN_TREE@5..20
L_PAREN@5..6 "("
IDENT@6..13 "feature"
EQ@13..14 "="
STRING@14..19 "\"std\""
R_PAREN@19..20 ")"
R_BRACK@20..21 "]"
MOD_KW@21..24 "mod"
NAME@24..25
IDENT@24..25 "m"
SEMICOLON@25..26 ";"
MODULE@26..52
ATTR@26..47
POUND@26..27 "#"
L_BRACK@27..28 "["
PATH@28..31
PATH_SEGMENT@28..31
NAME_REF@28..31
IDENT@28..31 "cfg"
TOKEN_TREE@31..46
L_PAREN@31..32 "("
IDENT@32..39 "feature"
EQ@39..40 "="
STRING@40..45 "\"std\""
R_PAREN@45..46 ")"
R_BRACK@46..47 "]"
MOD_KW@47..50 "mod"
NAME@50..51
IDENT@50..51 "f"
SEMICOLON@51..52 ";""###,
);
}

View file

@ -1,2 +1,2 @@
CHAR 1 "\'"
> error[0; 1) token("\'") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..1 token("\'") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 5 "\'🦀"
> error[0; 5) token("\'🦀") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..5 token("\'🦀") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 5 "\'\\x7f"
> error[0; 5) token("\'\\x7f") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..5 token("\'\\x7f") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 9 "\'\\u{20AA}"
> error[0; 9) token("\'\\u{20AA}") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..9 token("\'\\u{20AA}") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 2 "\' "
> error[0; 2) token("\' ") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..2 token("\' ") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 2 "\'\\"
> error[0; 2) token("\'\\") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..2 token("\'\\") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 3 "\'\\n"
> error[0; 3) token("\'\\n") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..3 token("\'\\n") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
CHAR 3 "\'\\\'"
> error[0; 3) token("\'\\\'") msg(Missing trailing `'` symbol to terminate the character literal)
> error0..3 token("\'\\\'") msg(Missing trailing `'` symbol to terminate the character literal)

View file

@ -1,2 +1,2 @@
BYTE 2 "b\'"
> error[0; 2) token("b\'") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..2 token("b\'") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 6 "b\'🦀"
> error[0; 6) token("b\'🦀") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..6 token("b\'🦀") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 6 "b\'\\x7f"
> error[0; 6) token("b\'\\x7f") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..6 token("b\'\\x7f") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 10 "b\'\\u{20AA}"
> error[0; 10) token("b\'\\u{20AA}") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..10 token("b\'\\u{20AA}") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 3 "b\' "
> error[0; 3) token("b\' ") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..3 token("b\' ") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 3 "b\'\\"
> error[0; 3) token("b\'\\") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..3 token("b\'\\") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 4 "b\'\\n"
> error[0; 4) token("b\'\\n") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..4 token("b\'\\n") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
BYTE 4 "b\'\\\'"
> error[0; 4) token("b\'\\\'") msg(Missing trailing `'` symbol to terminate the byte literal)
> error0..4 token("b\'\\\'") msg(Missing trailing `'` symbol to terminate the byte literal)

View file

@ -1,2 +1,2 @@
STRING 1 "\""
> error[0; 1) token("\"") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..1 token("\"") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 5 "\"🦀"
> error[0; 5) token("\"🦀") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..5 token("\"🦀") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 5 "\"\\x7f"
> error[0; 5) token("\"\\x7f") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..5 token("\"\\x7f") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 9 "\"\\u{20AA}"
> error[0; 9) token("\"\\u{20AA}") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..9 token("\"\\u{20AA}") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 2 "\" "
> error[0; 2) token("\" ") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..2 token("\" ") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 2 "\"\\"
> error[0; 2) token("\"\\") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..2 token("\"\\") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 3 "\"\\n"
> error[0; 3) token("\"\\n") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..3 token("\"\\n") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
STRING 3 "\"\\\""
> error[0; 3) token("\"\\\"") msg(Missing trailing `"` symbol to terminate the string literal)
> error0..3 token("\"\\\"") msg(Missing trailing `"` symbol to terminate the string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 2 "b\""
> error[0; 2) token("b\"") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..2 token("b\"") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 6 "b\"🦀"
> error[0; 6) token("b\"🦀") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..6 token("b\"🦀") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 6 "b\"\\x7f"
> error[0; 6) token("b\"\\x7f") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..6 token("b\"\\x7f") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 10 "b\"\\u{20AA}"
> error[0; 10) token("b\"\\u{20AA}") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..10 token("b\"\\u{20AA}") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 3 "b\" "
> error[0; 3) token("b\" ") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..3 token("b\" ") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 3 "b\"\\"
> error[0; 3) token("b\"\\") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..3 token("b\"\\") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 4 "b\"\\n"
> error[0; 4) token("b\"\\n") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..4 token("b\"\\n") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
BYTE_STRING 4 "b\"\\\""
> error[0; 4) token("b\"\\\"") msg(Missing trailing `"` symbol to terminate the byte string literal)
> error0..4 token("b\"\\\"") msg(Missing trailing `"` symbol to terminate the byte string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 4 "r##\""
> error[0; 4) token("r##\"") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..4 token("r##\"") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 8 "r##\"🦀"
> error[0; 8) token("r##\"🦀") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..8 token("r##\"🦀") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 8 "r##\"\\x7f"
> error[0; 8) token("r##\"\\x7f") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..8 token("r##\"\\x7f") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 12 "r##\"\\u{20AA}"
> error[0; 12) token("r##\"\\u{20AA}") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..12 token("r##\"\\u{20AA}") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 5 "r##\" "
> error[0; 5) token("r##\" ") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..5 token("r##\" ") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 5 "r##\"\\"
> error[0; 5) token("r##\"\\") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..5 token("r##\"\\") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 6 "r##\"\\n"
> error[0; 6) token("r##\"\\n") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)
> error0..6 token("r##\"\\n") msg(Missing trailing `"` with `#` symbols to terminate the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 5 "br##\""
> error[0; 5) token("br##\"") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..5 token("br##\"") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 9 "br##\"🦀"
> error[0; 9) token("br##\"🦀") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..9 token("br##\"🦀") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 9 "br##\"\\x7f"
> error[0; 9) token("br##\"\\x7f") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..9 token("br##\"\\x7f") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 13 "br##\"\\u{20AA}"
> error[0; 13) token("br##\"\\u{20AA}") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..13 token("br##\"\\u{20AA}") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 6 "br##\" "
> error[0; 6) token("br##\" ") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..6 token("br##\" ") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 6 "br##\"\\"
> error[0; 6) token("br##\"\\") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..6 token("br##\"\\") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 7 "br##\"\\n"
> error[0; 7) token("br##\"\\n") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)
> error0..7 token("br##\"\\n") msg(Missing trailing `"` with `#` symbols to terminate the raw byte string literal)

View file

@ -1,2 +1,2 @@
RAW_STRING 3 "r##"
> error[0; 3) token("r##") msg(Missing `"` symbol after `#` symbols to begin the raw string literal)
> error0..3 token("r##") msg(Missing `"` symbol after `#` symbols to begin the raw string literal)

View file

@ -1,2 +1,2 @@
RAW_BYTE_STRING 4 "br##"
> error[0; 4) token("br##") msg(Missing `"` symbol after `#` symbols to begin the raw byte string literal)
> error0..4 token("br##") msg(Missing `"` symbol after `#` symbols to begin the raw byte string literal)

View file

@ -7,4 +7,4 @@ IDENT 1 "a"
WHITESPACE 1 " "
IDENT 5 "quote"
BANG 1 "!"
> error[0; 4) token("r## ") msg(Missing `"` symbol after `#` symbols to begin the raw string literal)
> error0..4 token("r## ") msg(Missing `"` symbol after `#` symbols to begin the raw string literal)

View file

@ -7,4 +7,4 @@ IDENT 1 "a"
WHITESPACE 1 " "
IDENT 5 "quote"
BANG 1 "!"
> error[0; 5) token("br## ") msg(Missing `"` symbol after `#` symbols to begin the raw byte string literal)
> error0..5 token("br## ") msg(Missing `"` symbol after `#` symbols to begin the raw byte string literal)

View file

@ -1,2 +1,2 @@
COMMENT 2 "/*"
> error[0; 2) token("/*") msg(Missing trailing `*/` symbols to terminate the block comment)
> error0..2 token("/*") msg(Missing trailing `*/` symbols to terminate the block comment)

View file

@ -1,2 +1,2 @@
COMMENT 11 "/* comment\n"
> error[0; 11) token("/* comment\n") msg(Missing trailing `*/` symbols to terminate the block comment)
> error0..11 token("/* comment\n") msg(Missing trailing `*/` symbols to terminate the block comment)

View file

@ -1,2 +1,2 @@
COMMENT 9 "/* /* /*\n"
> error[0; 9) token("/* /* /*\n") msg(Missing trailing `*/` symbols to terminate the block comment)
> error0..9 token("/* /* /*\n") msg(Missing trailing `*/` symbols to terminate the block comment)

View file

@ -1,2 +1,2 @@
COMMENT 25 "/** /*! /* comment */ */\n"
> error[0; 25) token("/** /*! /* comment */ */\n") msg(Missing trailing `*/` symbols to terminate the block comment)
> error0..25 token("/** /*! /* comment */ */\n") msg(Missing trailing `*/` symbols to terminate the block comment)

View file

@ -24,16 +24,16 @@ INT_NUMBER 4 "0x_g"
WHITESPACE 1 "\n"
INT_NUMBER 4 "0x_G"
WHITESPACE 1 "\n"
> error[0; 2) token("0b") msg(Missing digits after the integer base prefix)
> error[3; 5) token("0o") msg(Missing digits after the integer base prefix)
> error[6; 8) token("0x") msg(Missing digits after the integer base prefix)
> error[10; 13) token("0b_") msg(Missing digits after the integer base prefix)
> error[14; 17) token("0o_") msg(Missing digits after the integer base prefix)
> error[18; 21) token("0x_") msg(Missing digits after the integer base prefix)
> error[23; 32) token("0bnoDigit") msg(Missing digits after the integer base prefix)
> error[33; 42) token("0onoDigit") msg(Missing digits after the integer base prefix)
> error[43; 52) token("0xnoDigit") msg(Missing digits after the integer base prefix)
> error[54; 57) token("0xG") msg(Missing digits after the integer base prefix)
> error[58; 61) token("0xg") msg(Missing digits after the integer base prefix)
> error[63; 67) token("0x_g") msg(Missing digits after the integer base prefix)
> error[68; 72) token("0x_G") msg(Missing digits after the integer base prefix)
> error0..2 token("0b") msg(Missing digits after the integer base prefix)
> error3..5 token("0o") msg(Missing digits after the integer base prefix)
> error6..8 token("0x") msg(Missing digits after the integer base prefix)
> error10..13 token("0b_") msg(Missing digits after the integer base prefix)
> error14..17 token("0o_") msg(Missing digits after the integer base prefix)
> error18..21 token("0x_") msg(Missing digits after the integer base prefix)
> error23..32 token("0bnoDigit") msg(Missing digits after the integer base prefix)
> error33..42 token("0onoDigit") msg(Missing digits after the integer base prefix)
> error43..52 token("0xnoDigit") msg(Missing digits after the integer base prefix)
> error54..57 token("0xG") msg(Missing digits after the integer base prefix)
> error58..61 token("0xg") msg(Missing digits after the integer base prefix)
> error63..67 token("0x_g") msg(Missing digits after the integer base prefix)
> error68..72 token("0x_G") msg(Missing digits after the integer base prefix)

View file

@ -46,17 +46,17 @@ FLOAT_NUMBER 9 "42.2E+f32"
WHITESPACE 1 "\n"
FLOAT_NUMBER 9 "42.2E-f32"
WHITESPACE 1 "\n"
> error[0; 2) token("0e") msg(Missing digits after the exponent symbol)
> error[3; 5) token("0E") msg(Missing digits after the exponent symbol)
> error[7; 11) token("42e+") msg(Missing digits after the exponent symbol)
> error[12; 16) token("42e-") msg(Missing digits after the exponent symbol)
> error[17; 21) token("42E+") msg(Missing digits after the exponent symbol)
> error[22; 26) token("42E-") msg(Missing digits after the exponent symbol)
> error[53; 59) token("42.2e+") msg(Missing digits after the exponent symbol)
> error[60; 66) token("42.2e-") msg(Missing digits after the exponent symbol)
> error[67; 73) token("42.2E+") msg(Missing digits after the exponent symbol)
> error[74; 80) token("42.2E-") msg(Missing digits after the exponent symbol)
> error[82; 91) token("42.2e+f32") msg(Missing digits after the exponent symbol)
> error[92; 101) token("42.2e-f32") msg(Missing digits after the exponent symbol)
> error[102; 111) token("42.2E+f32") msg(Missing digits after the exponent symbol)
> error[112; 121) token("42.2E-f32") msg(Missing digits after the exponent symbol)
> error0..2 token("0e") msg(Missing digits after the exponent symbol)
> error3..5 token("0E") msg(Missing digits after the exponent symbol)
> error7..11 token("42e+") msg(Missing digits after the exponent symbol)
> error12..16 token("42e-") msg(Missing digits after the exponent symbol)
> error17..21 token("42E+") msg(Missing digits after the exponent symbol)
> error22..26 token("42E-") msg(Missing digits after the exponent symbol)
> error53..59 token("42.2e+") msg(Missing digits after the exponent symbol)
> error60..66 token("42.2e-") msg(Missing digits after the exponent symbol)
> error67..73 token("42.2E+") msg(Missing digits after the exponent symbol)
> error74..80 token("42.2E-") msg(Missing digits after the exponent symbol)
> error82..91 token("42.2e+f32") msg(Missing digits after the exponent symbol)
> error92..101 token("42.2e-f32") msg(Missing digits after the exponent symbol)
> error102..111 token("42.2E+f32") msg(Missing digits after the exponent symbol)
> error112..121 token("42.2E-f32") msg(Missing digits after the exponent symbol)

View file

@ -2,5 +2,5 @@ LIFETIME 2 "\'1"
WHITESPACE 1 "\n"
LIFETIME 10 "\'1lifetime"
WHITESPACE 1 "\n"
> error[0; 2) token("\'1") msg(Lifetime name cannot start with a number)
> error[3; 13) token("\'1lifetime") msg(Lifetime name cannot start with a number)
> error0..2 token("\'1") msg(Lifetime name cannot start with a number)
> error3..13 token("\'1lifetime") msg(Lifetime name cannot start with a number)

View file

@ -1,34 +1,34 @@
SOURCE_FILE@[0; 34)
STRUCT_DEF@[0; 34)
STRUCT_KW@[0; 6) "struct"
WHITESPACE@[6; 7) " "
NAME@[7; 8)
IDENT@[7; 8) "S"
WHITESPACE@[8; 9) " "
RECORD_FIELD_DEF_LIST@[9; 34)
L_CURLY@[9; 10) "{"
WHITESPACE@[10; 15) "\n "
RECORD_FIELD_DEF@[15; 21)
NAME@[15; 16)
IDENT@[15; 16) "a"
COLON@[16; 17) ":"
WHITESPACE@[17; 18) " "
PATH_TYPE@[18; 21)
PATH@[18; 21)
PATH_SEGMENT@[18; 21)
NAME_REF@[18; 21)
IDENT@[18; 21) "u32"
WHITESPACE@[21; 26) "\n "
RECORD_FIELD_DEF@[26; 32)
NAME@[26; 27)
IDENT@[26; 27) "b"
COLON@[27; 28) ":"
WHITESPACE@[28; 29) " "
PATH_TYPE@[29; 32)
PATH@[29; 32)
PATH_SEGMENT@[29; 32)
NAME_REF@[29; 32)
IDENT@[29; 32) "u32"
WHITESPACE@[32; 33) "\n"
R_CURLY@[33; 34) "}"
error [21; 21): expected COMMA
SOURCE_FILE@0..34
STRUCT_DEF@0..34
STRUCT_KW@0..6 "struct"
WHITESPACE@6..7 " "
NAME@7..8
IDENT@7..8 "S"
WHITESPACE@8..9 " "
RECORD_FIELD_DEF_LIST@9..34
L_CURLY@9..10 "{"
WHITESPACE@10..15 "\n "
RECORD_FIELD_DEF@15..21
NAME@15..16
IDENT@15..16 "a"
COLON@16..17 ":"
WHITESPACE@17..18 " "
PATH_TYPE@18..21
PATH@18..21
PATH_SEGMENT@18..21
NAME_REF@18..21
IDENT@18..21 "u32"
WHITESPACE@21..26 "\n "
RECORD_FIELD_DEF@26..32
NAME@26..27
IDENT@26..27 "b"
COLON@27..28 ":"
WHITESPACE@28..29 " "
PATH_TYPE@29..32
PATH@29..32
PATH_SEGMENT@29..32
NAME_REF@29..32
IDENT@29..32 "u32"
WHITESPACE@32..33 "\n"
R_CURLY@33..34 "}"
error 21..21: expected COMMA

View file

@ -1,18 +1,18 @@
SOURCE_FILE@[0; 21)
ERROR@[0; 2)
IF_KW@[0; 2) "if"
WHITESPACE@[2; 3) " "
ERROR@[3; 8)
MATCH_KW@[3; 8) "match"
WHITESPACE@[8; 10) "\n\n"
STRUCT_DEF@[10; 21)
STRUCT_KW@[10; 16) "struct"
WHITESPACE@[16; 17) " "
NAME@[17; 18)
IDENT@[17; 18) "S"
WHITESPACE@[18; 19) " "
RECORD_FIELD_DEF_LIST@[19; 21)
L_CURLY@[19; 20) "{"
R_CURLY@[20; 21) "}"
error [0; 0): expected an item
error [3; 3): expected an item
SOURCE_FILE@0..21
ERROR@0..2
IF_KW@0..2 "if"
WHITESPACE@2..3 " "
ERROR@3..8
MATCH_KW@3..8 "match"
WHITESPACE@8..10 "\n\n"
STRUCT_DEF@10..21
STRUCT_KW@10..16 "struct"
WHITESPACE@16..17 " "
NAME@17..18
IDENT@17..18 "S"
WHITESPACE@18..19 " "
RECORD_FIELD_DEF_LIST@19..21
L_CURLY@19..20 "{"
R_CURLY@20..21 "}"
error 0..0: expected an item
error 3..3: expected an item

View file

@ -1,39 +1,39 @@
SOURCE_FILE@[0; 42)
SHEBANG@[0; 20) "#!/use/bin/env rusti"
WHITESPACE@[20; 21) "\n"
ATTR@[21; 23)
POUND@[21; 22) "#"
BANG@[22; 23) "!"
ERROR@[23; 24)
SLASH@[23; 24) "/"
USE_ITEM@[24; 28)
USE_KW@[24; 27) "use"
ERROR@[27; 28)
SLASH@[27; 28) "/"
MACRO_CALL@[28; 31)
PATH@[28; 31)
PATH_SEGMENT@[28; 31)
NAME_REF@[28; 31)
IDENT@[28; 31) "bin"
ERROR@[31; 32)
SLASH@[31; 32) "/"
MACRO_CALL@[32; 41)
PATH@[32; 35)
PATH_SEGMENT@[32; 35)
NAME_REF@[32; 35)
IDENT@[32; 35) "env"
WHITESPACE@[35; 36) " "
NAME@[36; 41)
IDENT@[36; 41) "rusti"
WHITESPACE@[41; 42) "\n"
error [23; 23): expected `[`
error [23; 23): expected an item
error [27; 27): expected one of `*`, `::`, `{`, `self`, `super` or an identifier
error [28; 28): expected SEMICOLON
error [31; 31): expected BANG
error [31; 31): expected `{`, `[`, `(`
error [31; 31): expected SEMICOLON
error [31; 31): expected an item
error [35; 35): expected BANG
error [41; 41): expected `{`, `[`, `(`
error [41; 41): expected SEMICOLON
SOURCE_FILE@0..42
SHEBANG@0..20 "#!/use/bin/env rusti"
WHITESPACE@20..21 "\n"
ATTR@21..23
POUND@21..22 "#"
BANG@22..23 "!"
ERROR@23..24
SLASH@23..24 "/"
USE_ITEM@24..28
USE_KW@24..27 "use"
ERROR@27..28
SLASH@27..28 "/"
MACRO_CALL@28..31
PATH@28..31
PATH_SEGMENT@28..31
NAME_REF@28..31
IDENT@28..31 "bin"
ERROR@31..32
SLASH@31..32 "/"
MACRO_CALL@32..41
PATH@32..35
PATH_SEGMENT@32..35
NAME_REF@32..35
IDENT@32..35 "env"
WHITESPACE@35..36 " "
NAME@36..41
IDENT@36..41 "rusti"
WHITESPACE@41..42 "\n"
error 23..23: expected `[`
error 23..23: expected an item
error 27..27: expected one of `*`, `::`, `{`, `self`, `super` or an identifier
error 28..28: expected SEMICOLON
error 31..31: expected BANG
error 31..31: expected `{`, `[`, `(`
error 31..31: expected SEMICOLON
error 31..31: expected an item
error 35..35: expected BANG
error 41..41: expected `{`, `[`, `(`
error 41..41: expected SEMICOLON

Some files were not shown because too many files have changed in this diff Show more