# substring [![Build Status](https://travis-ci.org/toqueteos/substring.png?branch=master)](https://travis-ci.org/toqueteos/substring) [![GoDoc](http://godoc.org/github.com/toqueteos/substring?status.png)](http://godoc.org/github.com/toqueteos/substring) [![GitHub release](https://img.shields.io/github/release/toqueteos/substring.svg)](https://github.com/toqueteos/substring/releases) Simple and composable alternative to [regexp](http://golang.org/pkg/regexp/) package for fast substring searches. ## Installation The recommended way to install substring ``` go get -t gopkg.in/toqueteos/substring.v1 ``` The `-t` flag is for fetching [gocheck](https://gopkg.in/check.v1), required for tests and benchmarks. ## Examples A basic example with two matchers: ```go package main import ( "fmt" "regexp" "gopkg.in/toqueteos/substring.v1" ) func main() { m1 := substring.After("assets/", substring.Or( substring.Has("jquery"), substring.Has("angular"), substring.Suffixes(".js", ".css", ".html"), )) fmt.Println(m1.Match("assets/angular/foo/bar")) //Prints: true fmt.Println(m1.Match("assets/js/file.js")) //Prints: true fmt.Println(m1.Match("assets/style/bar.css")) //Prints: true fmt.Println(m1.Match("assets/foo/bar.html")) //Prints: false fmt.Println(m1.Match("assets/js/qux.json")) //Prints: false fmt.Println(m1.Match("core/file.html")) //Prints: false fmt.Println(m1.Match("foobar/that.jsx")) //Prints: false m2 := substring.After("vendor/", substring.Suffixes(".css", ".js", ".less")) fmt.Println(m2.Match("foo/vendor/bar/qux.css")) //Prints: true fmt.Println(m2.Match("foo/var/qux.less")) //Prints: false re := regexp.MustCompile(`vendor\/.*\.(css|js|less)$`) fmt.Println(re.MatchString("foo/vendor/bar/qux.css")) //Prints: true fmt.Println(re.MatchString("foo/var/qux.less")) //Prints: false } ``` ## How fast? It may vary depending on your use case but 1~2 orders of magnitude faster than `regexp` is pretty common. Test it out for yourself by running `go test -check.b`! ``` $ go test -check.b PASS: lib_test.go:18: LibSuite.BenchmarkExample1 10000000 221 ns/op PASS: lib_test.go:23: LibSuite.BenchmarkExample2 10000000 229 ns/op PASS: lib_test.go:28: LibSuite.BenchmarkExample3 10000000 216 ns/op PASS: lib_test.go:33: LibSuite.BenchmarkExample4 10000000 208 ns/op PASS: lib_test.go:38: LibSuite.BenchmarkExample5 20000000 82.1 ns/op PASS: lib_test.go:48: LibSuite.BenchmarkExampleRe1 500000 4136 ns/op PASS: lib_test.go:53: LibSuite.BenchmarkExampleRe2 500000 5222 ns/op PASS: lib_test.go:58: LibSuite.BenchmarkExampleRe3 500000 5116 ns/op PASS: lib_test.go:63: LibSuite.BenchmarkExampleRe4 500000 4020 ns/op PASS: lib_test.go:68: LibSuite.BenchmarkExampleRe5 10000000 226 ns/op OK: 10 passed PASS ok gopkg.in/toqueteos/substring.v1 23.471s ``` License ------- MIT, see [LICENSE](LICENSE)