combu

crates.io version license

combu is a customizable (or rather bare bones...?) cli framework. The library name "combu" comes from command + 昆布(konbu, it means kelp in japanese).

combu has no dependencies(or depends on only std library). Crate.io's page is here.

combu(com + 昆布)は柔軟に CLI を組み上げられることを目標とした、カスタマイズ可能(というより骨組みを組み上げてあるだけのような気もする)な CLI フレームワークです。 (一時クレートの名前が cmb だったこともありましたが、現在は combu です)

Features (特徴)

Documentation

Here

Installation to your project (プロジェクトでの使用方法)

Combu exists on crates.io. You can use(or import) this crate like other crate that exists on crates.io.

combu は crates.io に登録してありますので、他の crates.io 上のクレートと同じように使用(インポート)することが可能です。

Edit cargo.toml manually (手動での cargo.toml への追加)

Add

toml combu="[version you want to use]"

to cargo.toml.

上記コードでバージョンを指定して、cargo.toml に追加してください。

Use cargo-edit (Recommended) (cargo-edit でプロジェクトに追加する(推奨))

If you installed cargo-edit, exec below command under the target project:

bash cargo add combu

cargo-edit をインストールしてある場合は、上記のコマンドを実行することで使用可能です。

Quick Start

```rust use combu::command::presets::func::helptablizewithaliasdedup; use combu::{actionresult, checkerror, checkhelp, done, presetroot, Command}; use combu::{Context, Flag}; use std::env;

fn main() { let r = presetroot!(act) .usage(env!("CARGOPKGNAME").tostring() + " [args]") .commonflag( Flag::newbool("help") .shortalias('h') .description("show help"), ) .localflag( Flag::newbool("local") .shortalias('l') .description("local flag"), ) .runfrom_args(env::args().collect()); }

fn act(cmd: Command, c: Context) -> actionresult!() { checkerror!(cmd, c); checkhelp!(cmd, c, helptablizewithalias_dedup); println!("Hello, combu - {:?}", c.args);

done!()

} ```

If you want to run quick start as example, exec

bash cargo run --example quick_start cargo run --example quick_start --help

More detail: See quick_start.rs

Example

Single (command has flags, but not has subcommand)

Multi (Have Sub command)

Inspired

TODO(or Features to be implemented)

CONTRIBUTING

If you want to contribute combu, please read CONTRIBUTING.md for checking our code of conduct, and submitting pull requests to us.

Author(s?)

suquiya.

README Contribute: ksk001100 contributed on this pull request.

License

This is licensed under MIT LICENSE

Information about construct for this README.md

This readme is mainly based on seahorse's readme - Copyright (c) 2019 Keisuke Toyota - licensed MIT License.