@@ -7,6 +7,8 @@ use std::{io, iter};
7
7
8
8
use super :: { AssertMessage , BinOp , TerminatorKind } ;
9
9
10
+ use super :: BorrowKind ;
11
+
10
12
pub fn function_name ( item : CrateItem ) -> String {
11
13
let mut pretty_name = String :: new ( ) ;
12
14
let body = item. body ( ) ;
@@ -40,7 +42,6 @@ pub fn function_body(body: &Body) -> String {
40
42
pretty_body. push_str ( format ! ( "{}" , pretty_ty( local. ty. kind( ) ) ) . as_str ( ) ) ;
41
43
pretty_body. push_str ( ";\n " ) ;
42
44
} ) ;
43
- pretty_body. push_str ( "}" ) ;
44
45
pretty_body
45
46
}
46
47
@@ -304,6 +305,7 @@ pub fn pretty_rvalue(rval: &Rvalue) -> String {
304
305
pretty. push_str ( format ! ( "(*_{})" , addr. local) . as_str ( ) ) ;
305
306
}
306
307
Rvalue :: Aggregate ( aggregatekind, operands) => {
308
+ // FIXME: Add pretty_aggregate function that returns a pretty string
307
309
pretty. push_str ( format ! ( "{:#?}" , aggregatekind) . as_str ( ) ) ;
308
310
pretty. push_str ( "(" ) ;
309
311
operands. iter ( ) . enumerate ( ) . for_each ( |( i, op) | {
@@ -314,24 +316,26 @@ pub fn pretty_rvalue(rval: &Rvalue) -> String {
314
316
} ) ;
315
317
pretty. push_str ( ")" ) ;
316
318
}
317
- Rvalue :: BinaryOp ( bin, op, op2) => {
318
- pretty. push_str ( & pretty_operand ( op) ) ;
319
- pretty. push_str ( " " ) ;
319
+ Rvalue :: BinaryOp ( bin, op1, op2) => {
320
320
pretty. push_str ( format ! ( "{:#?}" , bin) . as_str ( ) ) ;
321
- pretty. push_str ( " " ) ;
322
- pretty. push_str ( & pretty_operand ( op2) ) ;
321
+ pretty. push_str ( "(" ) ;
322
+ pretty. push_str ( format ! ( "_{}" , & pretty_operand( op1) ) . as_str ( ) ) ;
323
+ pretty. push_str ( ", " ) ;
324
+ pretty. push_str ( format ! ( "{}" , & pretty_operand( op2) ) . as_str ( ) ) ;
325
+ pretty. push_str ( ")" ) ;
323
326
}
324
327
Rvalue :: Cast ( _, op, ty) => {
325
328
pretty. push_str ( & pretty_operand ( op) ) ;
326
329
pretty. push_str ( " as " ) ;
327
330
pretty. push_str ( & pretty_ty ( ty. kind ( ) ) ) ;
328
331
}
329
332
Rvalue :: CheckedBinaryOp ( bin, op1, op2) => {
330
- pretty. push_str ( & pretty_operand ( op1) ) ;
331
- pretty. push_str ( " " ) ;
332
- pretty. push_str ( format ! ( "{:#?}" , bin) . as_str ( ) ) ;
333
- pretty. push_str ( " " ) ;
334
- pretty. push_str ( & pretty_operand ( op2) ) ;
333
+ pretty. push_str ( format ! ( "Checked{:#?}" , bin) . as_str ( ) ) ;
334
+ pretty. push_str ( "(" ) ;
335
+ pretty. push_str ( format ! ( "_{}" , & pretty_operand( op1) ) . as_str ( ) ) ;
336
+ pretty. push_str ( ", " ) ;
337
+ pretty. push_str ( format ! ( "{}" , & pretty_operand( op2) ) . as_str ( ) ) ;
338
+ pretty. push_str ( ")" ) ;
335
339
}
336
340
Rvalue :: CopyForDeref ( deref) => {
337
341
pretty. push_str ( "CopyForDeref" ) ;
@@ -346,8 +350,11 @@ pub fn pretty_rvalue(rval: &Rvalue) -> String {
346
350
pretty. push_str ( format ! ( "{}" , len. local) . as_str ( ) ) ;
347
351
}
348
352
Rvalue :: Ref ( _, borrowkind, place) => {
349
- pretty. push_str ( "ref" ) ;
350
- pretty. push_str ( format ! ( "{:#?}" , borrowkind) . as_str ( ) ) ;
353
+ match borrowkind {
354
+ BorrowKind :: Shared => pretty. push_str ( "&" ) ,
355
+ BorrowKind :: Fake => pretty. push_str ( "&fake " ) ,
356
+ BorrowKind :: Mut { .. } => pretty. push_str ( "&mut " ) ,
357
+ }
351
358
pretty. push_str ( format ! ( "{}" , place. local) . as_str ( ) ) ;
352
359
}
353
360
Rvalue :: Repeat ( op, cnst) => {
@@ -402,7 +409,7 @@ pub fn pretty_ty(ty: TyKind) -> String {
402
409
FloatTy :: F64 => "f64" . to_string ( ) ,
403
410
} ,
404
411
RigidTy :: Adt ( def, _) => {
405
- format ! ( "{:#? }" , with( |cx| cx. def_ty ( def. 0 ) ) )
412
+ format ! ( "{}" , with( |cx| cx. adt_literal ( & def) ) )
406
413
}
407
414
RigidTy :: Str => "str" . to_string ( ) ,
408
415
RigidTy :: Array ( ty, len) => {
0 commit comments