diff options
| author | Junegunn Choi <junegunn.c@gmail.com> | 2015-04-14 21:45:37 +0900 |
|---|---|---|
| committer | Junegunn Choi <junegunn.c@gmail.com> | 2015-04-14 21:45:37 +0900 |
| commit | 5c25984ea01677eb759501a5cff3fa63d2d460d8 (patch) | |
| tree | f73b7dd481bcb277372e8ac6f11a7ddede995ad1 /src/pattern.go | |
| parent | 319d6ced80712eedc818d6d9f9982be4860b2c01 (diff) | |
| download | fzf-5c25984ea01677eb759501a5cff3fa63d2d460d8.tar.gz | |
Fix Unicode case handling (#186)
Diffstat (limited to 'src/pattern.go')
| -rw-r--r-- | src/pattern.go | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/pattern.go b/src/pattern.go index fbb70c5f..e6bda5f3 100644 --- a/src/pattern.go +++ b/src/pattern.go @@ -4,12 +4,11 @@ import ( "regexp" "sort" "strings" + "unicode" "github.com/junegunn/fzf/src/algo" ) -const uppercaseLetters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" - // fuzzy // 'exact // ^exact-prefix @@ -91,7 +90,14 @@ func BuildPattern(mode Mode, caseMode Case, switch caseMode { case CaseSmart: - if !strings.ContainsAny(asString, uppercaseLetters) { + hasUppercase := false + for _, r := range runes { + if unicode.IsUpper(r) { + hasUppercase = true + break + } + } + if !hasUppercase { runes, caseSensitive = []rune(strings.ToLower(asString)), false } case CaseIgnore: |
