Skip to content

Commit

Permalink
auto merge of #16243 : alexcrichton/rust/fix-utime-for-windows, r=brson
Browse files Browse the repository at this point in the history
Apparently the units are in milliseconds, not in seconds!
  • Loading branch information
bors committed Aug 5, 2014
2 parents cbdae97 + 2677e5f commit fd02916
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 8 deletions.
4 changes: 2 additions & 2 deletions src/libnative/io/file_win32.rs
Original file line number Diff line number Diff line change
Expand Up @@ -516,8 +516,8 @@ pub fn lstat(_p: &CString) -> IoResult<rtio::FileStat> {

pub fn utime(p: &CString, atime: u64, mtime: u64) -> IoResult<()> {
let mut buf = libc::utimbuf {
actime: (atime / 1000) as libc::time64_t,
modtime: (mtime / 1000) as libc::time64_t,
actime: atime as libc::time64_t,
modtime: mtime as libc::time64_t,
};
let p = try!(to_utf16(p));
super::mkerr_libc(unsafe {
Expand Down
10 changes: 4 additions & 6 deletions src/libstd/io/fs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1588,26 +1588,24 @@ mod test {
"truncate didn't truncate");
})

#[test]
fn utime() {
iotest!(fn utime() {
let tmpdir = tmpdir();
let path = tmpdir.join("a");
check!(File::create(&path));

check!(change_file_times(&path, 1000, 2000));
assert_eq!(check!(path.stat()).accessed, 1000);
assert_eq!(check!(path.stat()).modified, 2000);
}
})

#[test]
fn utime_noexist() {
iotest!(fn utime_noexist() {
let tmpdir = tmpdir();

match change_file_times(&tmpdir.join("a"), 100, 200) {
Ok(..) => fail!(),
Err(..) => {}
}
}
})

iotest!(fn binary_file() {
use rand::{StdRng, Rng};
Expand Down

0 comments on commit fd02916

Please sign in to comment.