[package]
edition = "2024"
rust-version = "1.85"
name = "polyval"
version = "0.7.0"
authors = ["RustCrypto Developers"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = """
POLYVAL is a GHASH-like universal hash over GF(2^128) useful for constructing
a Message Authentication Code (MAC)
"""
documentation = "https://docs.rs/polyval"
readme = "README.md"
keywords = [
"aes-gcm",
"aes-gcm-siv",
"crypto",
"ghash",
"universal-hashing",
]
categories = [
"cryptography",
"no-std",
]
license = "Apache-2.0 OR MIT"
repository = "https://github.com/RustCrypto/universal-hashes"
[package.metadata.docs.rs]
all-features = true
[features]
hazmat = []
[lib]
name = "polyval"
path = "src/lib.rs"
[[test]]
name = "long_input"
path = "tests/long_input.rs"
[[test]]
name = "proptests"
path = "tests/proptests.rs"
[[bench]]
name = "polyval"
path = "benches/polyval.rs"
[dependencies.cpubits]
version = "0.1"
[dependencies.universal-hash]
version = "0.6"
[dependencies.zeroize]
version = "1"
optional = true
default-features = false
[dev-dependencies.hex-literal]
version = "1"
[target.'cfg(any(target_arch = "aarch64", target_arch = "x86", target_arch = "x86_64"))'.dependencies.cpufeatures]
version = "0.3"
[target."cfg(any(unix, windows))".dev-dependencies.proptest]
version = "1.9"
[lints.clippy]
borrow_as_ptr = "warn"
cast_lossless = "warn"
cast_possible_truncation = "warn"
cast_possible_wrap = "warn"
cast_precision_loss = "warn"
cast_sign_loss = "warn"
checked_conversions = "warn"
from_iter_instead_of_collect = "warn"
implicit_saturating_sub = "warn"
manual_assert = "warn"
map_unwrap_or = "warn"
missing_errors_doc = "warn"
missing_panics_doc = "warn"
mod_module_files = "warn"
must_use_candidate = "warn"
needless_range_loop = "allow"
ptr_as_ptr = "warn"
redundant_closure_for_method_calls = "warn"
ref_as_ptr = "warn"
return_self_not_must_use = "warn"
semicolon_if_nothing_returned = "warn"
std_instead_of_alloc = "warn"
std_instead_of_core = "warn"
suspicious_arithmetic_impl = "allow"
trivially_copy_pass_by_ref = "warn"
undocumented_unsafe_blocks = "warn"
unnecessary_safety_comment = "warn"
unwrap_in_result = "warn"
unwrap_used = "warn"
[lints.rust]
missing_copy_implementations = "warn"
missing_debug_implementations = "warn"
missing_docs = "warn"
trivial_casts = "warn"
trivial_numeric_casts = "warn"
unreachable_pub = "warn"
unused_lifetimes = "warn"
unused_qualifications = "warn"
[lints.rust.unexpected_cfgs]
level = "warn"
priority = 0
check-cfg = [
'cfg(cpubits, values("16", "32", "64"))',
'cfg(polyval_backend, values("soft"))',
]