Skip to content

Commit

Permalink
Clean up test cases
Browse files Browse the repository at this point in the history
  • Loading branch information
jroesch authored and Jared Roesch committed Jul 26, 2015
1 parent 01dcb3b commit e857871
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 34 deletions.
6 changes: 5 additions & 1 deletion src/librustc_typeck/check/mod.rs
Expand Up @@ -1141,7 +1141,11 @@ impl<'a, 'tcx> AstConv<'tcx> for FnCtxt<'a, 'tcx> {

fn ty_infer(&self, ty_param_def: Option<ty::TypeParameterDef<'tcx>>, span: Span) -> Ty<'tcx> {
let default = ty_param_def.and_then(|t|
t.default.map(|ty| type_variable::Default { ty: ty, origin_span: span, definition_span: span }));
t.default.map(|ty| type_variable::Default {
ty: ty,
origin_span: span,
definition_span: span
}));
self.infcx().next_ty_var_with_default(default)
}

Expand Down
@@ -0,0 +1,33 @@
// Copyright 2015 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.
//
use std::marker::PhantomData;

trait Id {
type This;
}

impl<A> Id for A {
type This = A;
}

struct Foo<X: Default = usize, Y = <X as Id>::This> {
data: PhantomData<(X, Y)>
}

impl<X: Default, Y> Foo<X, Y> {
fn new() -> Foo<X, Y> {
Foo { data: PhantomData }
}
}

fn main() {
let foo = Foo::new();
}
18 changes: 18 additions & 0 deletions src/test/run-pass/default_ty_param_dependent_defaults.rs
@@ -0,0 +1,18 @@
// Copyright 2015 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.
//

use std::marker::PhantomData;

struct Foo<T,U=T> { data: PhantomData<(T, U)> }

fn main() {
let foo = Foo { data: PhantomData };
}
@@ -1,7 +1,15 @@
use std::marker::PhantomData;
// Copyright 2015 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.
//

trait TypeEq<A> {}
impl<A> TypeEq<A> for A {}
use std::marker::PhantomData;

struct DeterministicHasher;
struct RandomHasher;
Expand Down

This file was deleted.

This file was deleted.

0 comments on commit e857871

Please sign in to comment.