2016-08-04 13:11:32 +05:30
|
|
|
/*
|
2019-04-09 11:39:42 -07:00
|
|
|
* MinIO Cloud Storage, (C) 2015, 2016 MinIO, Inc.
|
2016-08-04 13:11:32 +05:30
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package wildcard
|
|
|
|
|
2016-08-27 00:27:17 -07:00
|
|
|
// MatchSimple - finds whether the text matches/satisfies the pattern string.
|
2016-08-04 13:11:32 +05:30
|
|
|
// supports only '*' wildcard in the pattern.
|
|
|
|
// considers a file system path as a flat name space.
|
2016-08-27 00:27:17 -07:00
|
|
|
func MatchSimple(pattern, name string) bool {
|
2016-08-04 13:11:32 +05:30
|
|
|
if pattern == "" {
|
2016-08-27 00:27:17 -07:00
|
|
|
return name == pattern
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
|
|
|
if pattern == "*" {
|
|
|
|
return true
|
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
rname := make([]rune, 0, len(name))
|
|
|
|
rpattern := make([]rune, 0, len(pattern))
|
|
|
|
for _, r := range name {
|
|
|
|
rname = append(rname, r)
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
for _, r := range pattern {
|
|
|
|
rpattern = append(rpattern, r)
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
simple := true // Does only wildcard '*' match.
|
|
|
|
return deepMatchRune(rname, rpattern, simple)
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
|
|
|
|
2016-08-27 00:27:17 -07:00
|
|
|
// Match - finds whether the text matches/satisfies the pattern string.
|
2016-08-04 13:11:32 +05:30
|
|
|
// supports '*' and '?' wildcards in the pattern string.
|
|
|
|
// unlike path.Match(), considers a path as a flat name space while matching the pattern.
|
|
|
|
// The difference is illustrated in the example here https://play.golang.org/p/Ega9qgD4Qz .
|
2016-08-27 00:27:17 -07:00
|
|
|
func Match(pattern, name string) (matched bool) {
|
|
|
|
if pattern == "" {
|
|
|
|
return name == pattern
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
if pattern == "*" {
|
|
|
|
return true
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
rname := make([]rune, 0, len(name))
|
|
|
|
rpattern := make([]rune, 0, len(pattern))
|
|
|
|
for _, r := range name {
|
|
|
|
rname = append(rname, r)
|
|
|
|
}
|
|
|
|
for _, r := range pattern {
|
|
|
|
rpattern = append(rpattern, r)
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
simple := false // Does extended wildcard '*' and '?' match.
|
|
|
|
return deepMatchRune(rname, rpattern, simple)
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
|
|
|
|
2016-08-27 00:27:17 -07:00
|
|
|
func deepMatchRune(str, pattern []rune, simple bool) bool {
|
|
|
|
for len(pattern) > 0 {
|
|
|
|
switch pattern[0] {
|
2016-08-04 13:11:32 +05:30
|
|
|
default:
|
2016-08-27 00:27:17 -07:00
|
|
|
if len(str) == 0 || str[0] != pattern[0] {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
case '?':
|
|
|
|
if len(str) == 0 && !simple {
|
|
|
|
return false
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
case '*':
|
|
|
|
return deepMatchRune(str, pattern[1:], simple) ||
|
|
|
|
(len(str) > 0 && deepMatchRune(str[1:], pattern, simple))
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
str = str[1:]
|
|
|
|
pattern = pattern[1:]
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|
2016-08-27 00:27:17 -07:00
|
|
|
return len(str) == 0 && len(pattern) == 0
|
2016-08-04 13:11:32 +05:30
|
|
|
}
|