coreutils/unlink/unlink.rs
Michael Gehring 30bba07f9c always build multicall binary
squashed:
	a2c6b27 - build: automatically generate main() files
	c942f0f - remove MULTICALL=1 build from travis
	cb7b35b - make: remove unnecessary shell command
	69bbb31 - update README
	03a3168 - all: move main() into separate file that links against util crate
	8276384 - make: always build multicall binary
	aa4edeb - make: avoid 'rustc --crate-file-name'
2014-06-26 10:26:16 +02:00

87 lines
2.2 KiB
Rust

#![crate_id(name="unlink", vers="1.0.0", author="zvms")]
/*
* This file is part of the uutils coreutils package.
*
* (c) Colin Warren <me@zv.ms>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/* last synced with: unlink (GNU coreutils) 8.21 */
#![feature(macro_rules)]
extern crate getopts;
extern crate libc;
use std::io;
use std::io::fs;
use std::io::print;
#[path = "../common/util.rs"]
mod util;
static NAME: &'static str = "unlink";
pub fn uumain(args: Vec<String>) -> int {
let program = args.get(0).clone();
let opts = [
getopts::optflag("h", "help", "display this help and exit"),
getopts::optflag("V", "version", "output version information and exit"),
];
let matches = match getopts::getopts(args.tail(), opts) {
Ok(m) => m,
Err(f) => {
crash!(1, "invalid options\n{}", f)
}
};
if matches.opt_present("help") {
println!("unlink 1.0.0");
println!("");
println!("Usage:");
println!(" {0:s} [FILE]... [OPTION]...", program);
println!("");
print(getopts::usage("Unlink the file at [FILE].", opts).as_slice());
return 0;
}
if matches.opt_present("version") {
println!("unlink 1.0.0");
return 0;
}
if matches.free.len() == 0 {
crash!(1, "missing operand\nTry '{0:s} --help' for more information.", program);
} else if matches.free.len() > 1 {
crash!(1, "extra operand: '{1}'\nTry '{0:s} --help' for more information.", program, matches.free.get(1));
}
let path = Path::new(matches.free.get(0).clone());
let result = path.lstat().and_then(|info| {
match info.kind {
io::TypeFile => Ok(()),
io::TypeSymlink => Ok(()),
_ => Err(io::IoError {
kind: io::OtherIoError,
desc: "is not a file or symlink",
detail: None
})
}
}).and_then(|_| {
fs::unlink(&path)
});
match result {
Ok(_) => (),
Err(e) => {
crash!(1, "cannot unlink '{0}': {1}", path.display(), e.desc);
}
}
0
}