Commit 0d1b936f authored by Matthew Hooker's avatar Matthew Hooker

Fix UnixReader panic on empty lines.

Added a test for the failure.

Most of the scanner code looks like it's a modified version of
bufio.ScanLines, so I changed it to use that but always add a line feed.
parent 2e119b51
...@@ -2,7 +2,6 @@ package shell ...@@ -2,7 +2,6 @@ package shell
import ( import (
"bufio" "bufio"
"bytes"
"io" "io"
"sync" "sync"
) )
...@@ -54,35 +53,6 @@ func (r *UnixReader) Read(p []byte) (n int, err error) { ...@@ -54,35 +53,6 @@ func (r *UnixReader) Read(p []byte) (n int, err error) {
// only returns unix-style lines. So even if the line is "one\r\n", the // only returns unix-style lines. So even if the line is "one\r\n", the
// token returned will be "one\n". // token returned will be "one\n".
func scanUnixLine(data []byte, atEOF bool) (advance int, token []byte, err error) { func scanUnixLine(data []byte, atEOF bool) (advance int, token []byte, err error) {
if atEOF && len(data) == 0 { advance, token, err = bufio.ScanLines(data, atEOF)
return 0, nil, nil return advance, append(token, "\n"...), err
}
if i := bytes.IndexByte(data, '\n'); i >= 0 {
// We have a new-line terminated line. Return the line with the newline
return i + 1, dropCR(data[0 : i+1]), nil
}
if atEOF {
// We have a final, non-terminated line
return len(data), dropCR(data), nil
}
if data[len(data)-1] != '\r' {
// We have a normal line, just let it tokenize
return len(data), data, nil
}
// We need more data
return 0, nil, nil
}
func dropCR(data []byte) []byte {
if len(data) > 0 && data[len(data)-2] == '\r' {
// Trim off the last byte and replace it with a '\n'
data = data[0 : len(data)-1]
data[len(data)-1] = '\n'
}
return data
} }
...@@ -33,8 +33,8 @@ func TestUnixReader(t *testing.T) { ...@@ -33,8 +33,8 @@ func TestUnixReader(t *testing.T) {
} }
func TestUnixReader_unixOnly(t *testing.T) { func TestUnixReader_unixOnly(t *testing.T) {
input := "one\ntwo\nthree\n" input := "one\n\ntwo\nthree\n"
expected := "one\ntwo\nthree\n" expected := "one\n\ntwo\nthree\n"
r := &UnixReader{ r := &UnixReader{
Reader: bytes.NewReader([]byte(input)), Reader: bytes.NewReader([]byte(input)),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment