mirror of https://github.com/cheat/cheat.git
feat(search): search all cheatpaths
Update the search function. It now searches all cheatpaths all the time, as if `--all` were implicitly passed.
This commit is contained in:
parent
a58294859e
commit
4ef4c35d8c
|
@ -8,7 +8,6 @@ import (
|
||||||
|
|
||||||
"github.com/cheat/cheat/internal/config"
|
"github.com/cheat/cheat/internal/config"
|
||||||
"github.com/cheat/cheat/internal/display"
|
"github.com/cheat/cheat/internal/display"
|
||||||
"github.com/cheat/cheat/internal/sheet"
|
|
||||||
"github.com/cheat/cheat/internal/sheets"
|
"github.com/cheat/cheat/internal/sheets"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -32,72 +31,63 @@ func cmdSearch(opts map[string]interface{}, conf config.Config) {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// consolidate the cheatsheets found on all paths into a single map of
|
// iterate over each cheatpath
|
||||||
// `title` => `sheet` (ie, allow more local cheatsheets to override less
|
|
||||||
// local cheatsheets)
|
|
||||||
consolidated := sheets.Consolidate(cheatsheets)
|
|
||||||
|
|
||||||
// if <cheatsheet> was provided, search that single sheet only
|
|
||||||
if opts["<cheatsheet>"] != nil {
|
|
||||||
|
|
||||||
cheatsheet := opts["<cheatsheet>"].(string)
|
|
||||||
|
|
||||||
// assert that the cheatsheet exists
|
|
||||||
s, ok := consolidated[cheatsheet]
|
|
||||||
if !ok {
|
|
||||||
fmt.Printf("No cheatsheet found for '%s'.\n", cheatsheet)
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
|
|
||||||
consolidated = map[string]sheet.Sheet{
|
|
||||||
cheatsheet: s,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// sort the cheatsheets alphabetically, and search for matches
|
|
||||||
out := ""
|
out := ""
|
||||||
for _, sheet := range sheets.Sort(consolidated) {
|
for _, pathcheats := range cheatsheets {
|
||||||
|
|
||||||
// assume that we want to perform a case-insensitive search for <phrase>
|
// sort the cheatsheets alphabetically, and search for matches
|
||||||
pattern := "(?i)" + phrase
|
for _, sheet := range sheets.Sort(pathcheats) {
|
||||||
|
|
||||||
// unless --regex is provided, in which case we pass the regex unaltered
|
// if <cheatsheet> was provided, constrain the search only to
|
||||||
if opts["--regex"] == true {
|
// matching cheatsheets
|
||||||
pattern = phrase
|
if opts["<cheatsheet>"] != nil && sheet.Title != opts["<cheatsheet>"] {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// assume that we want to perform a case-insensitive search for <phrase>
|
||||||
|
pattern := "(?i)" + phrase
|
||||||
|
|
||||||
|
// unless --regex is provided, in which case we pass the regex unaltered
|
||||||
|
if opts["--regex"] == true {
|
||||||
|
pattern = phrase
|
||||||
|
}
|
||||||
|
|
||||||
|
// compile the regex
|
||||||
|
reg, err := regexp.Compile(pattern)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(os.Stderr, fmt.Sprintf("failed to compile regexp: %s, %v", pattern, err))
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
// `Search` will return text entries that match the search terms. We're
|
||||||
|
// using it here to overwrite the prior cheatsheet Text, filtering it to
|
||||||
|
// only what is relevant
|
||||||
|
sheet.Text = sheet.Search(reg)
|
||||||
|
|
||||||
|
// if the sheet did not match the search, ignore it and move on
|
||||||
|
if sheet.Text == "" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// if colorization was requested, apply it here
|
||||||
|
if conf.Color(opts) {
|
||||||
|
sheet.Colorize(conf)
|
||||||
|
}
|
||||||
|
|
||||||
|
// display the cheatsheet title and path
|
||||||
|
out += fmt.Sprintf("\n%s %s\n",
|
||||||
|
display.Underline(sheet.Title),
|
||||||
|
display.Faint(fmt.Sprintf("(%s)", sheet.CheatPath)),
|
||||||
|
)
|
||||||
|
|
||||||
|
// indent each line of content
|
||||||
|
out += display.Indent(sheet.Text) + "\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
// compile the regex
|
|
||||||
reg, err := regexp.Compile(pattern)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintln(os.Stderr, fmt.Sprintf("failed to compile regexp: %s, %v", pattern, err))
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
// `Search` will return text entries that match the search terms. We're
|
|
||||||
// using it here to overwrite the prior cheatsheet Text, filtering it to
|
|
||||||
// only what is relevant
|
|
||||||
sheet.Text = sheet.Search(reg)
|
|
||||||
|
|
||||||
// if the sheet did not match the search, ignore it and move on
|
|
||||||
if sheet.Text == "" {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
// if colorization was requested, apply it here
|
|
||||||
if conf.Color(opts) {
|
|
||||||
sheet.Colorize(conf)
|
|
||||||
}
|
|
||||||
|
|
||||||
// display the cheatsheet title and path
|
|
||||||
out += fmt.Sprintf("\n%s %s\n",
|
|
||||||
display.Underline(sheet.Title),
|
|
||||||
display.Faint(fmt.Sprintf("(%s)", sheet.CheatPath)),
|
|
||||||
)
|
|
||||||
|
|
||||||
// indent each line of content
|
|
||||||
out += display.Indent(sheet.Text) + "\n"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// trim the leading newline
|
||||||
|
out = strings.TrimPrefix(out, "\n")
|
||||||
|
|
||||||
// display the output
|
// display the output
|
||||||
// NB: resist the temptation to call `display.Display` multiple times in
|
// NB: resist the temptation to call `display.Display` multiple times in
|
||||||
// the loop above. That will not play nicely with the paginator.
|
// the loop above. That will not play nicely with the paginator.
|
||||||
|
|
Loading…
Reference in New Issue