mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-07-31 13:07:46 +00:00
Merge pull request #1189 from ProgVal/unlink-nul-terminator
unlink: Add a nul-terminator after the file name before calling lstat.
This commit is contained in:
commit
c50e7b5bc4
1 changed files with 6 additions and 3 deletions
|
@ -19,9 +19,10 @@ extern crate uucore;
|
||||||
|
|
||||||
use getopts::Options;
|
use getopts::Options;
|
||||||
use libc::{S_IFLNK, S_IFMT, S_IFREG};
|
use libc::{S_IFLNK, S_IFMT, S_IFREG};
|
||||||
use libc::{c_char, lstat, stat, unlink};
|
use libc::{lstat, stat, unlink};
|
||||||
use std::io::{Error, ErrorKind};
|
use std::io::{Error, ErrorKind};
|
||||||
use std::mem::uninitialized;
|
use std::mem::uninitialized;
|
||||||
|
use std::ffi::CString;
|
||||||
|
|
||||||
static NAME: &'static str = "unlink";
|
static NAME: &'static str = "unlink";
|
||||||
static VERSION: &'static str = env!("CARGO_PKG_VERSION");
|
static VERSION: &'static str = env!("CARGO_PKG_VERSION");
|
||||||
|
@ -67,11 +68,13 @@ pub fn uumain(args: Vec<String>) -> i32 {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let c_string = CString::new(matches.free[0].clone()).unwrap(); // unwrap() cannot fail, the string comes from argv so it cannot contain a \0.
|
||||||
|
|
||||||
let st_mode = {
|
let st_mode = {
|
||||||
let mut buf: stat = unsafe { uninitialized() };
|
let mut buf: stat = unsafe { uninitialized() };
|
||||||
let result = unsafe {
|
let result = unsafe {
|
||||||
lstat(
|
lstat(
|
||||||
matches.free[0].as_ptr() as *const c_char,
|
c_string.as_ptr(),
|
||||||
&mut buf as *mut stat,
|
&mut buf as *mut stat,
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
@ -94,7 +97,7 @@ pub fn uumain(args: Vec<String>) -> i32 {
|
||||||
"Not a regular file or symlink",
|
"Not a regular file or symlink",
|
||||||
))
|
))
|
||||||
} else {
|
} else {
|
||||||
let result = unsafe { unlink(matches.free[0].as_ptr() as *const c_char) };
|
let result = unsafe { unlink(c_string.as_ptr()) };
|
||||||
|
|
||||||
if result < 0 {
|
if result < 0 {
|
||||||
Err(Error::last_os_error())
|
Err(Error::last_os_error())
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue