05e3248a79
This can break code that looked like: impl Foo for Box<Any> { fn f(&self) { ... } } let x: Box<Any + Send> = ...; x.f(); Change such code to: impl Foo for Box<Any> { fn f(&self) { ... } } let x: Box<Any> = ...; x.f(); That is, upcast before calling methods. This is a conservative solution to #5781. A more proper treatment (see the xfail'd `trait-contravariant-self.rs`) would take variance into account. This change fixes the soundness hole. Some library changes had to be made to make this work. In particular, `Box<Any>` is no longer showable, and only `Box<Any+Send>` is showable. Eventually, this restriction can be lifted; for now, it does not prove too onerous, because `Any` is only used for propagating the result of task failure. This patch also adds a test for the variance inference work in #12828, which accidentally landed as part of DST. Closes #5781. [breaking-change]
32 lines
1015 B
Rust
32 lines
1015 B
Rust
// 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.
|
|
|
|
extern crate serialize;
|
|
|
|
use std::io::MemWriter;
|
|
use std::io;
|
|
use serialize::{Encodable, Encoder};
|
|
|
|
pub fn buffer_encode<'a,
|
|
T:Encodable<serialize::json::Encoder<'a>,io::IoError>>(
|
|
to_encode_object: &T)
|
|
-> Vec<u8> {
|
|
let mut m = MemWriter::new();
|
|
{
|
|
let mut encoder =
|
|
serialize::json::Encoder::new(&mut m as &mut io::Writer);
|
|
//~^ ERROR `m` does not live long enough
|
|
to_encode_object.encode(&mut encoder);
|
|
}
|
|
m.unwrap()
|
|
}
|
|
|
|
fn main() {}
|