Командний Рядок - Під Команди|Command-Line Subcommands
#
// Деякі з утиліт командного рядку, як то `go` чи `git`,
// мають великий вибір додаткових команд, а також власний набір
// прапорців/параметрів. Наприклад `go build` і `go get`
// являються додатковими командами для `go`-утиліти.
// Для роботи з прапорцями/параметрами в
// стандартній бібліотеці `go` є пакет `flag`, який дозволяє
// з легкістю визначати команди а також їх параметри.
package main
import (
"flag"
"fmt"
"os"
)
func main() {
// Тут, за допомогою функції `NewFlagSet`, визначається нова команда.
fooCmd := flag.NewFlagSet("foo", flag.ExitOnError)
// Далі оголошуються два додаткові параметри `enable` і `name`
// з типами ціле и стрічка відповідно.
fooEnable := fooCmd.Bool("enable", false, "enable")
fooName := fooCmd.String("name", "", "name")
// Для різних команд можна задати різні параметри,
// які вони підтримують.
barCmd := flag.NewFlagSet("bar", flag.ExitOnError)
barLevel := barCmd.Int("level", 0, "level")
// Очікується, що параметри будуть передані як перший аргумент при старті програми.
if len(os.Args) < 2 {
fmt.Println("expected 'foo' or 'bar' subcommands")
os.Exit(1)
}
// Перевірити, яка команда була передана.
switch os.Args[1] {
// Якщо була передана команда `foo`, виконати парсинг параметрів,
// а також вивести всі параметри які не були задіяні при парсингу вхідної стрічки.
case "foo":
fooCmd.Parse(os.Args[2:])
fmt.Println("subcommand 'foo'")
fmt.Println(" enable:", *fooEnable)
fmt.Println(" name:", *fooName)
fmt.Println(" tail:", fooCmd.Args())
// Якщо була передана команда `bar`, виконати парсинг параметрів,
// а також вивести всі параметри які не були задіяні при парсингу вхідної стрічки.
case "bar":
barCmd.Parse(os.Args[2:])
fmt.Println("subcommand 'bar'")
fmt.Println(" level:", *barLevel)
fmt.Println(" tail:", barCmd.Args())
// Якщо команда, що була передана - являється забороненою,
// вивести помилку і закінчити виконання.
default:
fmt.Println("expected 'foo' or 'bar' subcommands")
os.Exit(1)
}
}
$ go build command-line-subcommands.go
# Для початку викликати команду foo.
$ ./command-line-subcommands foo -enable -name=joe a1 a2
subcommand 'foo'
enable: true
name: joe
tail: [a1 a2]
# Тепер викликати команду bar.
$ ./command-line-subcommands bar -level 8 a1
subcommand 'bar'
level: 8
tail: [a1]
# Переконатись, що bar не приймає параметри визначенні в
# foo.
$ ./command-line-subcommands bar -enable a1
flag provided but not defined: -enable
Usage of bar:
-level int
level
# Далі будуть розглянуті змінні середовища,
# ще один поширений спосіб для заданя необхідних
# параметрів.