These two attributes are used to change the entry point into a Rust program, but
for now they're being put behind feature gates until we have a chance to think
about them a little more. The #[start] attribute specifically may have its
signature changed.
This is a breaking change to due the usage of these attributes generating errors
by default now. If your crate is using these attributes, add this to your crate
root:
#![feature(start)] // if you're using the #[start] attribute
#![feature(main)] // if you're using the #[main] attribute
cc #20064
65 lines
1.9 KiB
Rust
65 lines
1.9 KiB
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.
|
|
|
|
#![feature(start)]
|
|
|
|
use std::ffi;
|
|
use std::io::process::{Command, ProcessOutput};
|
|
use std::os;
|
|
use std::rt::unwind::try;
|
|
use std::rt;
|
|
use std::str;
|
|
use std::thread::Thread;
|
|
use std::thunk::Thunk;
|
|
|
|
#[start]
|
|
fn start(argc: int, argv: *const *const u8) -> int {
|
|
if argc > 1 {
|
|
unsafe {
|
|
match **argv.offset(1) {
|
|
1 => {}
|
|
2 => println!("foo"),
|
|
3 => assert!(try(|| {}).is_ok()),
|
|
4 => assert!(try(|| panic!()).is_err()),
|
|
5 => assert!(Command::new("test").spawn().is_err()),
|
|
_ => panic!()
|
|
}
|
|
}
|
|
return 0
|
|
}
|
|
|
|
let args = unsafe {
|
|
range(0, argc as uint).map(|i| {
|
|
let ptr = *argv.offset(i as int) as *const _;
|
|
ffi::c_str_to_bytes(&ptr).to_vec()
|
|
}).collect::<Vec<_>>()
|
|
};
|
|
let me = args[0].as_slice();
|
|
|
|
let x: &[u8] = &[1u8];
|
|
pass(Command::new(me).arg(x).output().unwrap());
|
|
let x: &[u8] = &[2u8];
|
|
pass(Command::new(me).arg(x).output().unwrap());
|
|
let x: &[u8] = &[3u8];
|
|
pass(Command::new(me).arg(x).output().unwrap());
|
|
let x: &[u8] = &[4u8];
|
|
pass(Command::new(me).arg(x).output().unwrap());
|
|
let x: &[u8] = &[5u8];
|
|
pass(Command::new(me).arg(x).output().unwrap());
|
|
|
|
0
|
|
}
|
|
|
|
fn pass(output: ProcessOutput) {
|
|
if !output.status.success() {
|
|
println!("{:?}", str::from_utf8(output.output.as_slice()));
|
|
println!("{:?}", str::from_utf8(output.error.as_slice()));
|
|
}
|
|
}
|