cargo-hakari

cargo-hakari on crates.io Documentation (latest release) Documentation (main) License License

cargo hakari is a command-line application to manage workspace-hack crates.

For an explanation of what workspace-hack packages are and how they can help, see the about module.

Platform support

Installation and usage

All of the below commands take options that control their behavior.

To install, run:

sh cargo install cargo-hakari

To update, run:

sh cargo install --force cargo-hakari

If $HOME/.cargo/bin is in your PATH, the cargo hakari command will be available.

Usage

Initialize a workspace-hack crate for a workspace at path my-workspace-hack:

sh cargo hakari init my-workspace-hack

Generate or update the contents of a workspace-hack crate.

sh cargo hakari generate

Add the workspace-hack crate as a dependency to all other workspace crates:

sh cargo hakari manage-deps

Publish a crate that currently depends on the workspace-hack crate (cargo publish can't be used in this circumstance):

sh cargo hakari publish -p <crate>

Disabling and uninstalling

Disable the workspace-hack crate temporarily by removing generated contents. (Re-enable by running cargo hakari generate).

sh cargo hakari disable

Remove the workspace-hack crate as a dependency from all other workspace crates:

sh cargo hakari remove-deps

Configuration

cargo hakari is configured through .guppy/hakari.toml at the root of the workspace.

Example configuration:

```toml

The name of the package used for workspace-hack unification.

hakari-package = "workspace-hack"

Cargo resolver version in use -- version 2 is highly recommended.

resolver = "2"

Add triples corresponding to platforms commonly used by developers here.

https://doc.rust-lang.org/rustc/platform-support.html

platforms = [ ## "x8664-unknown-linux-gnu", ## "x8664-apple-darwin", ## "x86_64-pc-windows-msvc", ]

Options to control Hakari output.

[output]

Write out exact versions rather than specifications. Set this to true if version numbers in

Cargo.toml and Cargo.lock files are kept in sync, e.g. in some configurations of

https://dependabot.com/.

exact-versions = false

```

For more options, see the config module.

Contributing

See the CONTRIBUTING file for how to help out.

License

This project is available under the terms of either the Apache 2.0 license or the MIT license.