2018-10-06 16:18:06 +00:00
|
|
|
|
// Copyright 2014-2018 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
|
// file at the top-level directory of this distribution.
|
|
|
|
|
//
|
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
|
|
|
2018-07-28 15:34:52 +00:00
|
|
|
|
#![feature(tool_lints)]
|
|
|
|
|
|
2017-10-10 04:00:47 +00:00
|
|
|
|
use std::collections::HashSet;
|
|
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
|
let x = "foo";
|
|
|
|
|
x.split("x");
|
|
|
|
|
x.split("xx");
|
|
|
|
|
x.split('x');
|
|
|
|
|
|
|
|
|
|
let y = "x";
|
|
|
|
|
x.split(y);
|
|
|
|
|
// Not yet testing for multi-byte characters
|
2018-07-28 15:34:52 +00:00
|
|
|
|
// Changing `r.len() == 1` to `r.chars().count() == 1` in `lint_clippy::single_char_pattern`
|
2017-10-10 04:00:47 +00:00
|
|
|
|
// should have done this but produced an ICE
|
|
|
|
|
//
|
|
|
|
|
// We may not want to suggest changing these anyway
|
|
|
|
|
// See: https://github.com/rust-lang-nursery/rust-clippy/issues/650#issuecomment-184328984
|
|
|
|
|
x.split("ß");
|
|
|
|
|
x.split("ℝ");
|
|
|
|
|
x.split("💣");
|
|
|
|
|
// Can't use this lint for unicode code points which don't fit in a char
|
|
|
|
|
x.split("❤️");
|
|
|
|
|
x.contains("x");
|
|
|
|
|
x.starts_with("x");
|
|
|
|
|
x.ends_with("x");
|
|
|
|
|
x.find("x");
|
|
|
|
|
x.rfind("x");
|
|
|
|
|
x.rsplit("x");
|
|
|
|
|
x.split_terminator("x");
|
|
|
|
|
x.rsplit_terminator("x");
|
|
|
|
|
x.splitn(0, "x");
|
|
|
|
|
x.rsplitn(0, "x");
|
|
|
|
|
x.matches("x");
|
|
|
|
|
x.rmatches("x");
|
|
|
|
|
x.match_indices("x");
|
|
|
|
|
x.rmatch_indices("x");
|
|
|
|
|
x.trim_left_matches("x");
|
|
|
|
|
x.trim_right_matches("x");
|
2018-03-02 15:00:01 +00:00
|
|
|
|
// Make sure we escape characters correctly.
|
|
|
|
|
x.split("\n");
|
2017-10-10 04:00:47 +00:00
|
|
|
|
|
|
|
|
|
let h = HashSet::<String>::new();
|
|
|
|
|
h.contains("X"); // should not warn
|
2018-07-31 10:20:32 +00:00
|
|
|
|
|
|
|
|
|
x.replace(";", ",").split(","); // issue #2978
|
2018-08-03 08:19:29 +00:00
|
|
|
|
x.starts_with("\x03"); // issue #2996
|
2018-09-23 13:25:10 +00:00
|
|
|
|
|
|
|
|
|
// Issue #3204
|
|
|
|
|
const S: &str = "#";
|
|
|
|
|
x.find(S);
|
2017-10-10 04:00:47 +00:00
|
|
|
|
}
|