rust/tests/target/match.rs

486 lines
13 KiB
Rust
Raw Normal View History

// rustfmt-normalize_comments: true
2015-08-14 20:00:22 +12:00
// Match expressions.
fn foo() {
// A match expression.
match x {
// Some comment.
a => foo(),
b if 0 < 42 => foo(),
2015-10-19 21:41:47 +02:00
c => {
// Another comment.
2015-08-14 20:00:22 +12:00
// Comment.
an_expression;
foo()
}
2015-11-20 21:05:10 +01:00
Foo(ref bar) => {
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
}
2015-08-14 20:00:22 +12:00
Pattern1 | Pattern2 | Pattern3 => false,
2017-11-16 16:42:11 +09:00
Paternnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn
| Paternnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn => blah,
Patternnnnnnnnnnnnnnnnnnn
| Patternnnnnnnnnnnnnnnnnnn
| Patternnnnnnnnnnnnnnnnnnn
| Patternnnnnnnnnnnnnnnnnnn => meh,
2015-08-14 20:00:22 +12:00
2017-07-10 02:25:26 +09:00
Patternnnnnnnnnnnnnnnnnnn | Patternnnnnnnnnnnnnnnnnnn if looooooooooooooooooong_guard => {
2015-11-20 21:05:10 +01:00
meh
}
2015-08-17 09:41:45 +12:00
2017-07-10 02:25:26 +09:00
Patternnnnnnnnnnnnnnnnnnnnnnnnn | Patternnnnnnnnnnnnnnnnnnnnnnnnn
2017-07-20 00:01:38 +09:00
if looooooooooooooooooooooooooooooooooooooooong_guard =>
{
meh
}
2017-07-10 02:25:26 +09:00
2015-08-17 09:41:45 +12:00
// Test that earlier patterns can take the guard space
2017-11-16 16:42:11 +09:00
(aaaa, bbbbb, ccccccc, aaaaa, bbbbbbbb, cccccc, aaaa, bbbbbbbb, cccccc, dddddd)
| Patternnnnnnnnnnnnnnnnnnnnnnnnn
if loooooooooooooooooooooooooooooooooooooooooong_guard => {}
2015-08-17 09:41:45 +12:00
2015-08-14 20:00:22 +12:00
_ => {}
2017-06-14 20:39:07 +09:00
ast::PathParameters::AngleBracketedParameters(ref data)
if data.lifetimes.len() > 0 || data.types.len() > 0 || data.bindings.len() > 0 => {}
2015-08-14 20:00:22 +12:00
}
let whatever = match something {
/// DOC COMMENT!
Some(_) => 42,
// Comment on an attribute.
2015-08-14 20:00:22 +12:00
#[an_attribute]
2015-08-17 09:41:45 +12:00
// Comment after an attribute.
2015-08-14 20:00:22 +12:00
None => 0,
2015-08-17 09:41:45 +12:00
#[rustfmt_skip]
Blurb => { }
2015-08-14 20:00:22 +12:00
};
}
// Test that a match on an overflow line is laid out properly.
fn main() {
let sub_span =
2015-09-09 23:15:37 +02:00
match xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx {
Some(sub_span) => Some(sub_span),
None => sub_span,
};
}
// Test that one-line bodies align.
fn main() {
match r {
2017-06-12 16:01:41 +12:00
Variableeeeeeeeeeeeeeeeee => (
"variable",
vec!["id", "name", "qualname", "value", "type", "scopeid"],
true,
true,
),
Enummmmmmmmmmmmmmmmmmmmm => (
"enum",
vec!["id", "qualname", "scopeid", "value"],
true,
true,
),
Variantttttttttttttttttttttttt => (
"variant",
2017-06-16 18:56:38 +09:00
vec!["id", "name", "qualname", "type", "value", "scopeid"],
2017-06-12 16:01:41 +12:00
true,
true,
),
2015-11-14 21:59:04 +01:00
};
match x {
y => { /*Block with comment. Preserve me.*/ }
2015-11-14 21:59:04 +01:00
z => {
stmt();
}
}
}
fn matches() {
match 1 {
2015-10-17 15:56:53 +02:00
-1 => 10,
1 => 1, // foo
2 => 2,
// bar
3 => 3,
_ => 0, // baz
}
}
fn match_skip() {
let _ = match Some(1) {
#[rustfmt_skip]
Some( n ) => n,
None => 1,
};
}
fn issue339() {
match a {
b => {}
c => {}
d => {}
e => {}
// collapsing here is safe
ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff => {}
// collapsing here exceeds line length
ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffg => {
}
2015-10-19 21:41:47 +02:00
h => {
// comment above block
}
2017-11-15 10:56:26 +09:00
i => {} // comment below block
j => {
// comment inside block
}
j2 => {
// comments inside...
2017-11-15 10:56:26 +09:00
} // ... and after
// TODO uncomment when vertical whitespace is handled better
// k => {
//
// // comment with WS above
// }
// l => {
// // comment with ws below
//
// }
m => {}
n => {}
o => {}
2015-10-19 21:41:47 +02:00
p => {
// Dont collapse me
}
q => {}
r => {}
s => 0, // s comment
// t comment
t => 1,
u => 2,
2017-08-18 23:20:12 +09:00
v => {} /* funky block
* comment */
/* final comment */
}
}
fn issue355() {
match mac {
a => println!("a", b),
2015-10-16 22:54:32 +02:00
b => vec![1, 2],
2017-05-19 19:25:53 +09:00
c => vec![3; 4],
d => println!("a", b),
e => vec![1, 2],
2017-05-19 19:25:53 +09:00
f => vec![3; 4],
h => println!("a", b), // h comment
2017-08-18 23:20:12 +09:00
i => vec![1, 2], // i comment
j => vec![3; 4], // j comment
// k comment
k => println!("a", b),
// l comment
2015-10-16 22:54:32 +02:00
l => vec![1, 2],
// m comment
2017-05-19 19:25:53 +09:00
m => vec![3; 4],
// Rewrite splits macro
2015-11-20 21:05:10 +01:00
nnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn => {
println!("a", b)
}
// Rewrite splits macro
2015-11-20 21:05:10 +01:00
oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo => {
vec![1, 2]
}
2017-11-01 07:33:55 +01:00
// Macro support fails to recognise this macro as splittable
// We push the whole expr to a new line, TODO split this macro as well
2015-11-20 21:05:10 +01:00
pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp => {
2017-05-19 19:25:53 +09:00
vec![3; 4]
2015-11-20 21:05:10 +01:00
}
// q, r and s: Rewrite splits match arm
2015-11-20 21:05:10 +01:00
qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq => {
println!("a", b)
}
rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr => {
vec![1, 2]
}
ssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss => {
2017-05-19 19:25:53 +09:00
vec![3; 4]
2015-11-20 21:05:10 +01:00
}
// Funky bracketing styles
t => println!{"a", b},
2015-10-16 22:54:32 +02:00
u => vec![1, 2],
2017-05-19 19:25:53 +09:00
v => vec![3; 4],
w => println!["a", b],
x => vec![1, 2],
y => vec![3; 4],
// Brackets with comments
tc => println!{"a", b}, // comment
2017-08-18 23:20:12 +09:00
uc => vec![1, 2], // comment
vc => vec![3; 4], // comment
wc => println!["a", b], // comment
2017-08-18 23:20:12 +09:00
xc => vec![1, 2], // comment
yc => vec![3; 4], // comment
2017-07-11 21:53:48 +09:00
yd => looooooooooooooooooooooooooooooooooooooooooooooooooooooooong_func(
aaaaaaaaaa,
bbbbbbbbbb,
cccccccccc,
dddddddddd,
),
}
}
fn issue280() {
{
match x {
2017-07-10 02:25:26 +09:00
CompressionMode::DiscardNewline | CompressionMode::CompressWhitespaceNewline => {
ch == '\n'
}
2015-11-20 21:05:10 +01:00
ast::ItemConst(ref typ, ref expr) => {
self.process_static_or_const_item(item, &typ, &expr)
}
}
}
}
fn issue383() {
match resolution.last_private {
LastImport { .. } => false,
_ => true,
};
}
fn issue507() {
match 1 {
1 => unsafe { std::intrinsics::abort() },
_ => (),
}
}
fn issue508() {
match s.type_id() {
Some(
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLCanvasElement)),
) => true,
Some(
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLObjectElement)),
) => s.has_object_data(),
Some(NodeTypeId::Element(_)) => false,
}
}
2015-10-23 21:20:43 +02:00
fn issue496() {
{
{
{
match def {
2017-07-10 02:25:26 +09:00
def::DefConst(def_id) | def::DefAssociatedConst(def_id) => {
2015-10-23 21:20:43 +02:00
match const_eval::lookup_const_by_id(cx.tcx, def_id, Some(self.pat.id)) {
Some(const_expr) => x,
2015-11-20 21:05:10 +01:00
}
}
2015-10-23 21:20:43 +02:00
}
}
}
}
}
fn issue494() {
{
match stmt.node {
2017-07-10 02:25:26 +09:00
hir::StmtExpr(ref expr, id) | hir::StmtSemi(ref expr, id) => {
2015-10-23 21:20:43 +02:00
result.push(StmtRef::Mirror(Box::new(Stmt {
2017-06-12 16:01:41 +12:00
span: stmt.span,
kind: StmtKind::Expr {
scope: cx.tcx.region_maps.node_extent(id),
expr: expr.to_ref(),
},
})))
2015-11-20 21:05:10 +01:00
}
2015-10-23 21:20:43 +02:00
}
}
}
fn issue386() {
match foo {
BiEq | BiLt | BiLe | BiNe | BiGt | BiGe => true,
2017-11-16 17:37:01 +09:00
BiAnd | BiOr | BiAdd | BiSub | BiMul | BiDiv | BiRem | BiBitXor | BiBitAnd | BiBitOr
| BiShl | BiShr => false,
}
}
fn guards() {
match foo {
2017-06-14 20:39:07 +09:00
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
if foooooooooooooo && barrrrrrrrrrrr => {}
2017-11-16 16:42:11 +09:00
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
2017-06-14 20:39:07 +09:00
if foooooooooooooo && barrrrrrrrrrrr => {}
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
2017-09-15 12:20:58 +09:00
if fooooooooooooooooooooo
&& (bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
|| cccccccccccccccccccccccccccccccccccccccc) => {}
}
}
2017-04-19 10:14:27 +09:00
fn issue1371() {
Some(match type_ {
2017-06-12 16:01:41 +12:00
sfEvtClosed => Closed,
sfEvtResized => {
let e = unsafe { *event.size.as_ref() };
2017-04-19 10:14:27 +09:00
2017-06-12 16:01:41 +12:00
Resized {
width: e.width,
height: e.height,
}
}
sfEvtLostFocus => LostFocus,
sfEvtGainedFocus => GainedFocus,
2017-07-11 21:53:48 +09:00
sfEvtTextEntered => TextEntered {
unicode: unsafe {
::std::char::from_u32((*event.text.as_ref()).unicode)
.expect("Invalid unicode encountered on TextEntered event")
},
},
2017-06-12 16:01:41 +12:00
sfEvtKeyPressed => {
let e = unsafe { event.key.as_ref() };
2017-04-19 10:14:27 +09:00
2017-06-12 16:01:41 +12:00
KeyPressed {
code: unsafe { ::std::mem::transmute(e.code) },
alt: e.alt.to_bool(),
ctrl: e.control.to_bool(),
shift: e.shift.to_bool(),
system: e.system.to_bool(),
}
}
sfEvtKeyReleased => {
let e = unsafe { event.key.as_ref() };
2017-04-19 10:14:27 +09:00
2017-06-12 16:01:41 +12:00
KeyReleased {
code: unsafe { ::std::mem::transmute(e.code) },
alt: e.alt.to_bool(),
ctrl: e.control.to_bool(),
shift: e.shift.to_bool(),
system: e.system.to_bool(),
}
}
})
2017-04-19 10:14:27 +09:00
}
fn issue1395() {
let bar = Some(true);
let foo = Some(true);
let mut x = false;
bar.and_then(|_| match foo {
2017-06-12 16:01:41 +12:00
None => None,
Some(b) => {
x = true;
Some(b)
}
});
2017-04-19 10:14:27 +09:00
}
fn issue1456() {
Ok(Recording {
artists: match reader.evaluate(".//mb:recording/mb:artist-credit/mb:name-credit")? {
2017-06-12 16:01:41 +12:00
Nodeset(nodeset) => {
let res: Result<Vec<ArtistRef>, ReadError> = nodeset
.iter()
.map(|node| {
XPathNodeReader::new(node, &context).and_then(|r| ArtistRef::from_xml(&r))
})
.collect();
res?
}
_ => Vec::new(),
},
})
2017-04-19 10:14:27 +09:00
}
2017-05-01 20:00:21 +09:00
fn issue1460() {
let _ = match foo {
REORDER_BUFFER_CHANGE_INTERNAL_SPEC_INSERT => {
"internal_spec_insert_internal_spec_insert_internal_spec_insert"
}
_ => "reorder_something",
};
}
fn issue525() {
2017-06-12 16:01:41 +12:00
foobar(
f,
"{}",
match *self {
TaskState::Started => "started",
TaskState::Success => "success",
TaskState::Failed => "failed",
},
);
}
2017-07-31 16:24:18 +09:00
// #1838, #1839
fn match_with_near_max_width() {
let (this_line_uses_99_characters_and_is_formatted_properly, x012345) = match some_expression {
_ => unimplemented!(),
};
let (should_be_formatted_like_the_line_above_using_100_characters, x0) = match some_expression {
_ => unimplemented!(),
};
let (should_put_the_brace_on_the_next_line_using_101_characters, x0000) = match some_expression
{
_ => unimplemented!(),
};
match m {
2017-11-16 16:42:11 +09:00
Variant::Tag
| Variant::Tag2
| Variant::Tag3
| Variant::Tag4
| Variant::Tag5
| Variant::Tag6 => {}
2017-07-31 16:24:18 +09:00
}
}
2017-08-05 15:24:20 +09:00
fn match_with_trailing_spaces() {
match x {
#![allow(simple_match)]
Some(..) => 0,
None => 1,
}
}
2017-10-30 23:31:08 +09:00
fn issue_2099() {
let a = match x {};
let b = match x {};
match x {}
}
2017-11-11 23:14:01 +09:00
// #2021
impl<'tcx> Const<'tcx> {
pub fn from_constval<'a>() -> Const<'tcx> {
let val = match *cv {
ConstVal::Variant(_) | ConstVal::Aggregate(..) | ConstVal::Unevaluated(..) => bug!(
"MIR must not use `{:?}` (aggregates are expanded to MIR rvalues)",
cv
),
};
}
}
2017-11-15 10:36:42 +09:00
2017-11-15 10:44:51 +09:00
// #2151
fn issue_2151() {
match either {
x => {}
y => (),
}
}
2017-11-15 10:36:42 +09:00
// #2152
fn issue_2152() {
match m {
"aaaaaaaaaaaaa" | "bbbbbbbbbbbbb" | "cccccccccccccccccccccccccccccccccccccccccccc"
if true => {}
"bind" | "writev" | "readv" | "sendmsg" | "recvmsg" if android && (aarch64 || x86_64) => {
true
}
}
}