Skip to content

Commit

Permalink
support contains
Browse files Browse the repository at this point in the history
  • Loading branch information
Jguer committed Nov 13, 2022
1 parent 56a4664 commit 5aeb0d6
Show file tree
Hide file tree
Showing 7 changed files with 41 additions and 22 deletions.
3 changes: 2 additions & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,8 @@ func main() {
config.Runtime.QueryBuilder = query.NewSourceQueryBuilder(
config.Runtime.AURClient, config.Runtime.AURCache,
config.SortBy,
config.Runtime.Mode, config.SearchBy, config.BottomUp, config.SingleLineResults)
config.Runtime.Mode, config.SearchBy, config.BottomUp,
config.SingleLineResults, config.NewInstallEngine)
} else {
config.Runtime.QueryBuilder = query.NewMixedSourceQueryBuilder(
config.Runtime.AURClient, config.SortBy,
Expand Down
20 changes: 15 additions & 5 deletions pkg/metadata/metadata_aur.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,9 @@ type AURCache struct {
}

type AURQuery struct {
Needles []string
By aur.By
Needles []string
By aur.By
Contains bool // if true, search for packages containing the needle, not exact matches
}

func NewAURCache(cachePath string) (*AURCache, error) {
Expand Down Expand Up @@ -142,15 +143,24 @@ func (a *AURCache) gojqGetBatch(ctx context.Context, query *AURQuery) ([]*aur.Pk

bys := toSearchBy(query.By)
for j, by := range bys {
pattern += fmt.Sprintf("(.%s == \"%s\")", by, searchTerm)
if query.Contains {
pattern += fmt.Sprintf("(.%s // empty | test(\"%s\"))", by, searchTerm)
} else {
pattern += fmt.Sprintf("(.%s == \"%s\")", by, searchTerm)
}

if j != len(bys)-1 {
pattern += " or "
pattern += " , "
}
}
}

pattern += ")"

if a.DebugLoggerFn != nil {
a.DebugLoggerFn("AUR metadata query", pattern)
}

parsed, err := gojq.Parse(pattern)
if err != nil {
log.Fatalln(err)
Expand All @@ -176,7 +186,7 @@ func (a *AURCache) gojqGetBatch(ctx context.Context, query *AURQuery) ([]*aur.Pk
}

if a.DebugLoggerFn != nil {
a.DebugLoggerFn("AUR Query", pattern, "Found", len(final))
a.DebugLoggerFn("AUR metadata query found", len(final))
}

return final, nil
Expand Down
1 change: 1 addition & 0 deletions pkg/query/aur_info.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ func AURInfo(ctx context.Context, aurClient aur.ClientInterface, names []string,
makeRequest := func(n, max int) {
defer wg.Done()

text.Debugln("AUR RPC:", names[n:max])
tempInfo, requestErr := aurClient.Info(ctx, names[n:max])
if requestErr != nil {
errs.Add(requestErr)
Expand Down
2 changes: 1 addition & 1 deletion pkg/query/mixed_sources.go
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,7 @@ func (s *MixedSourceQueryBuilder) Execute(ctx context.Context, dbExecutor db.Exe

if s.targetMode.AtLeastAUR() {
var aurResults aurQuery
aurResults, aurErr = queryAUR(ctx, s.aurClient, nil, pkgS, s.searchBy)
aurResults, aurErr = queryAUR(ctx, s.aurClient, nil, pkgS, s.searchBy, false)
dbName := sourceAUR

for i := range aurResults {
Expand Down
33 changes: 20 additions & 13 deletions pkg/query/source.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ const (
type SourceQueryBuilder struct {
repoQuery
aurQuery

useAURCache bool
sortBy string
searchBy string
targetMode parser.TargetMode
Expand All @@ -48,6 +50,7 @@ func NewSourceQueryBuilder(
searchBy string,
bottomUp,
singleLineResults bool,
useAURCache bool,
) *SourceQueryBuilder {
return &SourceQueryBuilder{
aurClient: aurClient,
Expand All @@ -59,6 +62,7 @@ func NewSourceQueryBuilder(
targetMode: targetMode,
searchBy: searchBy,
singleLineResults: singleLineResults,
useAURCache: useAURCache,
}
}

Expand All @@ -71,7 +75,7 @@ func (s *SourceQueryBuilder) Execute(ctx context.Context,
pkgS = RemoveInvalidTargets(pkgS, s.targetMode)

if s.targetMode.AtLeastAUR() {
s.aurQuery, aurErr = queryAUR(ctx, s.aurClient, s.aurCache, pkgS, s.searchBy)
s.aurQuery, aurErr = queryAUR(ctx, s.aurClient, s.aurCache, pkgS, s.searchBy, s.useAURCache)
s.aurQuery = filterAURResults(pkgS, s.aurQuery)

sort.Sort(aurSortable{aurQuery: s.aurQuery, sortBy: s.sortBy, bottomUp: s.bottomUp})
Expand Down Expand Up @@ -189,7 +193,7 @@ func filterAURResults(pkgS []string, results []aur.Pkg) []aur.Pkg {
// queryAUR searches AUR and narrows based on subarguments.
func queryAUR(ctx context.Context,
aurClient aur.ClientInterface, aurMetadata *metadata.AURCache,
pkgS []string, searchBy string,
pkgS []string, searchBy string, newEngine bool,
) ([]aur.Pkg, error) {
var (
err error
Expand All @@ -199,18 +203,11 @@ func queryAUR(ctx context.Context,
for _, word := range pkgS {
var r []aur.Pkg

// if one of the search terms returns a result we start filtering by it
if aurClient != nil {
r, err = aurClient.Search(ctx, word, by)
if err == nil {
return r, nil
}
}

if aurMetadata != nil {
if aurMetadata != nil && newEngine {
q, err := aurMetadata.Get(ctx, &metadata.AURQuery{
Needles: []string{word},
By: by,
Needles: []string{word},
By: by,
Contains: true,
})

for _, pkg := range q {
Expand All @@ -219,6 +216,16 @@ func queryAUR(ctx context.Context,

if err == nil {
return r, nil
} else {
text.Warnln("AUR Metadata search failed:", err)
}
}
// if one of the search terms returns a result we start filtering by it
if aurClient != nil {
text.Debugln("AUR RPC:", by, word)

if r, err = aurClient.Search(ctx, word, by); err == nil {
return r, nil
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion pkg/query/source_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ func TestSourceQueryBuilder(t *testing.T) {
client, err := aur.NewClient(aur.WithHTTPClient(&mockDoer{}))
require.NoError(t, err)

queryBuilder := NewSourceQueryBuilder(client, nil, "votes", parser.ModeAny, "", tc.bottomUp, false)
queryBuilder := NewSourceQueryBuilder(client, nil, "votes", parser.ModeAny, "", tc.bottomUp, false, false)
search := []string{"linux"}
mockStore := &mockDB{}

Expand Down
2 changes: 1 addition & 1 deletion pkg/text/print.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ func Debugln(a ...interface{}) {
return
}

fmt.Fprintln(os.Stdout, append([]interface{}{Bold(yellow("[DEBUG] "))}, a...)...)
fmt.Fprintln(os.Stdout, append([]interface{}{Bold(yellow("[DEBUG]"))}, a...)...)
fmt.Fprint(os.Stdout, ResetCode)
}

Expand Down

0 comments on commit 5aeb0d6

Please sign in to comment.