本文整理汇总了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
}
}