本文整理匯總了Golang中github.com/gsamokovarov/jump/cli.Args類的典型用法代碼示例。如果您正苦於以下問題:Golang Args類的具體用法?Golang Args怎麽用?Golang Args使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Args類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: updateCmd
func updateCmd(args cli.Args, conf *config.Config) {
dir, err := os.Getwd()
if len(args) == 0 && err != nil {
cli.Exitf(1, "err: %s\n", err)
} else {
if dir, err = filepath.Abs(args.CommandName()); err != nil {
cli.Exitf(1, "err: %s\n", err)
}
}
entries, err := conf.ReadEntries()
if err != nil {
cli.Exitf(1, "err: %s\n", err)
}
if entry, found := entries.Find(dir); found {
entry.UpdateScore()
} else {
entries = append(entries, *scoring.NewEntry(dir))
}
if err := conf.WriteEntries(entries); err != nil {
cli.Exitf(1, "err: %s\n", err)
}
}
示例2: hintCmd
func hintCmd(args cli.Args, conf *config.Config) {
var hints scoring.Entries
term := args.CommandName()
smart := args.Has("--smart")
entries, err := conf.ReadEntries()
if err != nil {
cli.Exitf(1, "%s\n", err)
}
if len(term) == 0 {
// We usually keep them reversely sort to optimize the fuzzy search.
sort.Sort(sort.Reverse(entries))
hints = hintSmartSelect(entries, term, smart)
} else {
fuzzyEntries := scoring.NewFuzzyEntries(entries, term)
hints = hintSmartSelect(&fuzzyEntries.Entries, term, smart)
}
for _, entry := range hints {
cli.Outf("%s\n", entry.Path)
}
}
示例3: shellCmd
func shellCmd(args cli.Args, _ *config.Config) {
hint := args.CommandName()
if len(hint) == 0 {
hint = os.Getenv("SHELL")
}
sh := shell.Guess(hint)
cli.Outf("%s", sh)
}
示例4: cdCmd
func cdCmd(args cli.Args, conf *config.Config) {
term := args.CommandName()
entries, err := conf.ReadEntries()
if err != nil {
cli.Exitf(1, "%s\n", err)
}
// If an auto-completion triggered a full path, just go there.
if filepath.IsAbs(term) {
cli.Outf("%s\n", term)
return
}
index, search := 0, conf.ReadSearch()
// If we happen to match the last term, e.g. j is called with no
// arguments then jump to the previous search.
if len(term) == 0 {
term, index = search.Term, search.Index+1
}
fuzzyEntries := scoring.NewFuzzyEntries(entries, term)
for {
if entry, empty := fuzzyEntries.Select(index); !empty {
// Remove the entries that no longer exists.
if _, err := os.Stat(entry.Path); os.IsNotExist(err) {
entries.Remove(entry.Path)
conf.WriteEntries(entries)
index++
continue
}
// Jump to the next entry, if the jump is going to land on the
// current directory.
if cwd, err := os.Getwd(); err == nil && entry.Path == cwd {
index++
continue
}
cli.Outf("%s\n", entry.Path)
conf.WriteSearch(term, index)
}
break
}
}