proxmox/proxmox-router/Cargo.toml

37 lines
1.1 KiB
TOML
Raw Normal View History

[package]
name = "proxmox-router"
version = "1.3.0"
authors.workspace = true
edition.workspace = true
license.workspace = true
repository.workspace = true
description = "proxmox API Router and CLI utilities"
exclude.workspace = true
[dependencies]
anyhow.workspace = true
env_logger = { version = "0.9", optional = true }
http = { workspace = true, optional = true }
hyper = { workspace = true, features = [ "full" ], optional = true }
nix.workspace = true
percent-encoding.workspace = true
serde_json.workspace = true
serde.workspace = true
unicode-width ="0.1.8"
# cli:
tokio = { workspace = true, features = [], optional = true }
rustyline = { version = "9", optional = true }
libc = { workspace = true, optional = true }
proxmox-lang = { path = "../proxmox-lang", version = "1.1" }
proxmox-schema = { path = "../proxmox-schema", version = "1.1" }
proxmox-async = { path = "../proxmox-async", version = "0.4.1" }
[features]
default = [ "cli", "server" ]
build: use weak and namespaced features to reduce the creep of optional dependencies being exposed as features. this requires cargo 0.63 (and debcargo built against at least that version), but greatly reduces the number of binary packages and provides generated, while still allowing sensible selection of optional dependencies via the explicit feature meant for pulling them in. diff stat for running `make deb` after this change: proxmox-http/debian/control | 226 ++++-------------------------------- proxmox-router/debian/control | 74 +----------- proxmox-schema/debian/control | 53 ++------- proxmox-subscription/debian/control | 17 +-- proxmox-sys/debian/control | 51 +++----- proxmox-tfa/debian/control | 110 ++---------------- 6 files changed, 72 insertions(+), 459 deletions(-) the 'dep:' prefix marks something on the RHS inside the features section as dependency, it's only allowed if the string after it is an optional dependency an no explicit feature of the same name exists. if all pointers to the optional dependency in the features section are marked as such, the optional dependency itself will not be exposed as a feature (either on the cargo or debian/control level). the '?' suffix marks dependencies as "weak", which only enables the optional dependency + its feature(s) if the optional dependency itself is also enabled. it has no effect on d/control since such a relationship is not encodable in Debian package relations, but it does affect cargo dependency resolution and allows skipping the build of unneeded optional dependencies in some cases. with no packages/crates depending on the no longer exposed automatically generated features/packages, so these are safe to remove even though it's technically a breaking change. Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
2022-08-22 11:24:04 +02:00
cli = [ "dep:env_logger", "dep:libc", "dep:rustyline", "dep:tokio" ]
server = [ "dep:http", "dep:hyper" ]
test-harness = [ "proxmox-schema/test-harness" ]