bitcoin_hashes 0.14.0

Hash functions used by the rust-bitcoin eccosystem
Documentation
# 0.14.0 - 2024-03-21

* Bump MSRV to Rust version 1.56.1 [#2188]https://github.com/rust-bitcoin/rust-bitcoin/pull/2188

## API improvemnts

* Add support for SHA384 [#2538]https://github.com/rust-bitcoin/rust-bitcoin/pull/2538
* Make from_hex inherent for byte-like types [#2491]https://github.com/rust-bitcoin/rust-bitcoin/pull/2491
* Add `Hash::from_bytes_iter` to construct hashes from iterators [#2272]https://github.com/rust-bitcoin/rust-bitcoin/pull/2272
* Make some constructors `const` [#2446]https://github.com/rust-bitcoin/rust-bitcoin/pull/2446

## Features/dependencies changes

* Removed `core2` dependency in favour of the new `bitcoin-io` crate [#2066]https://github.com/rust-bitcoin/rust-bitcoin/pull/2066
* Remove "serde-std" [#2384]https://github.com/rust-bitcoin/rust-bitcoin/pull/2384

## Error handling improvements

* Improve leaf errors [#2530]https://github.com/rust-bitcoin/rust-bitcoin/pull/2530
* Implement `From<Infallible>` for errors [#2516]https://github.com/rust-bitcoin/rust-bitcoin/pull/2516

# 0.13.0 - 2023-06-29

The main improvement in this version is removal of the `hex` module in favour of the new
[`hex-conservative`](https://crates.io/crates/hex-conservative) crate (which we wrote). We also
bumped the Minimum Supported Rust Version across the `rust-bitcoin` ecosystem to v1.48

* Bump MSRV to 1.48.0 [#1729]https://github.com/rust-bitcoin/rust-bitcoin/pull/1729.
* Depend on new `hex-conservative` crate and remove `hex` module [#1883]https://github.com/rust-bitcoin/rust-bitcoin/pull/1833.
* Make `sha256t_hash_newtype!` evocative of the output [#1773]https://github.com/rust-bitcoin/rust-bitcoin/pull/1773.
* Implement computing SHA256 in const context [#1769]https://github.com/rust-bitcoin/rust-bitcoin/pull/1769.
* Add `from_bytes_ref` and `from_bytes_mut` to all hash types [#1761]https://github.com/rust-bitcoin/rust-bitcoin/pull/1761.
* Rename `crate::Error` to `crate::FromSliceError` [#1873]https://github.com/rust-bitcoin/rust-bitcoin/pull/1873.
* Add simd sha256 intrinsics for x86 machines [#1962]https://github.com/rust-bitcoin/rust-bitcoin/pull/1962.
* Introduce the "small-hash" feature for `bitcoin_hashes` [#1990]https://github.com/rust-bitcoin/rust-bitcoin/pull/1990.

# 0.12.0 - 2023-03-05

0.12 is a significant release. We pulled the repository into the rust-bitcoin
repo to improve our integration testing and to get more eyes on this crate. We
began the process of replacing the hex functionality in this crate with a more
performant, dedicated crate, and otherwise cleaning up the API as we look forward
to 1.0.

* [Remove `FromHex` implementation]https://github.com/rust-bitcoin/rust-bitcoin/pull/1565/commits/a308e1e2ea5c6ae419d961b8da71cc8a35a92715
from all hashes and implement `FromStr` instead.
* Move crate from [original repo]https://github.com/rust-bitcoin/bitcoin_hashes to the
`rust-bitcoin` repository. Commit history was lost during move, for commit history see the original
repository. Tip of bitcoin_hashes:master at time of import: 54c16249e06cc6b7870c7fc07d90f489d82647c7
* [Remove `Deref` impls for all hashes]https://github.com/rust-bitcoin/rust-bitcoin/pull/1450
* [Add `AsRef` impls for all hashes from fixed-size arrays]https://github.com/rust-bitcoin/rust-bitcoin/pull/1593
* [Add the `sha512_256` hash]https://github.com/rust-bitcoin/rust-bitcoin/pull/1413
* [Remove the `ToHex` trait in favor of `DisplayHex` and `fmt::Display`]https://github.com/rust-bitcoin/rust-bitcoin/pull/1531
* [Remove the now-unused `HexWriter` object]https://github.com/rust-bitcoin/rust-bitcoin/pull/1572
* [nostd: `alloc` feature no longer enables `core2`]https://github.com/rust-bitcoin/rust-bitcoin/pull/1612
* [Rewrite `hash_newtype` macro with new syntax]https://github.com/rust-bitcoin/rust-bitcoin/pull/1659
* [Rename `Hash::Inner` to `Hash::Bytes`, 'Hash::*_inner` and several related conversion methods](https://github.com/rust-bitcoin/rust-bitcoin/pull/1577)


# 0.11.0 - 2022-06-25

The major change in this version is the increase of the Minimum Supported Rust Version (MSRV) from
1.29 to 1.41.1. This is a big change because it introduces Rust Edition 2018 to the codebase along
with all the benefits that brings. We also did a bunch of optimisations to speed up encoding and
decoding hex strings.

## Breaking changes

* [Enable edition 2018 and bump MSRV to Rust 1.41.1]https://github.com/rust-bitcoin/bitcoin_hashes/pull/136

## New features/APIs

* [Add `all_zeros` to `Hash` trait]https://github.com/rust-bitcoin/bitcoin_hashes/pull/148
* [Implement `Write` on `HmacEngine`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/133
* [Introduce `HexWriter`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/156, makes serialising hex faster
* [Implement `Read` on `HexIterator`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/135, makes deserialising hex faster

## Other improvements

* Use `rotate_left` [instead of custom macro]https://github.com/rust-bitcoin/bitcoin_hashes/pull/162
* [Enable clippy on CI]https://github.com/rust-bitcoin/bitcoin_hashes/pull/152
* Various docs fixes
* [Improve feature test coverage]https://github.com/rust-bitcoin/bitcoin_hashes/pull/147
* [Add a disabled `rustfmt.toml`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/141 to improve interaction with auto-formatting in editors


# 0.10.0 - 2021-07-05

* Increase `core2` to released version of 0.3.0

# 0.9.7 - 2021-06-17

* Introduce `alloc` feature and `core2` dependency for nostd support (this feature has MSRV of 1.36 rather than 1.29)

# 0.9.6 - 2021-05-03

* Re-export `core` as `_export::_core`. This resolves an issue when calling several exported macros with the `std` feature.

# 0.9.5 - 2021-04-28

* Add [`#[repr(transparent)]` to all newtype wrappers]https://github.com/rust-bitcoin/bitcoin_hashes/pull/108/
* Add [missing `#derive`s]https://github.com/rust-bitcoin/bitcoin_hashes/pull/110/
* Replace `fuzztarget` feature with [use of `cfg(fuzzing)`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/111/
* Use [`core` rather than `std`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/118/ and [fix `no_std` compilation]https://github.com/rust-bitcoin/bitcoin_hashes/pull/122/

Note that we have stopped re-exporting the `core` crate when compiling without `std`. This is technically a breaking change but it is hard to imagine what user might be affected.

# 0.9.4 - 2020-10-23

* Add `Hmac::from_inner_engines`

# 0.9.3 - 2020-10-19

* More serde macro fixes

# 0.9.2 - 2020-10-18

* Fix rustc 1.29.0 downstream issues with serde macros

# 0.9.2 - 2020-10-16

* Fix visibility issue with serde macros

# 0.9.1 - 2020-10-07

* Add `FromStr` impl to `sha256t::Hash`
* Fix `Hash::engine()` implementation for hash newtypes
* Add `sha256t_hash_newtype!` macro for creating tagged hashes

# 0.9.0 - 2020-08-27

* **Update MSRV to 1.29.0**

# 0.8.0 - 2020-08-26

* Add `as_inner` method to `Hash` trait
* Add `n_bytes_hashed` to `HashEngine` trait

# 0.7.6 - 2020-04-05

* Support hash newtypes with reversed hex serialization.

# 0.7.5 - 2020-04-02

* Add `sha256t` module for SHA-256-based tagged hashes.
* Add `FromStr` for hash newtypes.
* Add `from_hash` for hash newtypes.

# 0.7.3 - 2019-12-18

* Add `as_hash(&self) -> <inner>` method to hash newtypes.

# 0.7.2 - 2019-11-29

* Make the inner variable of `sha256::Midstat` public
* Drop the `byteorder` dependency in favor of manual endianness implementations
(later this will be in stdlib so we can drop even that)
* Fix the `hash_newtype` macro, which did not compile before

# 0.7.1 - 2019-08-14

* Add hash_newtype macro that allows third parties to create newtype structs.

# 0.7.0 - 2019-07-19

* Add `hex::Error` type for errors generated by the `hex` module.

# 0.6.0 - 2019-07-10

* Add `no_std` support, rearrange traits to not depend on `io::Write`

# 0.5.0 - 2019-06-28

* Fix panic when parsing hashes that contain multibyte characters
* Add `FromStr` to all hashes which hex-parses them

# 0.4.0 - 2019-06-23

* [Add `from_inner` method]https://github.com/rust-bitcoin/bitcoin_hashes/pull/20 to all hashes
* [Update `FromHex` trait]https://github.com/rust-bitcoin/bitcoin_hashes/pull/40 to require `from_byte_iter` method rather than `from_hex` be implemented
* Make `Hmac` midstate [an actual HMAC midstate]https://github.com/rust-bitcoin/bitcoin_hashes/pull/43
* Allow `Display` [of truncated hashes]https://github.com/rust-bitcoin/bitcoin_hashes/pull/9
* Require [using a constructor for `HexIterator`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/44 and then [clean up the internals]https://github.com/rust-bitcoin/bitcoin_hashes/pull/47
* [Strongly type `sha256::Midstate`]https://github.com/rust-bitcoin/bitcoin_hashes/pull/39 to allow independent serialization
* Add [siphash24 module]https://github.com/rust-bitcoin/bitcoin_hashes/pull/46

# 0.3.2 - 2019-03-20

* Implement the `FromHex` trait on [many more types]https://github.com/rust-bitcoin/bitcoin_hashes/pull/38

# 0.3.1 - 2019-03-04

* [Fix serde serialization]https://github.com/rust-bitcoin/bitcoin_hashes/pull/36

# 0.3.0 - 2019-01-23

* Bump minimum required rustc version to 1.22.0
* Fixed serde deserialization into owned string that previously caused panics
  when doing round-trip (de)serialization
* `HashEngine::block_size()` and `Hash::len()` are now associated constants
  `HashEngine::BLOCK_SIZE` and `Hash::LEN`
* Removed `block_size()` method from `Hash` trait. It is still available as
  `<T as Hash>::Engine::BLOCK_SIZE`

# 0.2.0 - 2019-01-15

* Add a constant-time comparison function
* Simplify `io::Write::write` implementations by having them do only partial writes
* Add fuzzing support
* Allow `Hash`es to be borrowed as `[u8]`
* Replace public `Hash` inners with `into_inner` method

# 0.1.0 - 2018-12-08

* Initial release