From 70e1c54fad02c76484d3f98e0c92ef8a34301402 Mon Sep 17 00:00:00 2001 From: Benjamin Atkin Date: Tue, 31 Dec 2024 02:00:37 +0000 Subject: [PATCH] fix extra newlines in raw strings --- src/tokenizer.rs | 12 +++++------- tests/string.rs | 9 +++++++++ 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/src/tokenizer.rs b/src/tokenizer.rs index 1e490c0ba..a93446dc7 100644 --- a/src/tokenizer.rs +++ b/src/tokenizer.rs @@ -1263,12 +1263,6 @@ pub fn parse_raw_string_literal( pos.advance(); match (next_char, &mut seen_hashes) { - // New line - ('\n', _) => { - result.push('\n'); - pos.new_line(); - } - // Begin attempt to close string ('"', None) => seen_hashes = Some(0), // Restart attempt to close string @@ -1294,7 +1288,11 @@ pub fn parse_raw_string_literal( result.push(c); seen_hashes = None; } - + // New line + ('\n', _) => { + result.push('\n'); + pos.new_line(); + } // Normal new character seen (c, None) => result.push(c), } diff --git a/tests/string.rs b/tests/string.rs index 29e91652f..b77c7e5de 100644 --- a/tests/string.rs +++ b/tests/string.rs @@ -29,6 +29,15 @@ string: "## + "\u2764""### .unwrap(), "Test\nstring: ❤" ); + assert_eq!( + engine + .eval::( + r###"##"Test" +string: "## + "\u2764""### + ) + .unwrap(), + "Test\"\nstring: ❤" + ); let bad_result = *engine.eval::(r###"#"Test string: \"##"###).unwrap_err(); if let EvalAltResult::ErrorParsing(parse_error, pos) = bad_result { assert_eq!(parse_error, ParseErrorType::UnknownOperator("#".to_string()));