|
|
|
@ -8,7 +8,7 @@ import (
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestParseTermsExtended(t *testing.T) {
|
|
|
|
|
terms := parseTerms(ModeExtended, CaseSmart,
|
|
|
|
|
terms := parseTerms(true, CaseSmart,
|
|
|
|
|
"aaa 'bbb ^ccc ddd$ !eee !'fff !^ggg !hhh$ ^iii$")
|
|
|
|
|
if len(terms) != 9 ||
|
|
|
|
|
terms[0].typ != termFuzzy || terms[0].inv ||
|
|
|
|
@ -33,7 +33,7 @@ func TestParseTermsExtended(t *testing.T) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestParseTermsExtendedExact(t *testing.T) {
|
|
|
|
|
terms := parseTerms(ModeExtendedExact, CaseSmart,
|
|
|
|
|
terms := parseTerms(false, CaseSmart,
|
|
|
|
|
"aaa 'bbb ^ccc ddd$ !eee !'fff !^ggg !hhh$")
|
|
|
|
|
if len(terms) != 8 ||
|
|
|
|
|
terms[0].typ != termExact || terms[0].inv || len(terms[0].text) != 3 ||
|
|
|
|
@ -49,7 +49,7 @@ func TestParseTermsExtendedExact(t *testing.T) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestParseTermsEmpty(t *testing.T) {
|
|
|
|
|
terms := parseTerms(ModeExtended, CaseSmart, "' $ ^ !' !^ !$")
|
|
|
|
|
terms := parseTerms(true, CaseSmart, "' $ ^ !' !^ !$")
|
|
|
|
|
if len(terms) != 0 {
|
|
|
|
|
t.Errorf("%s", terms)
|
|
|
|
|
}
|
|
|
|
@ -58,7 +58,7 @@ func TestParseTermsEmpty(t *testing.T) {
|
|
|
|
|
func TestExact(t *testing.T) {
|
|
|
|
|
defer clearPatternCache()
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pattern := BuildPattern(ModeExtended, CaseSmart, true,
|
|
|
|
|
pattern := BuildPattern(true, true, CaseSmart, true,
|
|
|
|
|
[]Range{}, Delimiter{}, []rune("'abc"))
|
|
|
|
|
sidx, eidx := algo.ExactMatchNaive(
|
|
|
|
|
pattern.caseSensitive, pattern.forward, []rune("aabbcc abc"), pattern.terms[0].text)
|
|
|
|
@ -70,7 +70,7 @@ func TestExact(t *testing.T) {
|
|
|
|
|
func TestEqual(t *testing.T) {
|
|
|
|
|
defer clearPatternCache()
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pattern := BuildPattern(ModeExtended, CaseSmart, true, []Range{}, Delimiter{}, []rune("^AbC$"))
|
|
|
|
|
pattern := BuildPattern(true, true, CaseSmart, true, []Range{}, Delimiter{}, []rune("^AbC$"))
|
|
|
|
|
|
|
|
|
|
match := func(str string, sidxExpected int, eidxExpected int) {
|
|
|
|
|
sidx, eidx := algo.EqualMatch(
|
|
|
|
@ -86,17 +86,17 @@ func TestEqual(t *testing.T) {
|
|
|
|
|
func TestCaseSensitivity(t *testing.T) {
|
|
|
|
|
defer clearPatternCache()
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat1 := BuildPattern(ModeFuzzy, CaseSmart, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
pat1 := BuildPattern(true, false, CaseSmart, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat2 := BuildPattern(ModeFuzzy, CaseSmart, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
pat2 := BuildPattern(true, false, CaseSmart, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat3 := BuildPattern(ModeFuzzy, CaseIgnore, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
pat3 := BuildPattern(true, false, CaseIgnore, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat4 := BuildPattern(ModeFuzzy, CaseIgnore, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
pat4 := BuildPattern(true, false, CaseIgnore, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat5 := BuildPattern(ModeFuzzy, CaseRespect, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
pat5 := BuildPattern(true, false, CaseRespect, true, []Range{}, Delimiter{}, []rune("abc"))
|
|
|
|
|
clearPatternCache()
|
|
|
|
|
pat6 := BuildPattern(ModeFuzzy, CaseRespect, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
pat6 := BuildPattern(true, false, CaseRespect, true, []Range{}, Delimiter{}, []rune("Abc"))
|
|
|
|
|
|
|
|
|
|
if string(pat1.text) != "abc" || pat1.caseSensitive != false ||
|
|
|
|
|
string(pat2.text) != "Abc" || pat2.caseSensitive != true ||
|
|
|
|
@ -109,19 +109,19 @@ func TestCaseSensitivity(t *testing.T) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestOrigTextAndTransformed(t *testing.T) {
|
|
|
|
|
pattern := BuildPattern(ModeExtended, CaseSmart, true, []Range{}, Delimiter{}, []rune("jg"))
|
|
|
|
|
pattern := BuildPattern(true, true, CaseSmart, true, []Range{}, Delimiter{}, []rune("jg"))
|
|
|
|
|
tokens := Tokenize([]rune("junegunn"), Delimiter{})
|
|
|
|
|
trans := Transform(tokens, []Range{Range{1, 1}})
|
|
|
|
|
|
|
|
|
|
origRunes := []rune("junegunn.choi")
|
|
|
|
|
for _, mode := range []Mode{ModeFuzzy, ModeExtended} {
|
|
|
|
|
for _, extended := range []bool{false, true} {
|
|
|
|
|
chunk := Chunk{
|
|
|
|
|
&Item{
|
|
|
|
|
text: []rune("junegunn"),
|
|
|
|
|
origText: &origRunes,
|
|
|
|
|
transformed: trans},
|
|
|
|
|
}
|
|
|
|
|
pattern.mode = mode
|
|
|
|
|
pattern.extended = extended
|
|
|
|
|
matches := pattern.matchChunk(&chunk)
|
|
|
|
|
if string(matches[0].text) != "junegunn" || string(*matches[0].origText) != "junegunn.choi" ||
|
|
|
|
|
matches[0].offsets[0][0] != 0 || matches[0].offsets[0][1] != 5 ||
|
|
|
|
|