From 514b8ca8f22614318600eeadebe7d38b7d340ac3 Mon Sep 17 00:00:00 2001 From: Eric Huss Date: Tue, 13 Aug 2019 13:48:54 -0700 Subject: [PATCH] Fix error line/column when using CRLF line endings. --- src/de.rs | 5 ++++- test-suite/tests/de-errors.rs | 27 +++++++++++++++++++++++++++ 2 files changed, 31 insertions(+), 1 deletion(-) diff --git a/src/de.rs b/src/de.rs index 234fa50..e71cd0c 100644 --- a/src/de.rs +++ b/src/de.rs @@ -1775,7 +1775,10 @@ impl<'a> Deserializer<'a> { /// All indexes are 0-based. fn to_linecol(&self, offset: usize) -> (usize, usize) { let mut cur = 0; - for (i, line) in self.input.lines().enumerate() { + // Use split_terminator instead of lines so that if there is a `\r`, + // it is included in the offset calculation. The `+1` values below + // account for the `\n`. + for (i, line) in self.input.split_terminator('\n').enumerate() { if cur + line.len() + 1 > offset { return (i, offset - cur); } diff --git a/test-suite/tests/de-errors.rs b/test-suite/tests/de-errors.rs index 7cceb7b..5005313 100644 --- a/test-suite/tests/de-errors.rs +++ b/test-suite/tests/de-errors.rs @@ -323,3 +323,30 @@ fn serde_derive_deserialize_errors() { "invalid type: integer `1`, expected a string for key `p_b` at line 4 column 34" ); } + +#[test] +fn error_handles_crlf() { + bad!( + "\r\n\ + [t1]\r\n\ + [t2]\r\n\ + a = 1\r\n\ + a = 2\r\n\ + ", + toml::Value, + "duplicate key: `a` for key `t2` at line 3 column 1" + ); + + // Should be the same as above. + bad!( + "\n\ + [t1]\n\ + [t2]\n\ + a = 1\n\ + a = 2\n\ + ", + toml::Value, + "duplicate key: `a` for key `t2` at line 3 column 1" + ); + +}