aboutsummaryrefslogtreecommitdiff
path: root/src/lib/win32_os.rs
diff options
context:
space:
mode:
authorRoy Frostig <[email protected]>2010-08-04 17:14:11 -0700
committerRoy Frostig <[email protected]>2010-08-04 17:14:17 -0700
commitc17ea956a26a05341ff24736105b43f2a16a1ad2 (patch)
tree71610381ab804635216eae7212759ebcf560d5f9 /src/lib/win32_os.rs
parentAdd a CHECK_XFAILS target that inverts the sense of check: it tries to compil... (diff)
downloadrust-c17ea956a26a05341ff24736105b43f2a16a1ad2.tar.xz
rust-c17ea956a26a05341ff24736105b43f2a16a1ad2.zip
Add per-platform file-open flags to std.os. Open buffers as desired in std._io.
Diffstat (limited to 'src/lib/win32_os.rs')
-rw-r--r--src/lib/win32_os.rs17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/lib/win32_os.rs b/src/lib/win32_os.rs
index f770a5de..3d8e5f3a 100644
--- a/src/lib/win32_os.rs
+++ b/src/lib/win32_os.rs
@@ -2,8 +2,23 @@ import _str.sbuf;
import _vec.vbuf;
native mod libc = "msvcrt.dll" {
- fn open(sbuf s, int flags) -> int = "_open";
+ fn open(sbuf s, int flags, uint mode) -> int = "_open";
fn read(int fd, vbuf buf, uint count) -> int = "_read";
fn write(int fd, vbuf buf, uint count) -> int = "_write";
fn close(int fd) -> int = "_close";
}
+
+mod libc_constants {
+ fn O_RDONLY() -> int { ret 0x0000; }
+ fn O_WRONLY() -> int { ret 0x0001; }
+ fn O_RDWR() -> int { ret 0x0002; }
+ fn O_APPEND() -> int { ret 0x0400; }
+ fn O_CREAT() -> int { ret 0x0040; }
+ fn O_EXCL() -> int { ret 0x0080; }
+ fn O_TRUNC() -> int { ret 0x0200; }
+ fn O_TEXT() -> int { ret 0x4000; }
+ fn O_BINARY() -> int { ret 0x8000; }
+
+ fn S_IRUSR() -> uint { ret 0x0100u; } // really _S_IREAD in win32
+ fn S_IWUSR() -> uint { ret 0x0080u; } // really _S_IWRITE in win32
+}