12 releases
0.2.4 | Jul 20, 2024 |
---|---|
0.2.2 | Jun 29, 2023 |
0.2.1 | Apr 28, 2023 |
0.1.8 | Jan 11, 2023 |
0.0.3 | May 12, 2022 |
#71 in Cargo plugins
39KB
580 lines
cargo-crate
Intro
cargo-crate
is an additional cargo command for your crate(s).
Features
In a nutshell cargo-crate
allows:
-
fetching information about one or several crates, including the owners
-
opening crate(s) in crates.io
-
opening crates' documentation directly
-
opening crates' repository directly
-
opening crates' homepage directly
-
search for crates passing a pattern
You may pass either the name of your crate such as cargo-crate
but you may also provide the path of a package or even a workspace.
You may for instance find the following commands rather useful:
cargo crate open .
cargo crate open . --doc
cargo crate open . --repo
(if you like that, checkoutchevdor/gho
)cargo crate info .
For all the command above, if you work on a workspace, all its crates will be handled.
Similar projects
cargo-crate
basically does the same (I’d argue better) than the following (combined):
cargo-show
cargo-info
cargo-open
cargo-search
Install
cargo instal cargo-crate
Aliases
You will typically use cargo-crate as cargo crate <command> [args]
which you may find a bit verbose.
To make it easier, cargo
allows defining aliases in you $CARGO_HOME/config
file under the [alias]
section.
You may for instance add:
[alias]
...
open = "crate open"
info = "crate info"
show = "crate info"
repo = "crate open --repo"
home = "crate open --home"
docu = "crate open --doc"
Those will allow you the following calls:
-
cargo repo clap
opens the clap documentation -
cargo home clap
opens the clap homepage -
etc…
Usage
cargo-crate
can be started using both cargo crate
or cargo-crate
.
Help
You can find all available commands below
Usage: cargo-crate [OPTIONS] <COMMAND>
Commands:
info The `info` command returns summarized information
open Opens the crate in a browser
search Search crates.io and return a list of crates matching your search pattern
help Print this message or the help of the given subcommand(s)
Options:
-j, --json Output as json
-h, --help Print help
-V, --version Print version
Info command
The `info` command returns summarized information
Usage: cargo-crate info [OPTIONS] [CRATE_NAMES]...
Arguments:
[CRATE_NAMES]... One or more crate, passed as name or path
Options:
-j, --json Output as json
-m, --max-versions <MAX_VERSIONS> Limit the number of versions that are displayed. You can push the limit using this flag [default: 10]
-h, --help Print help
-V, --version Print version
Open command
Opens the crate in a browser
Usage: cargo-crate open [OPTIONS] [CRATE_NAMES]...
Arguments:
[CRATE_NAMES]... The name(s) of the crate to open in your browser
Options:
-j, --json Output as json
--repository Open crates.io by default, use this flag to open the repo instead
--homepage Open crates.io by default, use this flag to open the homepage instead
--documentation Open crates.io by default, use this flag to open the documentation instead
-h, --help Print help
-V, --version Print version
Search command
Search crates.io and return a list of crates matching your search pattern
Usage: cargo-crate search [OPTIONS] <PATTERN>
Arguments:
<PATTERN> You search pattern
Options:
-j, --json Output as json
-l, --limit <LIMIT> Number of expected results: 0..100 [default: 12]
-r, --raw Show only the list of crates, without extra information
-h, --help Print help
-V, --version Print version
Advanced Usage
cargo-crate
can be used with fzf
for powerful interactive searches.
function crate_search() {
PATTERN=${@};
if [ $PATTERN ]; then
cargo-crate search --raw -l 100 $PATTERN | fzf -m -i --preview 'cargo-crate info {}' --query "$PATTERN"
else
echo You must provide a starting search pattern
exit 1
fi
}
allows doing cool things like this.
Dependencies
~17–30MB
~408K SLoC