aboutsummaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorTohava <tohava@tohava-laptop.(none)>2010-08-05 04:19:46 +0300
committerTohava <tohava@tohava-laptop.(none)>2010-08-05 04:19:46 +0300
commitce79b0e492f1583debbce3c8155da3536c684d9a (patch)
treef5a2a22230510dd14901742a4904c576f62a8500 /src/lib
parentAdded AST logging, and modified AST for consistent handling of alt stmts. (diff)
parentThread argument-types down to internal_check_outer_lval in type.ml, in prepar... (diff)
downloadrust-ce79b0e492f1583debbce3c8155da3536c684d9a.tar.xz
rust-ce79b0e492f1583debbce3c8155da3536c684d9a.zip
Merge branch 'master' of git://github.com/graydon/rust
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/_io.rs76
-rw-r--r--src/lib/_vec.rs9
-rw-r--r--src/lib/linux_os.rs17
-rw-r--r--src/lib/macos_os.rs17
-rw-r--r--src/lib/win32_os.rs17
5 files changed, 119 insertions, 17 deletions
diff --git a/src/lib/_io.rs b/src/lib/_io.rs
index 94021aa6..142f808a 100644
--- a/src/lib/_io.rs
+++ b/src/lib/_io.rs
@@ -2,23 +2,19 @@ type buf_reader = unsafe obj {
fn read() -> vec[u8];
};
+type buf_writer = unsafe obj {
+ fn write(vec[u8] v);
+};
+
fn default_bufsz() -> uint {
ret 4096u;
}
fn new_buf() -> vec[u8] {
- let vec[u8] v = vec();
- let uint i = default_bufsz();
- while (i > 0u) {
- i -= 1u;
- v += vec(0u8);
- }
- // FIXME (issue #93): should be:
- // ret _vec.alloc[u8](default_bufsz());
- ret v;
+ ret _vec.alloc[u8](default_bufsz());
}
-fn new_buf_reader(str s) -> buf_reader {
+fn new_buf_reader(str path) -> buf_reader {
unsafe obj fd_buf_reader(int fd, mutable vec[u8] buf) {
@@ -47,11 +43,67 @@ fn new_buf_reader(str s) -> buf_reader {
}
}
- auto fd = os.libc.open(_str.buf(s), 0);
+ auto fd = os.libc.open(_str.buf(path),
+ os.libc_constants.O_RDONLY() |
+ os.libc_constants.O_BINARY(),
+ 0u);
+
if (fd < 0) {
- log "error opening file";
+ log "error opening file for reading";
log sys.rustrt.last_os_error();
fail;
}
ret fd_buf_reader(fd, new_buf());
}
+
+type fileflag = tag(append(), create(), truncate());
+
+fn new_buf_writer(str path, vec[fileflag] flags) -> buf_writer {
+
+ unsafe obj fd_buf_writer(int fd) {
+
+ fn write(vec[u8] v) {
+ auto len = _vec.len[u8](v);
+ auto count = 0u;
+ auto vbuf;
+ while (count < len) {
+ vbuf = _vec.buf_off[u8](v, count);
+ auto nout = os.libc.write(fd, vbuf, len);
+ if (nout < 0) {
+ log "error dumping buffer";
+ log sys.rustrt.last_os_error();
+ fail;
+ }
+ count += nout as uint;
+ }
+ }
+
+ drop {
+ os.libc.close(fd);
+ }
+ }
+
+ let int fflags =
+ os.libc_constants.O_WRONLY() |
+ os.libc_constants.O_BINARY();
+
+ for (fileflag f in flags) {
+ alt (f) {
+ case (append()) { fflags |= os.libc_constants.O_APPEND(); }
+ case (create()) { fflags |= os.libc_constants.O_CREAT(); }
+ case (truncate()) { fflags |= os.libc_constants.O_TRUNC(); }
+ }
+ }
+
+ auto fd = os.libc.open(_str.buf(path),
+ fflags,
+ os.libc_constants.S_IRUSR() |
+ os.libc_constants.S_IWUSR());
+
+ if (fd < 0) {
+ log "error opening file for writing";
+ log sys.rustrt.last_os_error();
+ fail;
+ }
+ ret fd_buf_writer(fd);
+}
diff --git a/src/lib/_vec.rs b/src/lib/_vec.rs
index 43779015..e374bf52 100644
--- a/src/lib/_vec.rs
+++ b/src/lib/_vec.rs
@@ -3,7 +3,7 @@ import op = util.operator;
native "rust" mod rustrt {
type vbuf;
- fn vec_buf[T](vec[T] v) -> vbuf;
+ fn vec_buf[T](vec[T] v, uint offset) -> vbuf;
fn vec_len[T](vec[T] v) -> uint;
/* The T in vec_alloc[T, U] is the type of the vec to allocate. The
* U is the type of an element in the vec. So to allocate a vec[U] we
@@ -50,7 +50,12 @@ fn len[T](vec[T] v) -> uint {
}
fn buf[T](vec[T] v) -> vbuf {
- ret rustrt.vec_buf[T](v);
+ ret rustrt.vec_buf[T](v, 0u);
+}
+
+fn buf_off[T](vec[T] v, uint offset) -> vbuf {
+ check (offset < len[T](v));
+ ret rustrt.vec_buf[T](v, offset);
}
// Returns elements from [start..end) from v.
diff --git a/src/lib/linux_os.rs b/src/lib/linux_os.rs
index a775a97a..3f096e99 100644
--- a/src/lib/linux_os.rs
+++ b/src/lib/linux_os.rs
@@ -3,7 +3,7 @@ import _vec.vbuf;
native mod libc = "libc.so.6" {
- fn open(sbuf s, int flags) -> int;
+ fn open(sbuf s, int flags, uint mode) -> int;
fn read(int fd, vbuf buf, uint count) -> int;
fn write(int fd, vbuf buf, uint count) -> int;
fn close(int fd) -> int;
@@ -17,3 +17,18 @@ native mod libc = "libc.so.6" {
fn setenv(sbuf n, sbuf v, int overwrite) -> int;
fn unsetenv(sbuf n) -> int;
}
+
+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 0x0000; } // nonexistent in linux libc
+ fn O_BINARY() -> int { ret 0x0000; } // nonexistent in linux libc
+
+ fn S_IRUSR() -> uint { ret 0x0100u; }
+ fn S_IWUSR() -> uint { ret 0x0080u; }
+}
diff --git a/src/lib/macos_os.rs b/src/lib/macos_os.rs
index 8b30c8bc..2ada5c07 100644
--- a/src/lib/macos_os.rs
+++ b/src/lib/macos_os.rs
@@ -3,7 +3,7 @@ import _vec.vbuf;
native mod libc = "libc.dylib" {
- fn open(sbuf s, int flags) -> int;
+ fn open(sbuf s, int flags, uint mode) -> int;
fn read(int fd, vbuf buf, uint count) -> int;
fn write(int fd, vbuf buf, uint count) -> int;
fn close(int fd) -> int;
@@ -17,3 +17,18 @@ native mod libc = "libc.dylib" {
fn setenv(sbuf n, sbuf v, int overwrite) -> int;
fn unsetenv(sbuf n) -> int;
}
+
+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 0x0008; }
+ fn O_CREAT() -> int { ret 0x0200; }
+ fn O_EXCL() -> int { ret 0x0800; }
+ fn O_TRUNC() -> int { ret 0x0400; }
+ fn O_TEXT() -> int { ret 0x0000; } // nonexistent in darwin libc
+ fn O_BINARY() -> int { ret 0x0000; } // nonexistent in darwin libc
+
+ fn S_IRUSR() -> uint { ret 0x0400u; }
+ fn S_IWUSR() -> uint { ret 0x0200u; }
+}
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
+}