Add indent_match_arms option (#1404)

Makes it optional whether to indent arms in match expressions. Setting this
to false may be desirable for people wishing to avoid double-indents, in
that if the match arm is a block, the block will cause an extra indentation
level, and if it isn't a block but just a single line, it's still easy to
see the logic at a glance.

This style is preferred in certain other languages with switch statements,
e.g. Linux style C and the most common Java style.
This commit is contained in:
C4K3 2017-03-26 07:32:29 +02:00 committed by Nick Cameron
parent 0dd0cc1941
commit abca1deded
4 changed files with 64 additions and 1 deletions

View file

@ -388,6 +388,8 @@ create_config! {
wrap_match_arms: bool, true, "Wrap multiline match arms in blocks";
match_block_trailing_comma: bool, false,
"Put a trailing comma after a block based match arm (non-block arms are not affected)";
indent_match_arms: bool, true, "Indent match arms instead of keeping them at the same \
indentation level as the match keyword";
closure_block_indent_threshold: isize, 7, "How many lines a closure must have before it is \
block indented. -1 means never use block indent.";
space_before_type_annotation: bool, false,

View file

@ -1137,7 +1137,12 @@ fn rewrite_match(context: &RewriteContext,
};
let mut result = format!("match {}{}{{", cond_str, block_sep);
let arm_shape = shape.block_indent(context.config.tab_spaces);
let arm_shape = if context.config.indent_match_arms {
shape.block_indent(context.config.tab_spaces)
} else {
shape.block_indent(0)
};
let arm_indent_str = arm_shape.indent.to_string(context.config);
let open_brace_pos = context.codemap.span_after(mk_sp(cond.span.hi, arm_start_pos(&arms[0])),

View file

@ -0,0 +1,27 @@
// rustfmt-indent_match_arms: false
fn main() {
match x {
1 => "one",
2 => "two",
3 => "three",
4 => "four",
5 => "five",
_ => "something else",
}
match x {
1 => "one",
2 => "two",
3 => "three",
4 => "four",
5 => match y {
'a' => 'A',
'b' => 'B',
'c' => 'C',
_ => "Nope",
},
_ => "something else",
}
}

View file

@ -0,0 +1,29 @@
// rustfmt-indent_match_arms: false
fn main() {
match x {
1 => "one",
2 => "two",
3 => "three",
4 => "four",
5 => "five",
_ => "something else",
}
match x {
1 => "one",
2 => "two",
3 => "three",
4 => "four",
5 => {
match y {
'a' => 'A',
'b' => 'B',
'c' => 'C',
_ => "Nope",
}
}
_ => "something else",
}
}