mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 00:11:04 +00:00 
			
		
		
		
	An attempt at solving #7956. This (and rebuilding the index) seems enough to ensure the issue *appears* among the results. However, I couldn't figure out from [bleve docs](https://github.com/blevesearch/bleve/blob/master/docs/scoring.md) how to affect the scoring based on specific fields, or whether that is possible at all. Disclaimer: I've never written Go before, sorry 😅 take it as a quick PoC more than anything. ### Tests - I added test coverage for Go changes... - [x] in their respective `*_test.go` for unit tests. - [ ] in the `tests/integration` directory if it involves interactions with a live Forgejo server. - I added test coverage for JavaScript changes... - [ ] in `web_src/js/*.test.js` if it can be unit tested. - [ ] in `tests/e2e/*.test.e2e.js` if it requires interactions with a live Forgejo server (see also the [developer guide for JavaScript testing](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/tests/e2e/README.md#end-to-end-tests)). ### Documentation - [ ] I created a pull request [to the documentation](https://codeberg.org/forgejo/docs) to explain to Forgejo users how to use this change. - [x] I did not document these changes and I do not expect someone else to do it. ### Release notes - [ ] I do not want this change to show in the release notes. - [x] I want the title to show in the release notes with a link to this pull request. - [ ] I want the content of the `release-notes/<pull request number>.md` to be be used for the release notes instead of the title. <!--start release-notes-assistant--> ## Release notes <!--URL:https://codeberg.org/forgejo/forgejo--> - Features - [PR](https://codeberg.org/forgejo/forgejo/pulls/7968): <!--number 7968 --><!--line 0 --><!--description QWRkIGlzc3VlIG51bWJlciB0byB0aGUgc2VhcmNoIGluZGV4LCByYW5rIG51bWJlciBhbmQgdGl0bGUgbWF0Y2hlcyBoaWdoZXIgKCM3OTU2KQ==-->Add issue number to the search index, rank number and title matches higher (#7956)<!--description--> <!--end release-notes-assistant--> Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7968 Reviewed-by: Shiny Nematoda <snematoda@noreply.codeberg.org> Co-authored-by: Danko Aleksejevs <danko@very.lv> Co-committed-by: Danko Aleksejevs <danko@very.lv>
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2023 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package bleve
 | 
						|
 | 
						|
import (
 | 
						|
	"forgejo.org/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                                                  // codespell:ignore
 | 
						|
	q := bleve.NewNumericRangeInclusiveQuery(&f, &f, &tru, &tru) // codespell:ignore
 | 
						|
	q.SetField(field)
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
// MatchQuery generates a match query for the given phrase, field and analyzer
 | 
						|
func MatchQuery(matchTerm, field, analyzer string, fuzziness int) *query.MatchQuery {
 | 
						|
	q := bleve.NewMatchQuery(matchTerm)
 | 
						|
	q.FieldVal = field
 | 
						|
	q.Analyzer = analyzer
 | 
						|
	q.Fuzziness = fuzziness
 | 
						|
	return q
 | 
						|
}
 | 
						|
 | 
						|
// MatchPhraseQuery generates a match phrase query for the given phrase, field and analyzer
 | 
						|
func MatchPhraseQuery(matchPhrase, field, analyzer string, autoFuzzy bool, boost float64) *query.MatchPhraseQuery {
 | 
						|
	q := bleve.NewMatchPhraseQuery(matchPhrase)
 | 
						|
	q.FieldVal = field
 | 
						|
	q.Analyzer = analyzer
 | 
						|
	q.SetAutoFuzziness(autoFuzzy)
 | 
						|
	q.SetBoost(boost)
 | 
						|
	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
 | 
						|
}
 |