fixedbitset
---
A simple fixed size bitset container for Rust.
Please read the [API documentation here](https://docs.rs/fixedbitset/)
[![build\_status](https://github.com/petgraph/fixedbitset/workflows/Continuous%20integration/badge.svg?branch=master)](https://github.com/petgraph/fixedbitset/actions)
[![crates](https://img.shields.io/crates/v/fixedbitset.svg)](https://crates.io/crates/fixedbitset)
# Recent Changes
- 0.5.7
- [#127](https://github.com/petgraph/fixedbitset/pull/127) and [#128](https://github.com/petgraph/fixedbitset/pull/128): Optimize `Clone::clone_from` to avoid
extra allocations and copies.
- 0.5.6
- Fixed FixedBitset not implementing Send/Sync due to the stack size shrink.
- 0.5.5 (yanked)
- [#116](https://github.com/petgraph/fixedbitset/pull/116): Add functions for counting the results of a set operation (`union_count`,
`intersection_count`, `difference_count`, `symmetric_difference_count`) by @james7132.
- [#118](https://github.com/petgraph/fixedbitset/pull/118): Shrink the stack size of FixedBitset. There should be zero stack size overhead
compared to a Vec.
- [#119](https://github.com/petgraph/fixedbitset/pull/119): Fix builds for wasm32.
- [#120](https://github.com/petgraph/fixedbitset/pull/119): Add more utility functions that were previously missing from the public interface:
`contains_any_in_range`, `contains_all_in_range`, `minimum`, `maximum`, `is_full`, `count_zeroes`, and `remove_range`.
- [#121](https://github.com/petgraph/fixedbitset/pull/121): Add support for SIMD acceleration for AVX builds.
- 0.5.4
- [#112](https://github.com/petgraph/fixedbitset/pull/112): Fix undefined behavior in IntoOnes and setup testing with MIRI by @SkiFire13
- 0.5.3 (yanked)
- [#109](https://github.com/petgraph/fixedbitset/pull/109): Fix non-x86(_64) builds by @james7132
- 0.5.2 (yanked)
- [#86](https://github.com/petgraph/fixedbitset/pull/86): Explicit SIMD vectorization for set operations by @james7132.
- 0.5.1
- [#102](https://github.com/petgraph/fixedbitset/pull/102): Added `contains_unchecked`, `insert_unchecked`, `put_unchecked`,
`set_unchecked`, `toggle_unchecked`, `removed_unchecked`, `copy_bit_unchecked` unsafe variants of the safe functions, by @james7132
- [#103](https://github.com/petgraph/fixedbitset/pull/103): Added `into_ones` which returns a owned iterator over the one
values from a bitset, by @james7132.
- [#104](https://github.com/petgraph/fixedbitset/pull/104): Implemented `DoubleEndedIterator` for `Union`, `Intersection`,
`Difference`, and `SymmetricDifference` , by @james7132.
- 0.5.0
- [#74](https://github.com/petgraph/fixedbitset/pull/74): Accelerated set operations (union, intersection, difference,
symmetric difference) by using larger blocks internally, by @james7132.
- [#88](https://github.com/petgraph/fixedbitset/pull/88): Added `FixedBitSet::remove` by @james7132.
- [#89](https://github.com/petgraph/fixedbitset/pull/89): Added `FixedBitSet::zeros` and the `Zeros` iterator by @james7132.
- [#92](https://github.com/petgraph/fixedbitset/pull/92): Added `FixedBitSet::grow_and_insert` function, a
non-panicking version of `insert` that grows the underlying storage as need, by @shuoli84.
- [#98](https://github.com/petgraph/fixedbitset/pull/98): `Ones` now implements `DoubleEndedIterator`, by @tikhu.
- [#99](https://github.com/petgraph/fixedbitset/pull/99): **Breaking change**: serde now serializes and deserializes from a little-endian encoded
raw byte buffer. Existing stored instances of the serialized bitsets will need to be
re-encoded.
- Bumped MSRV to 1.56.
- 0.4.2
- [#79](https://github.com/petgraph/fixedbitset/pull/79): Add `is_clear`,
clarify `is_empty` and `len` documentation by \@nicopap.
- 0.4.1
- Documentation and formatting fixes.
- 0.4.0
- [#61](https://github.com/petgraph/fixedbitset/pull/61): Require
Rust 1.39.
- [#60](https://github.com/petgraph/fixedbitset/pull/60): Add
`const` `FixedBitSet::new` consructor
by \@jakobhellermann.
- [#59](https://github.com/petgraph/fixedbitset/pull/59): Add
optional `serde` support by \@keshavsn.
- 0.3.2
- [#18](https://github.com/petgraph/fixedbitset/pull/18): Optimize
`ones` using `trailing_zeroes` by \@vks
- 0.3.1
- Add bit assign operators for references by \@flaghacker
- Improve assertion error messages by \@lovasoa
- Add documentation examples for `with_capacity_and_blocks`
- 0.3.0
- Add `with_capacity_and_blocks` by \@luizirber
- Add `difference_with` by \@sunshowers
- Implement `Binary` and `Display` traits by \@Dolphindalt
- Add `toggle_range` by \@wirelyre
- 0.2.0
- Add assign operators for the bit operations by \@jrraymond
- Add `symmetric_difference`, `union_with`, `intersection_with` by
\@jrraymond
- Add `is_subset`, `is_superset`, `is_disjoint` by \@nwn
- Add `.toggle(i)` method by \@ShiroUsagi-san
- Add default feature \"std\" which can be disabled to make the
crate not link the std library. By \@jonimake and \@bluss
- Require Rust 1.31.
- 0.1.9
- Add intersection, union, difference iterators by \@jrraymond
- Add intersection: `&` and union: `|` operator implementations by
\@jrraymond
- Add Extend and FromIterator implementations (from sequences of
bit indices) by \@jrraymond
- 0.1.8
- Add missing `#[inline]` on the ones iterator
- Fix docs for `insert_range, set_range`
- 0.1.7
- Add fast methods `.insert_range`, `.set_range` by \@kennytm
- 0.1.6
- Add iterator `.ones()` by \@mneumann
- Fix bug with `.count_ones()` where it would erronously have an
out-of-bounds panic for even block endpoints
- 0.1.5
- Add method `.count_ones(range)`.
- 0.1.4
- Remove an assertion in `.copy_bit(from, to)` so that it is in
line with the documentation. The `from` bit does not need to be
in bounds.
- Improve `.grow()` to use `Vec::resize` internally.
- 0.1.3
- Add method `.put()` to enable a bit and return previous value
- 0.1.2
- Add method `.copy_bit()` (by fuine)
- impl Default
- 0.1.1
- Update documentation URL
- 0.1.0
- Add method `.grow()`
# License
Dual-licensed to be compatible with the Rust project.
Licensed under the [Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0)
or the [MIT license](https://opensource.org/licenses/MIT),
at your option. This file may not be copied, modified, or distributed except
according to those terms.