Skip to content

Commit

Permalink
Merge pull request #129 from benasher44/basher/improve-argument-help
Browse files Browse the repository at this point in the history
Improve Argument help message
  • Loading branch information
mdiep authored May 29, 2018
2 parents a3119f4 + 7583609 commit 169a1fe
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 4 deletions.
26 changes: 24 additions & 2 deletions Sources/Commandant/Argument.swift
Original file line number Diff line number Diff line change
Expand Up @@ -20,17 +20,39 @@ public struct Argument<T> {
/// be shown in help messages.
public let usage: String

public init(defaultValue: T? = nil, usage: String) {
/// A human-readable string that describes this argument as a paramater shown
/// in the list of possible parameters in help messages (e.g. for "paths", the
/// user would see <paths…>).
public let usageParameter: String?

public init(defaultValue: T? = nil, usage: String, usageParameter: String? = nil) {
self.defaultValue = defaultValue
self.usage = usage
self.usageParameter = usageParameter
}

fileprivate func invalidUsageError<ClientError>(_ value: String) -> CommandantError<ClientError> {
let description = "Invalid value for '\(self)': \(value)"
let description = "Invalid value for '\(self.usageParameterDescription)': \(value)"
return .usageError(description: description)
}
}

extension Argument {
/// A string describing this argument as a parameter in help messages. This falls back
/// to `"\(self)"` if `usageParameter` is `nil`
internal var usageParameterDescription: String {
return self.usageParameter.map { "<\($0)>" } ?? "\(self)"
}
}

extension Argument where T: Sequence {
/// A string describing this argument as a parameter in help messages. This falls back
/// to `"\(self)"` if `usageParameter` is `nil`
internal var usageParameterDescription: String {
return self.usageParameter.map { "<\($0)…>" } ?? "\(self)"
}
}

// MARK: - Operators

extension CommandMode {
Expand Down
8 changes: 6 additions & 2 deletions Sources/Commandant/Errors.swift
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,9 @@ internal func informativeUsageError<T: ArgumentProtocol, ClientError>(_ argument
var example = ""

var valueExample = ""
if let defaultValue = argument.defaultValue {
if argument.usageParameter != nil {
valueExample = argument.usageParameterDescription
} else if let defaultValue = argument.defaultValue {
valueExample = "\(defaultValue)"
}

Expand All @@ -106,7 +108,9 @@ internal func informativeUsageError<T: ArgumentProtocol, ClientError>(_ argument
var example = ""

var valueExample = ""
if let defaultValue = argument.defaultValue {
if argument.usageParameter != nil {
valueExample = argument.usageParameterDescription
} else if let defaultValue = argument.defaultValue {
valueExample = "\(defaultValue)"
}

Expand Down

0 comments on commit 169a1fe

Please sign in to comment.