aa8901e9bb
Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/193497 From-SVN: r275473
26 lines
734 B
Go
26 lines
734 B
Go
// Copyright 2018 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build ignore_for_gccgo
|
|
|
|
package bytealg
|
|
|
|
// Empirical data shows that using Index can get better
|
|
// performance when len(s) <= 16.
|
|
const MaxBruteForce = 16
|
|
|
|
func init() {
|
|
// Optimize cases where the length of the substring is less than 32 bytes
|
|
MaxLen = 32
|
|
}
|
|
|
|
// Cutover reports the number of failures of IndexByte we should tolerate
|
|
// before switching over to Index.
|
|
// n is the number of bytes processed so far.
|
|
// See the bytes.Index implementation for details.
|
|
func Cutover(n int) int {
|
|
// 1 error per 16 characters, plus a few slop to start.
|
|
return 4 + n>>4
|
|
}
|