aboutsummaryrefslogtreecommitdiff
path: root/src/bytes/reader.go
diff options
context:
space:
mode:
authorTim Cooper <tim.cooper@layeh.com>2018-10-26 16:34:27 -0500
committerBrad Fitzpatrick <bradfitz@golang.org>2018-10-29 20:07:25 +0000
commit5fc4604aa8b593d8d9e93c98a1380114633b7c6a (patch)
treebb9eeeeec7bcce7b36273d3ed417c9ae827e4bf4 /src/bytes/reader.go
parent70dd90c4a93d26215a3514d975c2692724d05ac6 (diff)
downloadgo-5fc4604aa8b593d8d9e93c98a1380114633b7c6a.tar.xz
bytes, strings: fix Reader.UnreadRune returning without error on a zero Reader
Fixes #28269 Change-Id: I878dff43c0b6bdb98702d8e73f2ecd984fb2350f Reviewed-on: https://go-review.googlesource.com/c/145098 Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org> Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
Diffstat (limited to 'src/bytes/reader.go')
-rw-r--r--src/bytes/reader.go6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/bytes/reader.go b/src/bytes/reader.go
index 08464c2402..5946cf9780 100644
--- a/src/bytes/reader.go
+++ b/src/bytes/reader.go
@@ -14,6 +14,7 @@ import (
// io.ByteScanner, and io.RuneScanner interfaces by reading from
// a byte slice.
// Unlike a Buffer, a Reader is read-only and supports seeking.
+// The zero value for Reader operates like a Reader of an empty slice.
type Reader struct {
s []byte
i int64 // current reading index
@@ -75,10 +76,10 @@ func (r *Reader) ReadByte() (byte, error) {
// UnreadByte complements ReadByte in implementing the io.ByteScanner interface.
func (r *Reader) UnreadByte() error {
- r.prevRune = -1
if r.i <= 0 {
return errors.New("bytes.Reader.UnreadByte: at beginning of slice")
}
+ r.prevRune = -1
r.i--
return nil
}
@@ -101,6 +102,9 @@ func (r *Reader) ReadRune() (ch rune, size int, err error) {
// UnreadRune complements ReadRune in implementing the io.RuneScanner interface.
func (r *Reader) UnreadRune() error {
+ if r.i <= 0 {
+ return errors.New("bytes.Reader.UnreadRune: at beginning of slice")
+ }
if r.prevRune < 0 {
return errors.New("bytes.Reader.UnreadRune: previous operation was not ReadRune")
}