Kommando is a library that helps you build small and large command line interfaces in crystal.
Add this to your application's shard.yml
:
dependencies:
kommando:
github: ragmaanir/kommando
- positional arguments (like in
crystal init app MyApp
) - short and long options (like
cli new MyProject --dry -v --permissions=644 --repo=github -l=MIT
) - validation and type conversion of arguments
- auto-generated documentation
- namespaces/subcommands like
cli create user Toby
Why classes for commands and not methods
Classes can define helper methods that are scoped to the command. And the helper methods have access to all options of the command.
record(User, name : String, age : Int32, height : Int32?, nickname : String?)
USERS = [] of User
class Create
include Kommando::Command
option(:height, Int32, "", validate: ->(v : Int32) { (100..250).includes?(v) })
option(:nickname, String, "", format: /\A[a-zA-Z]+\z/)
option(:dead, Bool, "Whether the person is dead", default: false)
arg(:name, String)
arg(:age, Int32)
def call
USERS << User.new(name, age, @height, @nickname)
end
end
test "create user with options" do
user = User.new("Christian", 55, 175, "Chris")
Create.call([
"-height=#{user.height}",
"-nickname=#{user.nickname}",
user.name, user.age.to_s,
])
assert USERS == [user]
end
require "kommando"
class Create
include Kommando::Command
def call
end
end
class Migrate
include Kommando::Command
def call
end
end
test do
root = Kommando::Namespace.root do
commands Create
namespace("db") do
commands Create, Migrate
end
end
assert root.commands.keys == ["create"]
assert root.namespaces.keys == ["db"]
root.run(["db", "create"])
end
- Fork it (https://github.com/ragmaanir/kommando/fork)
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
- ragmaanir ragmaanir - creator, maintainer