auto merge of #11911 : kballard/rust/empty-functional-update, r=pcwalton

Fixes #8972
This commit is contained in:
bors 2014-01-30 05:06:30 -08:00
commit e3dc5f5bcd
3 changed files with 45 additions and 13 deletions

View File

@ -1915,25 +1915,19 @@ impl Parser {
let mut fields = ~[]; let mut fields = ~[];
let mut base = None; let mut base = None;
fields.push(self.parse_field());
while self.token != token::RBRACE { while self.token != token::RBRACE {
self.commit_expr(fields.last().unwrap().expr,
&[token::COMMA], &[token::RBRACE]);
if self.eat(&token::DOTDOT) { if self.eat(&token::DOTDOT) {
base = Some(self.parse_expr()); base = Some(self.parse_expr());
break; break;
} }
if self.token == token::RBRACE {
// Accept an optional trailing comma.
break;
}
fields.push(self.parse_field()); fields.push(self.parse_field());
self.commit_expr(fields.last().unwrap().expr,
&[token::COMMA], &[token::RBRACE]);
} }
hi = pth.span.hi; hi = pth.span.hi;
self.commit_expr_expecting(fields.last().unwrap().expr, token::RBRACE); self.expect(&token::RBRACE);
ex = ExprStruct(pth, fields, base); ex = ExprStruct(pth, fields, base);
return self.mk_expr(lo, hi, ex); return self.mk_expr(lo, hi, ex);
} }
@ -2583,8 +2577,9 @@ impl Parser {
// For distingishing between struct literals and blocks // For distingishing between struct literals and blocks
fn looking_at_struct_literal(&mut self) -> bool { fn looking_at_struct_literal(&mut self) -> bool {
self.token == token::LBRACE && self.token == token::LBRACE &&
(self.look_ahead(1, |t| token::is_plain_ident(t)) && ((self.look_ahead(1, |t| token::is_plain_ident(t)) &&
self.look_ahead(2, |t| *t == token::COLON)) self.look_ahead(2, |t| *t == token::COLON))
|| self.look_ahead(1, |t| *t == token::DOTDOT))
} }
fn parse_match_expr(&mut self) -> @Expr { fn parse_match_expr(&mut self) -> @Expr {

View File

@ -1174,8 +1174,10 @@ pub fn print_expr(s: &mut State, expr: &ast::Expr) {
match wth { match wth {
Some(expr) => { Some(expr) => {
ibox(s, indent_unit); ibox(s, indent_unit);
word(&mut s.s, ","); if !fields.is_empty() {
space(&mut s.s); word(&mut s.s, ",");
space(&mut s.s);
}
word(&mut s.s, ".."); word(&mut s.s, "..");
print_expr(s, expr); print_expr(s, expr);
end(s); end(s);

View File

@ -0,0 +1,35 @@
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
#[deriving(Eq,Clone)]
struct Foo<T> {
bar: T,
baz: T
}
pub fn main() {
let foo = Foo {
bar: 0,
baz: 1
};
let foo_ = foo.clone();
let foo = Foo { ..foo };
assert_eq!(foo, foo_);
let foo = Foo {
bar: ~"one",
baz: ~"two"
};
let foo_ = foo.clone();
let foo = Foo { ..foo };
assert_eq!(foo, foo_);
}