cargo_edit/
lib.rs

1//! Show and Edit Cargo's Manifest Files
2//!
3//! # Semver Compatibility
4//!
5//! cargo-edit's versioning tracks compatibility for the binaries, not the API.  We upload to
6//! crates.io to distribute the binary.  If using this as a library, be sure to pin the version
7//! with a `=` version requirement operator.  Note though that our goal is for `cargo-edit` to go
8//! away as we move things into cargo.
9#![recursion_limit = "256"]
10#![cfg_attr(test, allow(dead_code))]
11#![warn(
12    missing_copy_implementations,
13    trivial_casts,
14    trivial_numeric_casts,
15    unsafe_code,
16    unstable_features,
17    unused_import_braces,
18    unused_qualifications
19)]
20
21#[macro_use]
22extern crate serde_derive;
23
24mod crate_spec;
25mod dependency;
26mod errors;
27mod fetch;
28mod index;
29mod manifest;
30mod metadata;
31mod registry;
32mod util;
33mod version;
34
35pub use crate_spec::CrateSpec;
36pub use dependency::Dependency;
37pub use dependency::PathSource;
38pub use dependency::RegistrySource;
39pub use dependency::Source;
40pub use errors::*;
41pub use fetch::{RustVersion, find_compatible_version, find_latest_version};
42pub use index::*;
43pub use manifest::{LocalManifest, Manifest, find, get_dep_version, set_dep_version};
44pub use metadata::manifest_from_pkgid;
45pub use registry::registry_url;
46pub use util::{
47    Color, ColorChoice, colorize_stderr, shell_note, shell_print, shell_status, shell_warn,
48    shell_write_stderr, shell_write_stdout,
49};
50pub use version::{VersionExt, upgrade_requirement};