mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 08:21:11 +00:00 
			
		
		
		
	meilisearch does not have an search option to contorl fuzzynes per query right now: - https://github.com/meilisearch/meilisearch/issues/1192 - https://github.com/orgs/meilisearch/discussions/377 - https://github.com/meilisearch/meilisearch/discussions/1096 so we have to create a workaround by post-filter the search result in gitea until this is addressed. For future works I added an option in backend only atm, to enable fuzzynes for issue indexer too. And also refactored the code so the fuzzy option is equal in logic to code indexer --- *Sponsored by Kithara Software GmbH* Conflicts: routers/web/repo/search.go trivial context confict s/isMatch/isFuzzy/
		
			
				
	
	
		
			60 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2023 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package bleve
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/blevesearch/bleve/v2"
 | 
						|
	"github.com/blevesearch/bleve/v2/search/query"
 | 
						|
)
 | 
						|
 | 
						|
// NumericEqualityQuery generates a numeric equality query for the given value and field
 | 
						|
func NumericEqualityQuery(value int64, field string) *query.NumericRangeQuery {
 | 
						|
	f := float64(value)
 | 
						|
	tru := true
 | 
						|
	q := bleve.NewNumericRangeInclusiveQuery(&f, &f, &tru, &tru)
 | 
						|
	q.SetField(field)
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
// MatchPhraseQuery generates a match phrase query for the given phrase, field and analyzer
 | 
						|
func MatchPhraseQuery(matchPhrase, field, analyzer string) *query.MatchPhraseQuery {
 | 
						|
	q := bleve.NewMatchPhraseQuery(matchPhrase)
 | 
						|
	q.FieldVal = field
 | 
						|
	q.Analyzer = analyzer
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
// PrefixQuery generates a match prefix query for the given prefix and field
 | 
						|
func PrefixQuery(matchPrefix, field string) *query.PrefixQuery {
 | 
						|
	q := bleve.NewPrefixQuery(matchPrefix)
 | 
						|
	q.FieldVal = field
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
// BoolFieldQuery generates a bool field query for the given value and field
 | 
						|
func BoolFieldQuery(value bool, field string) *query.BoolFieldQuery {
 | 
						|
	q := bleve.NewBoolFieldQuery(value)
 | 
						|
	q.SetField(field)
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
func NumericRangeInclusiveQuery(min, max *int64, field string) *query.NumericRangeQuery {
 | 
						|
	var minF, maxF *float64
 | 
						|
	var minI, maxI *bool
 | 
						|
	if min != nil {
 | 
						|
		minF = new(float64)
 | 
						|
		*minF = float64(*min)
 | 
						|
		minI = new(bool)
 | 
						|
		*minI = true
 | 
						|
	}
 | 
						|
	if max != nil {
 | 
						|
		maxF = new(float64)
 | 
						|
		*maxF = float64(*max)
 | 
						|
		maxI = new(bool)
 | 
						|
		*maxI = true
 | 
						|
	}
 | 
						|
	q := bleve.NewNumericRangeInclusiveQuery(minF, maxF, minI, maxI)
 | 
						|
	q.SetField(field)
 | 
						|
	return q
 | 
						|
}
 |