diff options
author | Jason Song <i@wolfogre.com> | 2023-08-16 23:40:13 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-16 15:40:13 +0000 |
commit | 3b129aaa80e752dd2e0e007fc28c0db652af6b5c (patch) | |
tree | 90102c735b44b4413645d0f4363f3493b7c231fd /modules/indexer/issues/internal/model.go | |
parent | 1432d4eab94814db267577ec911a3375a1269fc0 (diff) | |
download | gitea-3b129aaa80e752dd2e0e007fc28c0db652af6b5c.tar.gz gitea-3b129aaa80e752dd2e0e007fc28c0db652af6b5c.zip |
Explain SearchOptions and fix ToSearchOptions (#26542)
Follow #26012 #26490.
A detailed description has been added to the comment.
Diffstat (limited to 'modules/indexer/issues/internal/model.go')
-rw-r--r-- | modules/indexer/issues/internal/model.go | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/modules/indexer/issues/internal/model.go b/modules/indexer/issues/internal/model.go index 31acd16bd4..2de1e0e2bf 100644 --- a/modules/indexer/issues/internal/model.go +++ b/modules/indexer/issues/internal/model.go @@ -56,7 +56,21 @@ type SearchResult struct { Hits []Match } -// SearchOptions represents search options +// SearchOptions represents search options. +// +// It has a slightly different design from database query options. +// In database query options, a field is never a pointer, so it could be confusing when it's zero value: +// Do you want to find data with a field value of 0, or do you not specify the field in the options? +// To avoid this confusion, db introduced db.NoConditionID(-1). +// So zero value means the field is not specified in the search options, and db.NoConditionID means "== 0" or "id NOT IN (SELECT id FROM ...)" +// It's still not ideal, it trapped developers many times. +// And sometimes -1 could be a valid value, like issue ID, negative numbers indicate exclusion. +// Since db.NoConditionID is for "db" (the package name is db), it makes sense not to use it in the indexer: +// Why do bleve/elasticsearch/meilisearch indexers need to know about db.NoConditionID? +// So in SearchOptions, we use pointer for fields which could be not specified, +// and always use the value to filter if it's not nil, even if it's zero or negative. +// It can handle almost all cases, if there is an exception, we can add a new field, like NoLabelOnly. +// Unfortunately, we still use db for the indexer and have to convert between db.NoConditionID and nil for legacy reasons. type SearchOptions struct { Keyword string // keyword to search |