]> git.lizzy.rs Git - rust.git/commitdiff
rewrite_string: trim trailing whitespace in case the last_line fits in the given...
authorStéphane Campinas <stephane.campinas@gmail.com>
Thu, 4 Oct 2018 07:16:08 +0000 (09:16 +0200)
committerStéphane Campinas <stephane.campinas@gmail.com>
Mon, 8 Oct 2018 12:48:13 +0000 (14:48 +0200)
src/string.rs

index 6f84a8e2c02014282d565353bac7987cfcec32dc..b5ba022a93ca6f8f7c6bd621de4542a9b2c8b1c8 100644 (file)
@@ -98,7 +98,12 @@ pub fn rewrite_string<'a>(orig: &str, fmt: &StringFormat<'a>) -> Option<String>
     loop {
         // All the input starting at cur_start fits on the current line
         if graphemes.len() - cur_start <= cur_max_chars {
-            result.push_str(&graphemes[cur_start..].join(""));
+            let last_line = graphemes[cur_start..].join("");
+            if fmt.trim_end {
+                result.push_str(&last_line.trim_right());
+            } else {
+                result.push_str(&last_line);
+            }
             break;
         }
 
@@ -363,4 +368,19 @@ fn newline_in_candidate_line() {
             Some("\"Nulla\nconsequat erat at massa. \\\n Vivamus id mi.\"".to_string())
         );
     }
+
+    #[test]
+    fn last_line_fit_with_trailing_whitespaces() {
+        let string = "Vivamus id mi.  ";
+        let config: Config = Default::default();
+        let mut fmt = StringFormat::new(Shape::legacy(25, Indent::empty()), &config);
+
+        fmt.trim_end = true;
+        let rewritten_string = rewrite_string(string, &fmt);
+        assert_eq!(rewritten_string, Some("\"Vivamus id mi.\"".to_string()));
+
+        fmt.trim_end = false; // default value of trim_end
+        let rewritten_string = rewrite_string(string, &fmt);
+        assert_eq!(rewritten_string, Some("\"Vivamus id mi.  \"".to_string()));
+    }
 }