-
Notifications
You must be signed in to change notification settings - Fork 13.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implemented Decodable/Encodable for Cell and RefCell. Fixes #15395
Updated PR with fixme and test Updated PR with fixme and test
- Loading branch information
1 parent
36d7d74
commit 0e84d6f
Showing
2 changed files
with
85 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
55 changes: 55 additions & 0 deletions
55
src/test/run-pass/deriving-encodable-decodable-cell-refcell.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
// 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. | ||
|
||
// This briefuly tests the capability of `Cell` and `RefCell` to implement the | ||
// `Encodable` and `Decodable` traits via `#[deriving(Encodable, Decodable)]` | ||
|
||
extern crate serialize; | ||
|
||
use std::cell::{Cell, RefCell}; | ||
use std::io::MemWriter; | ||
use serialize::{Encodable, Decodable}; | ||
use serialize::ebml; | ||
use serialize::ebml::writer::Encoder; | ||
use serialize::ebml::reader::Decoder; | ||
|
||
#[deriving(Encodable, Decodable)] | ||
struct A { | ||
baz: int | ||
} | ||
|
||
#[deriving(Encodable, Decodable)] | ||
struct B { | ||
foo: Cell<bool>, | ||
bar: RefCell<A>, | ||
} | ||
|
||
fn main() { | ||
let obj = B { | ||
foo: Cell::new(true), | ||
bar: RefCell::new( A { baz: 2 } ) | ||
}; | ||
let mut w = MemWriter::new(); | ||
{ | ||
let mut e = Encoder::new(&mut w); | ||
match obj.encode(&mut e) { | ||
Ok(()) => (), | ||
Err(e) => fail!("Failed to encode: {}", e) | ||
}; | ||
} | ||
let doc = ebml::Doc::new(w.get_ref()); | ||
let mut dec = Decoder::new(doc); | ||
let obj2: B = match Decodable::decode(&mut dec) { | ||
Ok(v) => v, | ||
Err(e) => fail!("Failed to decode: {}", e) | ||
}; | ||
assert!(obj.foo.get() == obj2.foo.get()); | ||
assert!(obj.bar.borrow().baz == obj2.bar.borrow().baz); | ||
} |
0e84d6f
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
saw approval from alexcrichton
at mitchmindtree@0e84d6f
0e84d6f
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
merging mitchmindtree/rust/master = 0e84d6f into auto
0e84d6f
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
mitchmindtree/rust/master = 0e84d6f merged ok, testing candidate = 179b2b4
0e84d6f
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
all tests pass:
success: http://buildbot.rust-lang.org/builders/auto-mac-32-opt/builds/214
success: http://buildbot.rust-lang.org/builders/auto-mac-64-opt/builds/215
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-c/builds/214
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-t/builds/215
success: http://buildbot.rust-lang.org/builders/auto-linux-32-opt/builds/217
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-c/builds/218
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-t/builds/217
success: http://buildbot.rust-lang.org/builders/auto-linux-64-opt/builds/223
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-c/builds/218
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-t/builds/217
success: http://buildbot.rust-lang.org/builders/auto-linux-64-x-android-t/builds/220
success: http://buildbot.rust-lang.org/builders/auto-win-32-opt/builds/218
success: http://buildbot.rust-lang.org/builders/auto-win-32-nopt-t/builds/217
0e84d6f
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fast-forwarding master to auto = 179b2b4