Go to file
Eyal Posener 98eb9847f2
Merge pull request from posener/fix-59
install: create file directory before file is created
2018-03-09 08:24:32 +02:00
cmd install: create file directory before file is created 2018-03-09 08:18:31 +02:00
example/self Fix example/self 2017-05-23 07:33:38 +03:00
gocomplete Merge branch 'master' into split-last-equal 2017-11-04 11:52:49 +02:00
match Fix './' prefix for file completion 2017-05-18 23:29:55 +03:00
tests fix nested files 2017-05-13 00:40:26 +03:00
.gitignore Add go test script and travis file 2017-05-06 00:38:16 +03:00
.travis.yml travis: add go1.9, remove tip 2017-11-04 10:57:04 +02:00
LICENSE.txt change license to MIT 2017-05-20 23:22:26 +03:00
args.go Add logic to complete when last flag uses the equal sign 2017-11-04 11:32:33 +02:00
args_test.go Add logic to complete when last flag uses the equal sign 2017-11-04 11:32:33 +02:00
command.go Filter matches as a final stage 2017-11-04 10:51:40 +02:00
common_test.go remove testing flags from complete command 2017-05-13 11:07:03 +03:00
complete.go Merge branch 'master' into split-last-equal 2017-11-04 11:52:49 +02:00
complete_test.go Merge branch 'master' into split-last-equal 2017-11-04 11:52:49 +02:00
log.go Roughly add all go commands 2017-05-06 00:25:27 +03:00
metalinter.json travis: add gometalinter tests 2017-05-19 00:33:49 +03:00
predict.go predict: split file 2017-05-11 22:02:05 +03:00
predict_files.go predict files: remove loop 2017-05-20 08:13:13 +03:00
predict_set.go Filter matches as a final stage 2017-11-04 10:51:40 +02:00
predict_test.go Merge branch 'master' into split-last-equal 2017-11-04 11:52:49 +02:00
readme.md update readme 2018-01-19 10:59:08 +02:00
test.sh [travis] test multiple packages 2017-05-08 06:30:01 +03:00
utils.go Fix './' prefix for file completion 2017-05-18 23:29:55 +03:00

readme.md

complete

A tool for bash writing bash completion in go, and bash completion for the go command line.

Build Status codecov GoDoc Go Report Card

Writing bash completion scripts is a hard work. This package provides an easy way to create bash completion scripts for any command, and also an easy way to install/uninstall the completion of the command.

go command bash completion

In gocomplete there is an example for bash completion for the go command line.

This is an example that uses the complete package on the go command - the complete package can also be used to implement any completions, see Usage.

Install

  1. Type in your shell:
go get -u github.com/posener/complete/gocomplete
gocomplete -install
  1. Restart your shell

Uninstall by gocomplete -uninstall

Features

  • Complete go command, including sub commands and all flags.
  • Complete packages names or .go files when necessary.
  • Complete test names after -run flag.

complete package

Supported shells:

  • bash
  • zsh
  • fish

Usage

Assuming you have program called run and you want to have bash completion for it, meaning, if you type run then space, then press the Tab key, the shell will suggest relevant complete options.

In that case, we will create a program called runcomplete, a go program, with a func main() and so, that will make the completion of the run program. Once the runcomplete will be in a binary form, we could runcomplete -install and that will add to our shell all the bash completion options for run.

So here it is:

import "github.com/posener/complete"

func main() {

	// create a Command object, that represents the command we want
	// to complete.
	run := complete.Command{

		// Sub defines a list of sub commands of the program,
		// this is recursive, since every command is of type command also.
		Sub: complete.Commands{

			// add a build sub command
			"build": complete.Command {

				// define flags of the build sub command
				Flags: complete.Flags{
					// build sub command has a flag '-cpus', which
					// expects number of cpus after it. in that case
					// anything could complete this flag.
					"-cpus": complete.PredictAnything,
				},
			},
		},

		// define flags of the 'run' main command
		Flags: complete.Flags{
			// a flag -o, which expects a file ending with .out after
			// it, the tab completion will auto complete for files matching
			// the given pattern.
			"-o": complete.PredictFiles("*.out"),
		},

		// define global flags of the 'run' main command
		// those will show up also when a sub command was entered in the
		// command line
		GlobalFlags: complete.Flags{

			// a flag '-h' which does not expects anything after it
			"-h": complete.PredictNothing,
		},
	}

	// run the command completion, as part of the main() function.
	// this triggers the autocompletion when needed.
	// name must be exactly as the binary that we want to complete.
	complete.New("run", run).Run()
}

Self completing program

In case that the program that we want to complete is written in go we can make it self completing.

Here is an example