v/vlib/cli
Cameron Katri 340543dfc0
cli: add automatic manpage generation with -man (#13911)
2022-04-03 10:12:47 +03:00
..
README.md docs: add more documentation to each of the modules in vlib (#13043) 2022-01-07 13:28:50 +02:00
command.v cli: add automatic manpage generation with -man (#13911) 2022-04-03 10:12:47 +03:00
command_test.v
flag.v
flag_test.v cli: improve multiple value management (#8310) 2021-03-19 13:09:56 +02:00
help.v cli: make help fn's public (#13275) 2022-01-25 15:58:06 +02:00
help_test.v
man.v cli: add automatic manpage generation with -man (#13911) 2022-04-03 10:12:47 +03:00
man_test.v cli: add automatic manpage generation with -man (#13911) 2022-04-03 10:12:47 +03:00
version.v

README.md

Description:

cli is a command line option parser, that supports declarative subcommands, each having separate set of options.

See also the flag module, for a simpler command line option parser, that supports only options.

Example:

module main

import os
import cli

fn main() {
	mut app := cli.Command{
		name: 'example-app'
		description: 'example-app'
		execute: fn (cmd cli.Command) ? {
			println('hello app')
			return
		}
		commands: [
			cli.Command{
				name: 'sub'
				execute: fn (cmd cli.Command) ? {
					println('hello subcommand')
					return
				}
			},
		]
	}
	app.setup()
	app.parse(os.args)
}