##// END OF EJS Templates
rust: Generalize the `trim_end_newlines` utility of byte strings...
Simon Sapin -
r48761:696abab1 default
parent child Browse files
Show More
@@ -127,7 +127,8 impl Repo {
127 127 } else {
128 128 let bytes = hg_vfs.read("sharedpath")?;
129 129 let mut shared_path =
130 get_path_from_bytes(bytes.trim_end_newlines()).to_owned();
130 get_path_from_bytes(bytes.trim_end_matches(|b| b == b'\n'))
131 .to_owned();
131 132 if relative {
132 133 shared_path = dot_hg.join(shared_path)
133 134 }
@@ -67,36 +67,34 where
67 67 }
68 68
69 69 pub trait SliceExt {
70 fn trim_end_newlines(&self) -> &Self;
71 70 fn trim_end(&self) -> &Self;
72 71 fn trim_start(&self) -> &Self;
72 fn trim_end_matches(&self, f: impl FnMut(u8) -> bool) -> &Self;
73 fn trim_start_matches(&self, f: impl FnMut(u8) -> bool) -> &Self;
73 74 fn trim(&self) -> &Self;
74 75 fn drop_prefix(&self, needle: &Self) -> Option<&Self>;
75 76 fn split_2(&self, separator: u8) -> Option<(&[u8], &[u8])>;
76 77 }
77 78
78 #[allow(clippy::trivially_copy_pass_by_ref)]
79 fn is_not_whitespace(c: &u8) -> bool {
80 !(*c as char).is_whitespace()
79 impl SliceExt for [u8] {
80 fn trim_end(&self) -> &[u8] {
81 self.trim_end_matches(|byte| byte.is_ascii_whitespace())
81 82 }
82 83
83 impl SliceExt for [u8] {
84 fn trim_end_newlines(&self) -> &[u8] {
85 if let Some(last) = self.iter().rposition(|&byte| byte != b'\n') {
84 fn trim_start(&self) -> &[u8] {
85 self.trim_start_matches(|byte| byte.is_ascii_whitespace())
86 }
87
88 fn trim_end_matches(&self, mut f: impl FnMut(u8) -> bool) -> &Self {
89 if let Some(last) = self.iter().rposition(|&byte| !f(byte)) {
86 90 &self[..=last]
87 91 } else {
88 92 &[]
89 93 }
90 94 }
91 fn trim_end(&self) -> &[u8] {
92 if let Some(last) = self.iter().rposition(is_not_whitespace) {
93 &self[..=last]
94 } else {
95 &[]
96 }
97 }
98 fn trim_start(&self) -> &[u8] {
99 if let Some(first) = self.iter().position(is_not_whitespace) {
95
96 fn trim_start_matches(&self, mut f: impl FnMut(u8) -> bool) -> &Self {
97 if let Some(first) = self.iter().position(|&byte| !f(byte)) {
100 98 &self[first..]
101 99 } else {
102 100 &[]
General Comments 0
You need to be logged in to leave comments. Login now