Skip to content

Commit 3f5d0b5

Browse files
committed
auto merge of rust-lang#16590 : nham/rust/str_searcher_underflow, r=alexcrichton
This incidentally fixes rust-lang#16589, because it will cause `MatchIndices` to use `NaiveSearcher` instead of `TwoWaySearcher`, but I'm not sure rust-lang#16589 should be closed until the underlying problem in `TwoWaySearcher` is found.
2 parents c883510 + 3b0084e commit 3f5d0b5

File tree

3 files changed

+16
-1
lines changed

3 files changed

+16
-1
lines changed

src/libcore/str.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -562,7 +562,7 @@ enum Searcher {
562562
impl Searcher {
563563
fn new(haystack: &[u8], needle: &[u8]) -> Searcher {
564564
// FIXME: Tune this.
565-
if needle.len() > haystack.len() - 20 {
565+
if needle.len() + 20 > haystack.len() {
566566
Naive(NaiveSearcher::new())
567567
} else {
568568
let searcher = TwoWaySearcher::new(needle);

src/libcoretest/lib.rs

+1
Original file line numberDiff line numberDiff line change
@@ -29,4 +29,5 @@ mod ptr;
2929
mod raw;
3030
mod result;
3131
mod slice;
32+
mod str;
3233
mod tuple;

src/libcoretest/str.rs

+14
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
#[test]
12+
fn strslice_issue_16589() {
13+
assert!("bananas".contains("nana"));
14+
}

0 commit comments

Comments
 (0)