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