diff options
| author | bors <bors@rust-lang.org> | 2014-05-04 18:36:43 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2014-05-04 18:36:43 -0700 |
| commit | 1b5bbbf87792859c0f9bb797688259b19f626ab0 (patch) | |
| tree | 07ec9365f43f8fb8636b96e021d168ff36927f14 | |
| parent | b0977b1e0f7ba53b6301e2d5f7b26dd2d9c72fbf (diff) | |
| parent | 8375a22b16ae6d746ccfd1f725a26562f55a82ba (diff) | |
| download | rust-1b5bbbf87792859c0f9bb797688259b19f626ab0.tar.gz rust-1b5bbbf87792859c0f9bb797688259b19f626ab0.zip | |
auto merge of #13865 : alexcrichton/rust/issue-13861, r=brson
Previously, windows was using the CREATE_NEW flag which fails if the file previously existed, which differed from the unix semantics. This alters the opening to use the OPEN_ALWAYS flag to mirror the unix semantics. Closes #13861
| -rw-r--r-- | src/libnative/io/file_win32.rs | 2 | ||||
| -rw-r--r-- | src/libstd/io/fs.rs | 20 |
2 files changed, 21 insertions, 1 deletions
diff --git a/src/libnative/io/file_win32.rs b/src/libnative/io/file_win32.rs index 6a6fb31d3e3..88ba6dcbc7e 100644 --- a/src/libnative/io/file_win32.rs +++ b/src/libnative/io/file_win32.rs @@ -274,7 +274,7 @@ pub fn open(path: &CString, fm: io::FileMode, fa: io::FileAccess) (io::Truncate, io::Read) => libc::TRUNCATE_EXISTING, (io::Truncate, _) => libc::CREATE_ALWAYS, (io::Open, io::Read) => libc::OPEN_EXISTING, - (io::Open, _) => libc::CREATE_NEW, + (io::Open, _) => libc::OPEN_ALWAYS, (io::Append, io::Read) => { dwDesiredAccess |= libc::FILE_APPEND_DATA; libc::OPEN_EXISTING diff --git a/src/libstd/io/fs.rs b/src/libstd/io/fs.rs index f9e189e4c80..cd304250b19 100644 --- a/src/libstd/io/fs.rs +++ b/src/libstd/io/fs.rs @@ -1255,11 +1255,31 @@ mod test { match File::open_mode(&tmpdir.join("a"), io::Open, io::Read) { Ok(..) => fail!(), Err(..) => {} } + + // Perform each one twice to make sure that it succeeds the second time + // (where the file exists) + check!(File::open_mode(&tmpdir.join("b"), io::Open, io::Write)); + assert!(tmpdir.join("b").exists()); check!(File::open_mode(&tmpdir.join("b"), io::Open, io::Write)); + check!(File::open_mode(&tmpdir.join("c"), io::Open, io::ReadWrite)); + assert!(tmpdir.join("c").exists()); + check!(File::open_mode(&tmpdir.join("c"), io::Open, io::ReadWrite)); + + check!(File::open_mode(&tmpdir.join("d"), io::Append, io::Write)); + assert!(tmpdir.join("d").exists()); check!(File::open_mode(&tmpdir.join("d"), io::Append, io::Write)); + + check!(File::open_mode(&tmpdir.join("e"), io::Append, io::ReadWrite)); + assert!(tmpdir.join("e").exists()); check!(File::open_mode(&tmpdir.join("e"), io::Append, io::ReadWrite)); + check!(File::open_mode(&tmpdir.join("f"), io::Truncate, io::Write)); + assert!(tmpdir.join("f").exists()); + check!(File::open_mode(&tmpdir.join("f"), io::Truncate, io::Write)); + + check!(File::open_mode(&tmpdir.join("g"), io::Truncate, io::ReadWrite)); + assert!(tmpdir.join("g").exists()); check!(File::open_mode(&tmpdir.join("g"), io::Truncate, io::ReadWrite)); check!(File::create(&tmpdir.join("h")).write("foo".as_bytes())); |
