1
0
Fork 0
golang-github-blevesearch-b.../search/query/multi_phrase.go
Daniel Baumann 982828099e
Adding upstream version 2.5.1.
Signed-off-by: Daniel Baumann <daniel@debian.org>
2025-05-19 00:20:02 +02:00

130 lines
3.4 KiB
Go

// Copyright (c) 2014 Couchbase, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package query
import (
"context"
"fmt"
"github.com/blevesearch/bleve/v2/mapping"
"github.com/blevesearch/bleve/v2/search"
"github.com/blevesearch/bleve/v2/search/searcher"
"github.com/blevesearch/bleve/v2/util"
index "github.com/blevesearch/bleve_index_api"
)
type MultiPhraseQuery struct {
Terms [][]string `json:"terms"`
FieldVal string `json:"field,omitempty"`
BoostVal *Boost `json:"boost,omitempty"`
Fuzziness int `json:"fuzziness"`
autoFuzzy bool
}
// NewMultiPhraseQuery creates a new Query for finding
// term phrases in the index.
// It is like PhraseQuery, but each position in the
// phrase may be satisfied by a list of terms
// as opposed to just one.
// At least one of the terms must exist in the correct
// order, at the correct index offsets, in the
// specified field. Queried field must have been indexed with
// IncludeTermVectors set to true.
func NewMultiPhraseQuery(terms [][]string, field string) *MultiPhraseQuery {
return &MultiPhraseQuery{
Terms: terms,
FieldVal: field,
}
}
func (q *MultiPhraseQuery) SetFuzziness(f int) {
q.Fuzziness = f
}
func (q *MultiPhraseQuery) SetAutoFuzziness(auto bool) {
q.autoFuzzy = auto
}
func (q *MultiPhraseQuery) SetBoost(b float64) {
boost := Boost(b)
q.BoostVal = &boost
}
func (q *MultiPhraseQuery) Boost() float64 {
return q.BoostVal.Value()
}
func (q *MultiPhraseQuery) Field() string {
return q.FieldVal
}
func (q *MultiPhraseQuery) SetField(f string) {
q.FieldVal = f
}
func (q *MultiPhraseQuery) Searcher(ctx context.Context, i index.IndexReader, m mapping.IndexMapping, options search.SearcherOptions) (search.Searcher, error) {
return searcher.NewMultiPhraseSearcher(ctx, i, q.Terms, q.Fuzziness, q.autoFuzzy, q.FieldVal, q.BoostVal.Value(), options)
}
func (q *MultiPhraseQuery) Validate() error {
if len(q.Terms) < 1 {
return fmt.Errorf("phrase query must contain at least one term")
}
return nil
}
func (q *MultiPhraseQuery) UnmarshalJSON(data []byte) error {
type Alias MultiPhraseQuery
aux := &struct {
Fuzziness interface{} `json:"fuzziness"`
*Alias
}{
Alias: (*Alias)(q),
}
if err := util.UnmarshalJSON(data, &aux); err != nil {
return err
}
switch v := aux.Fuzziness.(type) {
case float64:
q.Fuzziness = int(v)
case string:
if v == "auto" {
q.autoFuzzy = true
}
}
return nil
}
func (f *MultiPhraseQuery) MarshalJSON() ([]byte, error) {
var fuzzyValue interface{}
if f.autoFuzzy {
fuzzyValue = "auto"
} else {
fuzzyValue = f.Fuzziness
}
type multiPhraseQuery struct {
Terms [][]string `json:"terms"`
FieldVal string `json:"field,omitempty"`
BoostVal *Boost `json:"boost,omitempty"`
Fuzziness interface{} `json:"fuzziness"`
}
aux := multiPhraseQuery{
Terms: f.Terms,
FieldVal: f.FieldVal,
BoostVal: f.BoostVal,
Fuzziness: fuzzyValue,
}
return util.MarshalJSON(aux)
}