mas/Carthage/Checkouts/Commandant
2019-12-13 17:47:44 -07:00
..
Carthage/Checkouts 🔥 Remove obsolete Result sources 2019-12-13 17:47:44 -07:00
Commandant.xcodeproj Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Commandant.xcworkspace Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Sources/Commandant Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Tests Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
.gitignore Bootstrap initial Carthage dependency sources 2018-09-05 09:54:08 +10:00
.gitmodules Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
.hound.yml Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
.swift-version Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
.swiftlint.yml Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
.travis.yml Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Cartfile.private ⬆️ Commandant (0.15.0+) 2019-12-13 16:44:43 -07:00
Cartfile.resolved Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Commandant.podspec Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
CONTRIBUTING.md Bootstrap initial Carthage dependency sources 2018-09-05 09:54:08 +10:00
LICENSE.md Bootstrap initial Carthage dependency sources 2018-09-05 09:54:08 +10:00
Package.resolved Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
Package.swift Result, ⬆️ Quick (2.2.0), Nimble (8.0.4), Commandant (0.17.0) 2019-12-13 17:36:15 -07:00
README.md ⬆️ Commandant (0.15.0+) 2019-12-13 16:44:43 -07:00

Commandant

Commandant is a Swift framework for parsing command-line arguments, inspired by Argo (which is, in turn, inspired by the Haskell library Aeson).

Reviewed by Hound

Example

With Commandant, a command and its associated options could be defined as follows:

struct LogCommand: CommandProtocol {
	typealias Options = LogOptions

	let verb = "log"
	let function = "Reads the log"

	func run(_ options: Options) -> Result<(), YourErrorType> {
		// Use the parsed options to do something interesting here.
		return ()
	}
}

struct LogOptions: OptionsProtocol {
	let lines: Int
	let verbose: Bool
	let logName: String

	static func create(_ lines: Int) -> (Bool) -> (String) -> LogOptions {
		return { verbose in { logName in LogOptions(lines: lines, verbose: verbose, logName: logName) } }
	}

	static func evaluate(_ m: CommandMode) -> Result<LogOptions, CommandantError<YourErrorType>> {
		return create
			<*> m <| Option(key: "lines", defaultValue: 0, usage: "the number of lines to read from the logs")
			<*> m <| Option(key: "verbose", defaultValue: false, usage: "show verbose output")
			<*> m <| Argument(usage: "the log to read")
	}
}

Then, each available command should be added to a registry:

let commands = CommandRegistry<YourErrorType>()
commands.register(LogCommand())
commands.register(VersionCommand())

After which, arguments can be parsed by simply invoking the registry:

var arguments = CommandLine.arguments

// Remove the executable name.
assert(!arguments.isEmpty)
arguments.remove(at: 0)

if let verb = arguments.first {
	// Remove the command name.
	arguments.remove(at: 0)

	if let result = commands.run(command: verb, arguments: arguments) {
		// Handle success or failure.
	} else {
		// Unrecognized command.
	}
} else {
	// No command given.
}

For real-world examples, see the implementation of the Carthage command-line tool.

License

Commandant is released under the MIT license.