From b2a076e8b8421aecbee9de72ccf1e36b6959407b Mon Sep 17 00:00:00 2001 From: yuyi Date: Wed, 29 Apr 2020 22:50:02 +0800 Subject: [PATCH] csv: fix last-field-empty error --- vlib/encoding/csv/reader.v | 25 +++++++++++++------------ vlib/encoding/csv/reader_test.v | 27 +++++++++++++++++++++++++++ 2 files changed, 40 insertions(+), 12 deletions(-) diff --git a/vlib/encoding/csv/reader.v b/vlib/encoding/csv/reader.v index 1709e1cece..44d33d5153 100644 --- a/vlib/encoding/csv/reader.v +++ b/vlib/encoding/csv/reader.v @@ -129,18 +129,19 @@ fn (r mut Reader) read_record() ?[]string { // quoted else { line = line[1..] - if j := line.index('"') { - if j+1 == line.len { - // last record - fields << line[..j] - break - } - next := line[j+1] - if next == r.delimiter { - fields << line[..j] - line = line[j..] - continue - } + j := line.index('"') or { + break + } + if j+1 == line.len { + // last record + fields << line[..j] + break + } + next := line[j+1] + if next == r.delimiter { + fields << line[..j] + line = line[j..] + continue } line = line[1..] } diff --git a/vlib/encoding/csv/reader_test.v b/vlib/encoding/csv/reader_test.v index 0cae790ead..f9725440da 100644 --- a/vlib/encoding/csv/reader_test.v +++ b/vlib/encoding/csv/reader_test.v @@ -120,3 +120,30 @@ fn test_no_line_ending() { assert row_count == 2 } + +fn test_last_field_empty() { + data := '"name","description","value"\n"one","first","1"\n"two","second",\n' + mut csv_reader := csv.new_reader(data) + + mut row_count := 0 + for { + row := csv_reader.read() or { + break + } + row_count++ + if row_count == 1 { + assert row[0] == 'name' + assert row[1] == 'description' + assert row[2] == 'value' + } + if row_count == 2 { + assert row[0] == 'one' + assert row[1] == 'first' + assert row[2] == '1' + } + if row_count == 3 { + assert row[0] == 'two' + assert row[1] == 'second' + } + } +}