ByteBuffer.WriteByte
R=r
DELTA=17 (10 added, 0 deleted, 7 changed)
OCL=28860
CL=28862
diff --git a/src/lib/io/bytebuffer.go b/src/lib/io/bytebuffer.go
index bc6a737..5d4cd8a 100644
--- a/src/lib/io/bytebuffer.go
+++ b/src/lib/io/bytebuffer.go
@@ -74,6 +74,13 @@
return n, nil
}
+// WriteByte appends the byte c to the buffer.
+// Because Write never fails and WriteByte is not part of the
+// io.Writer interface, it does not need to return a value.
+func (b *ByteBuffer) WriteByte(c byte) {
+ b.Write([]byte{c});
+}
+
// Read reads the next len(p) bytes from the buffer or until the buffer
// is drained. The return value n is the number of bytes read; err is always nil.
func (b *ByteBuffer) Read(p []byte) (n int, err os.Error) {
diff --git a/src/lib/io/bytebuffer_test.go b/src/lib/io/bytebuffer_test.go
index e91a641..5a54322 100644
--- a/src/lib/io/bytebuffer_test.go
+++ b/src/lib/io/bytebuffer_test.go
@@ -101,20 +101,23 @@
}
check(t, "TestBasicOperations (4)", &buf, "a");
- n, err = buf.Write(data[1 : 26]);
- if n != 25 {
+ buf.WriteByte(data[1]);
+ check(t, "TestBasicOperations (5)", &buf, "ab");
+
+ n, err = buf.Write(data[2 : 26]);
+ if n != 24 {
t.Errorf("wrote 25 bytes, but n == %d\n", n);
}
- check(t, "TestBasicOperations (5)", &buf, string(data[0 : 26]));
-
- buf.Truncate(26);
check(t, "TestBasicOperations (6)", &buf, string(data[0 : 26]));
- buf.Truncate(20);
- check(t, "TestBasicOperations (7)", &buf, string(data[0 : 20]));
+ buf.Truncate(26);
+ check(t, "TestBasicOperations (7)", &buf, string(data[0 : 26]));
- empty(t, "TestBasicOperations (8)", &buf, string(data[0 : 20]), make([]byte, 5));
- empty(t, "TestBasicOperations (9)", &buf, "", make([]byte, 100));
+ buf.Truncate(20);
+ check(t, "TestBasicOperations (8)", &buf, string(data[0 : 20]));
+
+ empty(t, "TestBasicOperations (9)", &buf, string(data[0 : 20]), make([]byte, 5));
+ empty(t, "TestBasicOperations (10)", &buf, "", make([]byte, 100));
}
}