Auto merge of #29498 - wthrowe:replace-pattern, r=alexcrichton
It appears this was left out of RFC rust-lang/rfcs#528 because it might be useful to also generalize the second argument in some way. That doesn't seem to prevent generalizing the first argument now, however. This is a [breaking-change] because it could cause type-inference to fail where it previously succeeded. Also update docs for a few other methods that still referred to `&str` instead of patterns.
This commit is contained in:
commit
8796e012cb
@ -857,9 +857,10 @@ impl str {
|
||||
Utf16Units { encoder: Utf16Encoder::new(self[..].chars()) }
|
||||
}
|
||||
|
||||
/// Returns `true` if the given `&str` is a sub-slice of this string slice.
|
||||
/// Returns `true` if the given pattern matches a sub-slice of
|
||||
/// this string slice.
|
||||
///
|
||||
/// Returns `false` if it's not.
|
||||
/// Returns `false` if it does not.
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
@ -876,9 +877,10 @@ impl str {
|
||||
core_str::StrExt::contains(self, pat)
|
||||
}
|
||||
|
||||
/// Returns `true` if the given `&str` is a prefix of this string slice.
|
||||
/// Returns `true` if the given pattern matches a prefix of this
|
||||
/// string slice.
|
||||
///
|
||||
/// Returns `false` if it's not.
|
||||
/// Returns `false` if it does not.
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
@ -895,9 +897,10 @@ impl str {
|
||||
core_str::StrExt::starts_with(self, pat)
|
||||
}
|
||||
|
||||
/// Returns `true` if the given `&str` is a suffix of this string slice.
|
||||
/// Returns `true` if the given pattern matches a suffix of this
|
||||
/// string slice.
|
||||
///
|
||||
/// Returns `false` if not.
|
||||
/// Returns `false` if it does not.
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
@ -1681,11 +1684,11 @@ impl str {
|
||||
core_str::StrExt::parse(self)
|
||||
}
|
||||
|
||||
/// Replaces all occurrences of one string with another.
|
||||
/// Replaces all matches of a pattern with another string.
|
||||
///
|
||||
/// `replace` creates a new [`String`], and copies the data from this string slice into it.
|
||||
/// While doing so, it attempts to find a sub-`&str`. If it finds it, it replaces it with
|
||||
/// the replacement string slice.
|
||||
/// While doing so, it attempts to find matches of a pattern. If it finds any, it
|
||||
/// replaces them with the replacement string slice.
|
||||
///
|
||||
/// [`String`]: string/struct.String.html
|
||||
///
|
||||
@ -1699,14 +1702,14 @@ impl str {
|
||||
/// assert_eq!("this is new", s.replace("old", "new"));
|
||||
/// ```
|
||||
///
|
||||
/// When a `&str` isn't found:
|
||||
/// When the pattern doesn't match:
|
||||
///
|
||||
/// ```
|
||||
/// let s = "this is old";
|
||||
/// assert_eq!(s, s.replace("cookie monster", "little lamb"));
|
||||
/// ```
|
||||
#[stable(feature = "rust1", since = "1.0.0")]
|
||||
pub fn replace(&self, from: &str, to: &str) -> String {
|
||||
pub fn replace<'a, P: Pattern<'a>>(&'a self, from: P, to: &str) -> String {
|
||||
let mut result = String::new();
|
||||
let mut last_end = 0;
|
||||
for (start, part) in self.match_indices(from) {
|
||||
|
@ -269,6 +269,15 @@ fn test_replace_2d() {
|
||||
assert_eq!(data.replace(d, repl), data);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_replace_pattern() {
|
||||
let data = "abcdαβγδabcdαβγδ";
|
||||
assert_eq!(data.replace("dαβ", "😺😺😺"), "abc😺😺😺γδabc😺😺😺γδ");
|
||||
assert_eq!(data.replace('γ', "😺😺😺"), "abcdαβ😺😺😺δabcdαβ😺😺😺δ");
|
||||
assert_eq!(data.replace(&['a', 'γ'] as &[_], "😺😺😺"), "😺😺😺bcdαβ😺😺😺δ😺😺😺bcdαβ😺😺😺δ");
|
||||
assert_eq!(data.replace(|c| c == 'γ', "😺😺😺"), "abcdαβ😺😺😺δabcdαβ😺😺😺δ");
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_slice() {
|
||||
assert_eq!("ab", &"abc"[0..2]);
|
||||
|
Loading…
Reference in New Issue
Block a user