mirror of
https://github.com/rsteube/carapace-bin.git
synced 2025-05-14 11:44:32 +00:00
70 lines
3.4 KiB
Go
70 lines
3.4 KiB
Go
package cmd
|
|
|
|
import (
|
|
"github.com/rsteube/carapace"
|
|
"github.com/rsteube/carapace-bin/pkg/actions/tools/git"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
var checkoutCmd = &cobra.Command{
|
|
Use: "checkout",
|
|
Short: "Switch branches or restore working tree files",
|
|
Run: func(cmd *cobra.Command, args []string) {},
|
|
GroupID: groups[group_main].ID,
|
|
}
|
|
|
|
func init() {
|
|
carapace.Gen(checkoutCmd).Standalone()
|
|
|
|
checkoutCmd.Flags().StringS("B", "B", "", "create/reset and checkout a branch")
|
|
checkoutCmd.Flags().StringS("b", "b", "", "create and checkout a new branch")
|
|
checkoutCmd.Flags().String("conflict", "", "conflict style (merge or diff3)")
|
|
checkoutCmd.Flags().BoolP("detach", "d", false, "detach HEAD at named commit")
|
|
checkoutCmd.Flags().BoolP("force", "f", false, "force checkout (throw away local modifications)")
|
|
checkoutCmd.Flags().Bool("guess", false, "second guess 'git checkout <no-such-branch>' (default)")
|
|
checkoutCmd.Flags().Bool("ignore-other-worktrees", false, "do not check if another worktree is holding the given ref")
|
|
checkoutCmd.Flags().Bool("ignore-skip-worktree-bits", false, "do not limit pathspecs to sparse entries only")
|
|
checkoutCmd.Flags().BoolS("l", "l", false, "create reflog for new branch")
|
|
checkoutCmd.Flags().BoolP("merge", "m", false, "perform a 3-way merge with the new branch")
|
|
checkoutCmd.Flags().String("orphan", "", "new unparented branch")
|
|
checkoutCmd.Flags().BoolP("ours", "2", false, "checkout our version for unmerged files")
|
|
checkoutCmd.Flags().Bool("overlay", false, "use overlay mode (default)")
|
|
checkoutCmd.Flags().Bool("overwrite-ignore", false, "update ignored files (default)")
|
|
checkoutCmd.Flags().BoolP("patch", "p", false, "select hunks interactively")
|
|
checkoutCmd.Flags().Bool("pathspec-file-nul", false, "pathspec elements are separated with NUL character")
|
|
checkoutCmd.Flags().String("pathspec-from-file", "", "read pathspec from file")
|
|
checkoutCmd.Flags().Bool("progress", false, "force progress reporting")
|
|
checkoutCmd.Flags().BoolP("quiet", "q", false, "suppress progress reporting")
|
|
checkoutCmd.Flags().String("recurse-submodules", "", "control recursive updating of submodules")
|
|
checkoutCmd.Flags().BoolP("theirs", "3", false, "checkout their version for unmerged files")
|
|
checkoutCmd.Flags().BoolP("track", "t", false, "set upstream info for new branch")
|
|
rootCmd.AddCommand(checkoutCmd)
|
|
|
|
carapace.Gen(checkoutCmd).FlagCompletion(carapace.ActionMap{
|
|
"B": git.ActionRefs(git.RefOption{LocalBranches: true}),
|
|
"b": git.ActionRefs(git.RefOption{LocalBranches: true}),
|
|
"conflict": carapace.ActionValues("merge", "diff3"),
|
|
"orphan": git.ActionRefs(git.RefOption{LocalBranches: true, RemoteBranches: true}),
|
|
"pathspec-from-file": carapace.ActionFiles(),
|
|
})
|
|
|
|
carapace.Gen(checkoutCmd).PositionalCompletion(
|
|
git.ActionRefs(git.RefOption{}.Default()),
|
|
)
|
|
|
|
carapace.Gen(checkoutCmd).PositionalAnyCompletion(
|
|
carapace.ActionCallback(func(c carapace.Context) carapace.Action {
|
|
return git.ActionRefChanges(c.Args[0]).Invoke(c).Filter(c.Args[1:]...).ToA()
|
|
}),
|
|
)
|
|
|
|
carapace.Gen(checkoutCmd).DashAnyCompletion(
|
|
carapace.ActionCallback(func(c carapace.Context) carapace.Action {
|
|
if args := checkoutCmd.Flags().Args(); len(args[:checkoutCmd.ArgsLenAtDash()]) > 0 {
|
|
return git.ActionRefChanges(args[0]).Invoke(c).Filter(args[1:]...).ToA()
|
|
}
|
|
return git.ActionChanges(git.ChangeOpts{}.Default()).FilterArgs()
|
|
}),
|
|
)
|
|
}
|