From 1f2fe401f1e98a9a1d3122b79593e12a668bfb43 Mon Sep 17 00:00:00 2001 From: Johann Klähn Date: Sat, 13 Oct 2012 19:38:42 +0200 Subject: ignore (some) empty field when converting csv This fixes bug #733 and bug #734. --- test/regress/0DDDEBC0.dat | 3 +++ test/regress/0DDDEBC0.test | 9 +++++++++ test/regress/A3FA7601.dat | 3 +++ test/regress/A3FA7601.test | 9 +++++++++ 4 files changed, 24 insertions(+) create mode 100644 test/regress/0DDDEBC0.dat create mode 100644 test/regress/0DDDEBC0.test create mode 100644 test/regress/A3FA7601.dat create mode 100644 test/regress/A3FA7601.test (limited to 'test') diff --git a/test/regress/0DDDEBC0.dat b/test/regress/0DDDEBC0.dat new file mode 100644 index 00000000..21b6fce1 --- /dev/null +++ b/test/regress/0DDDEBC0.dat @@ -0,0 +1,3 @@ +date,posted,amount, +12/12/2011,12/13/2011,$10, +12/12/2011,,$20, diff --git a/test/regress/0DDDEBC0.test b/test/regress/0DDDEBC0.test new file mode 100644 index 00000000..cccb1b6b --- /dev/null +++ b/test/regress/0DDDEBC0.test @@ -0,0 +1,9 @@ +test -f /dev/null --input-date-format '%m/%d/%Y' convert test/regress/0DDDEBC0.dat +2011/12/12=2011/12/13 * + Expenses:Unknown $10 + Equity:Unknown + +2011/12/12 * + Expenses:Unknown $20 + Equity:Unknown +end test diff --git a/test/regress/A3FA7601.dat b/test/regress/A3FA7601.dat new file mode 100644 index 00000000..9a734e67 --- /dev/null +++ b/test/regress/A3FA7601.dat @@ -0,0 +1,3 @@ +date,posted,code,payee,amount,total,note, +12/12/2011,12/13/2011,100,Test,$10,$20,test, +12/12/2011,12/12/2011,,,$10,$20, diff --git a/test/regress/A3FA7601.test b/test/regress/A3FA7601.test new file mode 100644 index 00000000..5029f6d8 --- /dev/null +++ b/test/regress/A3FA7601.test @@ -0,0 +1,9 @@ +test -f /dev/null --input-date-format '%m/%d/%Y' convert test/regress/A3FA7601.dat +2011/12/12=2011/12/13 * (100) Test ;test + Expenses:Unknown $10 + Equity:Unknown $-10 = $20 + +2011/12/12=2011/12/12 * + Expenses:Unknown $10 + Equity:Unknown $-10 = $20 +end test -- cgit v1.2.3 From 27d9d770d3f6d40af4934da1dcf0306daf7678dd Mon Sep 17 00:00:00 2001 From: Johann Klähn Date: Sat, 13 Oct 2012 19:47:29 +0200 Subject: update baseline test for convert command --- test/baseline/cmd-convert.test | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'test') diff --git a/test/baseline/cmd-convert.test b/test/baseline/cmd-convert.test index 181165df..d3fbeae5 100644 --- a/test/baseline/cmd-convert.test +++ b/test/baseline/cmd-convert.test @@ -4,7 +4,7 @@ test -f /dev/null --input-date-format "%m/%d/%Y" convert test/baseline/cmd-conve Expenses:Unknown $10 Equity:Unknown $-10 = $20 -2011/12/12=2011/12/12 * ; +2011/12/12=2011/12/12 * Expenses:Unknown $10 Equity:Unknown end test -- cgit v1.2.3 From 937c9c7bd1a96ca24ecae71695f12bd25641c14c Mon Sep 17 00:00:00 2001 From: Johann Klähn Date: Sat, 13 Oct 2012 20:03:44 +0200 Subject: ignore extra fields when converting csv files This fixes bug #736. --- src/csv.cc | 2 +- test/regress/68917252.dat | 2 ++ test/regress/68917252.test | 5 +++++ 3 files changed, 8 insertions(+), 1 deletion(-) create mode 100644 test/regress/68917252.dat create mode 100644 test/regress/68917252.test (limited to 'test') diff --git a/src/csv.cc b/src/csv.cc index aca69307..4992372a 100644 --- a/src/csv.cc +++ b/src/csv.cc @@ -166,7 +166,7 @@ xact_t * csv_reader::read_xact(bool rich_data) string total; string field; - while (instr.good() && ! instr.eof()) { + while (instr.good() && ! instr.eof() && n < index.size()) { field = read_field(instr); switch (index[n]) { diff --git a/test/regress/68917252.dat b/test/regress/68917252.dat new file mode 100644 index 00000000..8857f741 --- /dev/null +++ b/test/regress/68917252.dat @@ -0,0 +1,2 @@ +date,amount, +12/12/2011,10,test,extra,fields diff --git a/test/regress/68917252.test b/test/regress/68917252.test new file mode 100644 index 00000000..52fde1d9 --- /dev/null +++ b/test/regress/68917252.test @@ -0,0 +1,5 @@ +test -f /dev/null --input-date-format "%m/%d/%Y" convert test/regress/68917252.dat +2011/12/12 * + Expenses:Unknown 10 + Equity:Unknown +end test -- cgit v1.2.3