1.0.14 (current)
From google/supply-chain copy of chromium. By Liza Burakova.
These reviews are from cargo-vet. To add your review, set up cargo-vet
and submit your URL to its registry.
1.0.14 (current)
From google/supply-chain copy of chromium. By Liza Burakova.
1.0.14 — diff review from 1.0.11 only (current)
From bytecodealliance/wasmtime. Audited without comment by Dan Gohman.
The current version of itoa is 1.0.14.
1.0.11 (older version)
From google/supply-chain copy of chromium. By Lukasz Anforowicz.
Straightforward diff between 1.0.10 and 1.0.11 - only 3 commits:
unsafe
blocks more granular:
https://github.com/dtolnay/itoa/pull/421.0.11 (older version)
From kornelski/crev-proofs copy of git.savannah.gnu.org.
Packaged for Guix (crates-io)
1.0.10 — diff review from 1.0.9 only (older version)
From zcash/rust-ecosystem copy of zcash/zcash. Audited without comment by str4d.
1.0.9 — diff review from 1.0.6 only (older version)
From google/supply-chain copy of chromium. Audited without comment by George Burgess IV.
1.0.9 (older version)
From kornelski/crev-proofs copy of salsa.debian.org.
Only in debcargo (unstable). Changelog:
1.0.5 (older version)
From google/supply-chain copy of chromium. Audited without comment by ChromeOS.
1.0.5 — diff review from 1.0.3 only (older version)
From mozilla/supply-chain copy of hg. Audited without comment by Mike Hommey.
1.0.3 — diff review from 1.0.1 only (older version)
From zcash/rust-ecosystem copy of zcash/zcash. By Jack Grigg.
Update makes no changes to code.
0.4.7 (older version)
From google/supply-chain copy of chromium. Audited without comment by Android Legacy.
cargo-vet does not verify reviewers' identity. You have to fully trust the source the audits are from.
This crate can be compiled, run, and tested on a local workstation or in controlled automation without surprising consequences. More…
Inspection reveals that the crate in question does not attempt to implement any cryptographic algorithms on its own.
Note that certification of this does not require an expert on all forms of cryptography: it's expected for crates we import to be "good enough" citizens, so they'll at least be forthcoming if they try to implement something cryptographic. When in doubt, please ask an expert.
All crypto algorithms in this crate have been reviewed by a relevant expert.
Note: If a crate does not implement crypto, use does-not-implement-crypto
,
which implies crypto-safe
, but does not require expert review in order to
audit for.
This crate will not introduce a serious security vulnerability to production software exposed to untrusted input. More…
Negligible unsoundness or average soundness.
Full description of the audit criteria can be found at https://github.com/google/rust-crate-audits/blob/main/auditing_standards.md#ub-risk-2
Mild unsoundness or suboptimal soundness.
Full description of the audit criteria can be found at https://github.com/google/rust-crate-audits/blob/main/auditing_standards.md#ub-risk-3
Extreme unsoundness.
Full description of the audit criteria can be found at https://github.com/google/rust-crate-audits/blob/main/auditing_standards.md#ub-risk-4
May have been packaged automatically without a review
These reviews are from Crev, a distributed system for code reviews. To add your review, set up cargo-crev
.
The current version of itoa is 1.0.14.
1.0.10 (older version) Thoroughness: High Understanding: High
by weiznich on 2024-02-29
Review update from 1.0.9 to 1.0.10
0.4.8 (older version) Thoroughness: Low Understanding: Medium
by leo60228 on 2021-09-28
only minor changes
0.4.4 (older version) Thoroughness: Low Understanding: Low
by MaulingMonkey on 2019-07-26
I believe this is sound, but has way too much unsafe and too few tests for my tastes. udivmod_1e19 reduces my thoroughness and understanding to low, otherwise both would be medium or higher.
Reviewed: benches/bench.rs +1
src/lib.rs 0
119 mem::uninitialized (POD)
164 impl_IntegerCommon is potentially unsound, but not public, and guarded by debug_assert!s at least.
Would vastly prefer static_assertions though.
196 one giant unsafe block for pointer math? No bounds checks? Super gross!
Relies on $max_len being enough for $t with no bounds checking.
Relies on d1/d2/n being unable to overflow DEC_DIGITS_LUT.
A careful reading makes this appear technically sound, but super super sketchy.
246 Carefully audited for impl_Integer.
255 Carefully audited for impl_Integer.
267 Carefully audited for impl_Integer.
270 Carefully audited for impl_Integer.
273 Carefully audited for impl_Integer.
294 Again? A careful reading makes this appear technically sound, but super super sketchy.
338 Carefully audited for impl_Integer128.
339 Shouldn't this technically have the cfg if U128_MAX_LEN is going to have it?
341 Carefully audited for impl_Integer128.
tests/test.rs +1
Not nearly enough tests for my liking given how much unsafe code there is.
I'd like to see every edge case of iota::write tested, they aren't.
I'd like to see every edge case of udivmod_1e19 tested, it's not directly tested at all.
.gitignore +1
.travis.yml +1
Cargo.toml +1
Cargo.toml.orig +1
README.md +1
Not yet fully reviewed:
src/udiv128.rs 0
34 Correct - since high is nonzero (line 29 bails if it wasn't), leading_zeros < 64.
35+ My eyes glazed over at this point. I haven't verified udivmod_1e19(...).1 meets it's invariants!
TIL:
You can use \
``edition2018on doc comment code blocks. You can have a public trait require a private one to "seal" it. You can specify
sudo: false` in .travis.yml
Lib.rs has been able to verify that all files in the crate's tarball, except Cargo.lock
,
are in the crate's repository with a git tag matching the version. Please note that this check is still in beta, and absence of this confirmation does not mean that the files don't match.
Crates in the crates.io registry are tarball snapshots uploaded by crates' publishers. The registry is not using crates' git repositories, so there is a possibility that published crates have a misleading repository URL, or contain different code from the code in the repository.
To review the actual code of the crate, it's best to use cargo crev open itoa
. Alternatively, you can download the tarball of itoa v1.0.14 or view the source online.
Unsafe review at https://crrev.com/c/6051067