Skip to content

IGLOU-EU/go-wildcard

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

47 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Go-wildcard

Warning

Deprecated β€” moved to gitlab.com/iglou.eu/goulc/wildcard. This library has been merged into the goulc bundle that regroups several Iglou libraries under one module. This repository is no longer maintained; please migrate.

Go Report Card Go Reference BSD 3 Clause

πŸ’‘ Why

The purpose of this library is to provide a simple and fast wildcard pattern matching. Regex are much more complex and slower (even prepared regex)... and the filepath.Match is file-name-centric.

So, this library is a very fast and very simple alternative to regex and not tied to filename semantics unlike filepath.Match. There are no dependencies and is allocation-free. πŸ₯³

🧰 Features

These are the supported pattern operators:

  • * match zero or more characters
  • ? match zero or one character
  • . match exactly one character

🧐 How to

⚠️ WARNING: Unlike the GNU "libc", this library have no equivalent to "FNM_FILE_NAME". To do this you can use "path/filepath" https://pkg.go.dev/path/filepath#Match

It is very simple to use this library: import it and call the Match function β€” or one of its variants, as shown below.

package main

import (
	"fmt"

	"github.com/IGLOU-EU/go-wildcard/v2"
)

func main() {
	str := "daaadabadmanda"
	pattern := "?a*da*d.?*"

	resultM := wildcard.Match(pattern, str) // Fastest, compares byte by byte
	resultMFB := wildcard.MatchFromByte([]byte(pattern), []byte(str)) // Like Match, for byte slices. Skips the string conversion
	resultMBR := wildcard.MatchByRune(pattern, str) // Compares rune by rune. Slower and the []rune conversion allocates

	fmt.Println(str, pattern, resultM, resultMFB, resultMBR)
}

πŸ›Έ Benchmark

The benchmark is done with the following command:

go test -benchmem -bench . github.com/IGLOU-EU/go-wildcard/v2/benchmark
goos: linux
goarch: amd64
pkg: github.com/IGLOU-EU/go-wildcard/v2
cpu: AMD Ryzen 7 PRO 6850U with Radeon Graphics  

The tested functions are:

  • regexp.MatchString
  • regexp.MatchPreparedString
  • filepath.Match
  • oldMatchSimple From the commit a899be92514ed08aa5271bc3b93320b719ce2114
  • oldMatch From the commit a899be92514ed08aa5271bc3b93320b719ce2114
  • Match From string with byte comparison
  • MatchByRune From string with rune comparison
  • MatchFromByte From byte slice with byte comparison
Rank Benchmark Average ns/op Samples
1 BenchmarkMatch 10.83 6
2 BenchmarkMatchFromByte 12.14 6
3 BenchmarkMatchByRune 60.78 6
4 BenchmarkRegexPrepared 86.48 4
5 BenchmarkFilepath 87.90 6
6 BenchmarkOldMatch 97.04 6
7 BenchmarkOldMatchSimple 98.24 6
8 BenchmarkRegex 2261.77 6

time bench allocs bench

πŸ•° History

Originally, this library was a fork from the Minio project. The purpose was to give access to this "lib" under Apache license, without importing the entire Minio project. And to keep it usable under the Apache License Version 2.0 after MinIO project is migrated to GNU Affero General Public License 3.0 or later from update license change for MinIO

The actual Minio wildcard matching code can be found in wildcard.go

About

πŸš€ Fast and light wildcard pattern matching.

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors