mirror of
https://github.com/go-gitea/gitea
synced 2024-09-27 14:54:05 +00:00
12a1f914f4
* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
99 lines
2.5 KiB
Go
Vendored
99 lines
2.5 KiB
Go
Vendored
// Copyright 2012-present Oliver Eilhard. All rights reserved.
|
|
// Use of this source code is governed by a MIT-license.
|
|
// See http://olivere.mit-license.org/license.txt for details.
|
|
|
|
package elastic
|
|
|
|
// SpanNearQuery matches spans which are near one another. One can specify slop,
|
|
// the maximum number of intervening unmatched positions, as well as whether
|
|
// matches are required to be in-order. The span near query maps to Lucene SpanNearQuery.
|
|
//
|
|
// See https://www.elastic.co/guide/en/elasticsearch/reference/7.7/query-dsl-span-near-query.html
|
|
// for details.
|
|
type SpanNearQuery struct {
|
|
clauses []Query
|
|
slop *int
|
|
inOrder *bool
|
|
boost *float64
|
|
queryName string
|
|
}
|
|
|
|
// NewSpanNearQuery creates a new SpanNearQuery.
|
|
func NewSpanNearQuery(clauses ...Query) *SpanNearQuery {
|
|
return &SpanNearQuery{
|
|
clauses: clauses,
|
|
}
|
|
}
|
|
|
|
// Add clauses to use in the query.
|
|
func (q *SpanNearQuery) Add(clauses ...Query) *SpanNearQuery {
|
|
q.clauses = append(q.clauses, clauses...)
|
|
return q
|
|
}
|
|
|
|
// Clauses to use in the query.
|
|
func (q *SpanNearQuery) Clauses(clauses ...Query) *SpanNearQuery {
|
|
q.clauses = clauses
|
|
return q
|
|
}
|
|
|
|
// Slop controls the maximum number of intervening unmatched positions permitted.
|
|
func (q *SpanNearQuery) Slop(slop int) *SpanNearQuery {
|
|
q.slop = &slop
|
|
return q
|
|
}
|
|
|
|
// InOrder, when true, the spans from each clause must be in the same order as
|
|
// in Clauses and must be non-overlapping. Defaults to true.
|
|
func (q *SpanNearQuery) InOrder(inOrder bool) *SpanNearQuery {
|
|
q.inOrder = &inOrder
|
|
return q
|
|
}
|
|
|
|
// Boost sets the boost for this query.
|
|
func (q *SpanNearQuery) Boost(boost float64) *SpanNearQuery {
|
|
q.boost = &boost
|
|
return q
|
|
}
|
|
|
|
// QueryName sets the query name for the filter that can be used when
|
|
// searching for matched_filters per hit.
|
|
func (q *SpanNearQuery) QueryName(queryName string) *SpanNearQuery {
|
|
q.queryName = queryName
|
|
return q
|
|
}
|
|
|
|
// Source returns the JSON body.
|
|
func (q *SpanNearQuery) Source() (interface{}, error) {
|
|
m := make(map[string]interface{})
|
|
c := make(map[string]interface{})
|
|
|
|
if len(q.clauses) > 0 {
|
|
var clauses []interface{}
|
|
for _, clause := range q.clauses {
|
|
src, err := clause.Source()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
clauses = append(clauses, src)
|
|
}
|
|
c["clauses"] = clauses
|
|
}
|
|
|
|
if v := q.slop; v != nil {
|
|
c["slop"] = *v
|
|
}
|
|
if v := q.inOrder; v != nil {
|
|
c["in_order"] = *v
|
|
}
|
|
|
|
if v := q.boost; v != nil {
|
|
c["boost"] = *v
|
|
}
|
|
if v := q.queryName; v != "" {
|
|
c["query_name"] = v
|
|
}
|
|
m["span_near"] = c
|
|
return m, nil
|
|
}
|