mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 19:42:38 +00:00 
			
		
		
		
	also bleve did match on fuzzy search and the other way around. this also fix that bug. (cherry picked from commit b9c57fb78e8e0d80d786d8e1da433b6c7ebf2f1c) Conflicts: tests/integration/repo_search_test.go simple conflict resolution in the tests
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package bleve
 | |
| 
 | |
| import (
 | |
| 	"code.gitea.io/gitea/modules/optional"
 | |
| 
 | |
| 	"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, fuzziness int) *query.MatchPhraseQuery {
 | |
| 	q := bleve.NewMatchPhraseQuery(matchPhrase)
 | |
| 	q.FieldVal = field
 | |
| 	q.Analyzer = analyzer
 | |
| 	q.Fuzziness = fuzziness
 | |
| 	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 optional.Option[int64], field string) *query.NumericRangeQuery {
 | |
| 	var minF, maxF *float64
 | |
| 	var minI, maxI *bool
 | |
| 	if min.Has() {
 | |
| 		minF = new(float64)
 | |
| 		*minF = float64(min.Value())
 | |
| 		minI = new(bool)
 | |
| 		*minI = true
 | |
| 	}
 | |
| 	if max.Has() {
 | |
| 		maxF = new(float64)
 | |
| 		*maxF = float64(max.Value())
 | |
| 		maxI = new(bool)
 | |
| 		*maxI = true
 | |
| 	}
 | |
| 	q := bleve.NewNumericRangeInclusiveQuery(minF, maxF, minI, maxI)
 | |
| 	q.SetField(field)
 | |
| 	return q
 | |
| }
 |