diff options
| author | Roy Frostig <[email protected]> | 2010-08-04 23:09:25 -0700 |
|---|---|---|
| committer | Roy Frostig <[email protected]> | 2010-08-04 23:09:33 -0700 |
| commit | 718c0b5963e6513337e4fee003b34423397c2d14 (patch) | |
| tree | bfce28f0d0e3b523691c4b536af213330a0f0a96 /src/lib/_io.rs | |
| parent | Thread argument-types down to internal_check_outer_lval in type.ml, in prepar... (diff) | |
| download | rust-718c0b5963e6513337e4fee003b34423397c2d14.tar.xz rust-718c0b5963e6513337e4fee003b34423397c2d14.zip | |
Add to std._io some formatter/type-specific-writer mechanism. Make a few type-specific buffered writers as wrappers of buf_writer.
Diffstat (limited to 'src/lib/_io.rs')
| -rw-r--r-- | src/lib/_io.rs | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/lib/_io.rs b/src/lib/_io.rs index 142f808a..b0b0c313 100644 --- a/src/lib/_io.rs +++ b/src/lib/_io.rs @@ -1,3 +1,7 @@ +import std.os; +import std._str; +import std._vec; + type buf_reader = unsafe obj { fn read() -> vec[u8]; }; @@ -107,3 +111,50 @@ fn new_buf_writer(str path, vec[fileflag] flags) -> buf_writer { } ret fd_buf_writer(fd); } + +type formatter[T] = fn(&T x) -> vec[u8]; + +type writer[T] = unsafe obj { fn write(&T x); }; + +fn mk_writer[T](str path, + vec[fileflag] flags, + &formatter[T] fmt) + -> writer[T] +{ + unsafe obj w[T](buf_writer out, formatter[T] fmt) { + fn write(&T x) { + out.write(fmt(x)); + } + } + ret w[T](new_buf_writer(path, flags), fmt); +} + +/* TODO: int_writer, uint_writer, ... */ + +fn str_writer(str path, vec[fileflag] flags) -> writer[str] { + auto fmt = _str.bytes; // FIXME (issue #90) + ret mk_writer[str](path, flags, fmt); +} + +fn vec_writer[T](str path, + vec[fileflag] flags, + &formatter[T] inner) + -> writer[vec[T]] +{ + fn fmt[T](&vec[T] v, &formatter[T] inner) -> vec[u8] { + let vec[u8] res = _str.bytes("vec("); + auto first = true; + for (T x in v) { + if (!first) { + res += _str.bytes(", "); + } else { + first = false; + } + res += inner(x); + } + res += _str.bytes(")\n"); + ret res; + } + + ret mk_writer[vec[T]](path, flags, bind fmt[T](_, inner)); +} |