Skip to content

Commit bf2d91b

Browse files
bors[bot]lnicola
andauthored
Merge #3858
3858: Hide unit function return types r=flodiebold a=lnicola r? @flodiebold This might be a bit heavy-handed (e.g. `|| -> ()` to `||`), what do you think? Co-authored-by: Laurențiu Nicola <[email protected]>
2 parents 3431312 + 7d62280 commit bf2d91b

File tree

5 files changed

+28
-20
lines changed

5 files changed

+28
-20
lines changed

crates/ra_hir_ty/src/display.rs

Lines changed: 14 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -155,7 +155,11 @@ impl HirDisplay for ApplicationTy {
155155
let sig = FnSig::from_fn_ptr_substs(&self.parameters);
156156
write!(f, "fn(")?;
157157
f.write_joined(sig.params(), ", ")?;
158-
write!(f, ") -> {}", sig.ret().display(f.db))?;
158+
write!(f, ")")?;
159+
let ret = sig.ret();
160+
if *ret != Ty::unit() {
161+
write!(f, " -> {}", ret.display(f.db))?;
162+
}
159163
}
160164
TypeCtor::FnDef(def) => {
161165
let sig = f.db.callable_item_signature(def).subst(&self.parameters);
@@ -180,7 +184,11 @@ impl HirDisplay for ApplicationTy {
180184
}
181185
write!(f, "(")?;
182186
f.write_joined(sig.params(), ", ")?;
183-
write!(f, ") -> {}", sig.ret().display(f.db))?;
187+
write!(f, ")")?;
188+
let ret = sig.ret();
189+
if *ret != Ty::unit() {
190+
write!(f, " -> {}", ret.display(f.db))?;
191+
}
184192
}
185193
TypeCtor::Adt(def_id) => {
186194
let name = match def_id {
@@ -242,16 +250,16 @@ impl HirDisplay for ApplicationTy {
242250
let sig = self.parameters[0]
243251
.callable_sig(f.db)
244252
.expect("first closure parameter should contain signature");
245-
let return_type_hint = sig.ret().display(f.db);
246253
if sig.params().is_empty() {
247-
write!(f, "|| -> {}", return_type_hint)?;
254+
write!(f, "||")?;
248255
} else if f.omit_verbose_types() {
249-
write!(f, "|{}| -> {}", TYPE_HINT_TRUNCATION, return_type_hint)?;
256+
write!(f, "|{}|", TYPE_HINT_TRUNCATION)?;
250257
} else {
251258
write!(f, "|")?;
252259
f.write_joined(sig.params(), ", ")?;
253-
write!(f, "| -> {}", return_type_hint)?;
260+
write!(f, "|")?;
254261
};
262+
write!(f, " -> {}", sig.ret().display(f.db))?;
255263
}
256264
}
257265
Ok(())

crates/ra_hir_ty/src/tests/coercion.rs

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -407,16 +407,16 @@ fn test() {
407407
[30; 31) 'x': &Foo
408408
[39; 41) '{}': ()
409409
[52; 133) '{ ...oo); }': ()
410-
[58; 71) 'takes_ref_foo': fn takes_ref_foo(&Foo) -> ()
410+
[58; 71) 'takes_ref_foo': fn takes_ref_foo(&Foo)
411411
[58; 77) 'takes_...(&Foo)': ()
412412
[72; 76) '&Foo': &Foo
413413
[73; 76) 'Foo': Foo
414-
[83; 96) 'takes_ref_foo': fn takes_ref_foo(&Foo) -> ()
414+
[83; 96) 'takes_ref_foo': fn takes_ref_foo(&Foo)
415415
[83; 103) 'takes_...&&Foo)': ()
416416
[97; 102) '&&Foo': &&Foo
417417
[98; 102) '&Foo': &Foo
418418
[99; 102) 'Foo': Foo
419-
[109; 122) 'takes_ref_foo': fn takes_ref_foo(&Foo) -> ()
419+
[109; 122) 'takes_ref_foo': fn takes_ref_foo(&Foo)
420420
[109; 130) 'takes_...&&Foo)': ()
421421
[123; 129) '&&&Foo': &&&Foo
422422
[124; 129) '&&Foo': &&Foo
@@ -484,7 +484,7 @@ fn test() {
484484
[171; 178) 'loop {}': !
485485
[176; 178) '{}': ()
486486
[191; 236) '{ ... }); }': ()
487-
[197; 210) 'takes_ref_str': fn takes_ref_str(&str) -> ()
487+
[197; 210) 'takes_ref_str': fn takes_ref_str(&str)
488488
[197; 233) 'takes_...g() })': ()
489489
[211; 232) '&{ ret...ng() }': &String
490490
[212; 232) '{ retu...ng() }': String

crates/ra_hir_ty/src/tests/regression.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -376,7 +376,7 @@ fn issue_2669() {
376376
),
377377
@r###"
378378
[147; 262) '{ ... }': ()
379-
[161; 164) 'end': fn end<{unknown}>() -> ()
379+
[161; 164) 'end': fn end<{unknown}>()
380380
[161; 166) 'end()': ()
381381
[199; 252) '{ ... }': ()
382382
[221; 223) '_x': !

crates/ra_hir_ty/src/tests/simple.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -521,7 +521,7 @@ fn test() -> &mut &f64 {
521521
[88; 89) 'a': u32
522522
[92; 108) 'unknow...nction': {unknown}
523523
[92; 110) 'unknow...tion()': u32
524-
[116; 125) 'takes_u32': fn takes_u32(u32) -> ()
524+
[116; 125) 'takes_u32': fn takes_u32(u32)
525525
[116; 128) 'takes_u32(a)': ()
526526
[126; 127) 'a': u32
527527
[138; 139) 'b': i32
@@ -1749,9 +1749,9 @@ fn main() {
17491749
[67; 91) 'Vtable...| {} }': Vtable
17501750
[84; 89) '|| {}': || -> ()
17511751
[87; 89) '{}': ()
1752-
[101; 102) 'm': fn() -> ()
1752+
[101; 102) 'm': fn()
17531753
[105; 111) 'vtable': Vtable
1754-
[105; 118) 'vtable.method': fn() -> ()
1754+
[105; 118) 'vtable.method': fn()
17551755
"###
17561756
);
17571757
}

crates/ra_hir_ty/src/tests/traits.rs

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -263,7 +263,7 @@ fn test() {
263263
[119; 120) 'S': S<u32>(u32) -> S<u32>
264264
[119; 129) 'S(unknown)': S<u32>
265265
[121; 128) 'unknown': u32
266-
[135; 138) 'foo': fn foo<S<u32>>(S<u32>) -> ()
266+
[135; 138) 'foo': fn foo<S<u32>>(S<u32>)
267267
[135; 141) 'foo(s)': ()
268268
[139; 140) 's': S<u32>
269269
"###
@@ -962,7 +962,7 @@ fn test(x: impl Trait<u64>, y: &impl Trait<u32>) {
962962
[224; 225) 'S': S<u16>(u16) -> S<u16>
963963
[224; 228) 'S(1)': S<u16>
964964
[226; 227) '1': u16
965-
[234; 237) 'bar': fn bar(S<u16>) -> ()
965+
[234; 237) 'bar': fn bar(S<u16>)
966966
[234; 240) 'bar(z)': ()
967967
[238; 239) 'z': S<u16>
968968
[246; 247) 'x': impl Trait<u64>
@@ -1108,8 +1108,8 @@ fn test() {
11081108
[40; 47) 'loop {}': !
11091109
[45; 47) '{}': ()
11101110
[91; 124) '{ ...foo; }': ()
1111-
[101; 102) 'f': fn(S) -> ()
1112-
[118; 121) 'foo': fn foo(S) -> ()
1111+
[101; 102) 'f': fn(S)
1112+
[118; 121) 'foo': fn foo(S)
11131113
"###
11141114
);
11151115
}
@@ -1962,7 +1962,7 @@ fn test() -> impl Trait<i32> {
19621962
[229; 241) 'S(default())': S<u32>
19631963
[231; 238) 'default': fn default<u32>() -> u32
19641964
[231; 240) 'default()': u32
1965-
[247; 250) 'foo': fn foo(S<u32>) -> ()
1965+
[247; 250) 'foo': fn foo(S<u32>)
19661966
[247; 254) 'foo(s1)': ()
19671967
[251; 253) 's1': S<u32>
19681968
[264; 265) 'x': i32
@@ -2012,7 +2012,7 @@ fn main() {
20122012
[147; 149) '_v': F
20132013
[192; 195) '{ }': ()
20142014
[207; 238) '{ ... }); }': ()
2015-
[213; 223) 'f::<(), _>': fn f<(), |&()| -> ()>(|&()| -> ()) -> ()
2015+
[213; 223) 'f::<(), _>': fn f<(), |&()| -> ()>(|&()| -> ())
20162016
[213; 235) 'f::<()... z; })': ()
20172017
[224; 234) '|z| { z; }': |&()| -> ()
20182018
[225; 226) 'z': &()

0 commit comments

Comments
 (0)