7f928d150e
declared with the same name in the same scope. This breaks several common patterns. First are unused imports: use foo::bar; use baz::bar; Change this code to the following: use baz::bar; Second, this patch breaks globs that import names that are shadowed by subsequent imports. For example: use foo::*; // including `bar` use baz::bar; Change this code to remove the glob: use foo::{boo, quux}; use baz::bar; Or qualify all uses of `bar`: use foo::{boo, quux}; use baz; ... baz::bar ... Finally, this patch breaks code that, at top level, explicitly imports `std` and doesn't disable the prelude. extern crate std; Because the prelude imports `std` implicitly, there is no need to explicitly import it; just remove such directives. The old behavior can be opted into via the `import_shadowing` feature gate. Use of this feature gate is discouraged. This implements RFC #116. Closes #16464. [breaking-change]
97 lines
4.3 KiB
ObjectPascal
97 lines
4.3 KiB
ObjectPascal
#![feature(phase)]
|
|
#![no_std]
|
|
#![feature(globs)]
|
|
#[phase(plugin, link)]
|
|
extern crate std = "std";
|
|
extern crate rt = "native";
|
|
#[prelude_import]
|
|
use std::prelude::*;
|
|
// 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.
|
|
|
|
// pretty-compare-only
|
|
// pretty-mode:typed
|
|
// pp-exact:issue-4264.pp
|
|
|
|
// #4264 fixed-length vector types
|
|
|
|
pub fn foo(_: [int, ..(3 as uint)]) { }
|
|
|
|
pub fn bar() {
|
|
static FOO: uint = ((5u as uint) - (4u as uint) as uint);
|
|
let _: [(), ..(FOO as uint)] = ([(() as ())] as [(), .. 1]);
|
|
|
|
let _: [(), ..(1u as uint)] = ([(() as ())] as [(), .. 1]);
|
|
|
|
let _ =
|
|
(((&((([(1i as int), (2 as int), (3 as int)] as [int, .. 3])) as
|
|
[int, .. 3]) as &[int, .. 3]) as *const _ as
|
|
*const [int, .. 3]) as *const [int, ..(3u as uint)] as
|
|
*const [int, .. 3]);
|
|
(match (() as ()) {
|
|
() => {
|
|
#[inline]
|
|
#[allow(dead_code)]
|
|
static __STATIC_FMTSTR:
|
|
[::std::fmt::rt::Piece<'static>, ..(1u as uint)] =
|
|
([((::std::fmt::rt::String as
|
|
fn(&'static str) -> core::fmt::rt::Piece<'static>)(("test"
|
|
as
|
|
&'static str))
|
|
as core::fmt::rt::Piece<'static>)] as
|
|
[core::fmt::rt::Piece<'static>, .. 1]);
|
|
let __args_vec =
|
|
(&([] as &'static [core::fmt::Argument<'static>]) as
|
|
&'static [core::fmt::Argument<'static>]);
|
|
let __args =
|
|
(unsafe {
|
|
((::std::fmt::Arguments::new as
|
|
unsafe fn(&'static [core::fmt::rt::Piece<'static>], &'a [core::fmt::Argument<'a>]) -> core::fmt::Arguments<'a>)((__STATIC_FMTSTR
|
|
as
|
|
[core::fmt::rt::Piece<'static>, .. 1]),
|
|
(__args_vec
|
|
as
|
|
&'static [core::fmt::Argument<'static>]))
|
|
as core::fmt::Arguments<'static>)
|
|
} as core::fmt::Arguments<'static>);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
((::std::fmt::format as
|
|
fn(&core::fmt::Arguments<'_>) -> collections::string::String)((&(__args
|
|
as
|
|
core::fmt::Arguments<'static>)
|
|
as
|
|
&core::fmt::Arguments<'static>))
|
|
as collections::string::String)
|
|
}
|
|
} as collections::string::String);
|
|
}
|
|
pub type Foo = [int, ..(3u as uint)];
|
|
pub struct Bar {
|
|
pub x: [int, ..(3u as uint)],
|
|
}
|
|
pub struct TupleBar([int, ..(4u as uint)]);
|
|
pub enum Baz { BazVariant([int, ..(5u as uint)]), }
|
|
pub fn id<T>(x: T) -> T { (x as T) }
|
|
pub fn use_id() {
|
|
let _ =
|
|
((id::<[int, ..(3u as uint)]> as
|
|
fn([int, .. 3]) -> [int, .. 3])(([(1 as int), (2 as int),
|
|
(3 as int)] as [int, .. 3])) as
|
|
[int, .. 3]);
|
|
}
|
|
fn main() { }
|