about summary refs log tree commit diff
path: root/compiler/rustc_index/src/bit_set/tests.rs
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2024-12-09 07:13:11 +0000
committerbors <bors@rust-lang.org>2024-12-09 07:13:11 +0000
commitf6cb952dc115fd1311b02b694933e31d8dc8b002 (patch)
tree80edf807196eafc8f1e9c6af6bf39be56c04103d /compiler/rustc_index/src/bit_set/tests.rs
parent1b3fb316751227d30b1523ed0e3f00d83956d4d0 (diff)
parentfa6ceba208fed892648679342fbf444d68385195 (diff)
downloadrust-f6cb952dc115fd1311b02b694933e31d8dc8b002.tar.gz
rust-f6cb952dc115fd1311b02b694933e31d8dc8b002.zip
Auto merge of #133891 - nnethercote:MixedBitSet, r=Mark-Simulacrum
Introduce `MixedBitSet`

`ChunkedBitSet` is good at avoiding excessive memory usage for programs with very large functgions where dataflow bitsets have very large domain sizes. But it's overly heavyweight for small bitsets, because any non-empty `ChunkedBitSet` takes up at least 256 bytes.

This PR introduces `MixedBitSet`, which is a simple bitset that uses `BitSet` for small/medium bitsets and `ChunkedBitSet` for large bitsets. It's a speed and memory usage win.

r? `@Mark-Simulacrum`
Diffstat (limited to 'compiler/rustc_index/src/bit_set/tests.rs')
-rw-r--r--compiler/rustc_index/src/bit_set/tests.rs6
1 files changed, 3 insertions, 3 deletions
diff --git a/compiler/rustc_index/src/bit_set/tests.rs b/compiler/rustc_index/src/bit_set/tests.rs
index 3f9198ce37f..f6142323979 100644
--- a/compiler/rustc_index/src/bit_set/tests.rs
+++ b/compiler/rustc_index/src/bit_set/tests.rs
@@ -503,15 +503,15 @@ fn sparse_matrix_operations() {
     matrix.insert(2, 99);
     matrix.insert(4, 0);
 
-    let mut disjoint: ChunkedBitSet<usize> = ChunkedBitSet::new_empty(100);
+    let mut disjoint: BitSet<usize> = BitSet::new_empty(100);
     disjoint.insert(33);
 
-    let mut superset = ChunkedBitSet::new_empty(100);
+    let mut superset = BitSet::new_empty(100);
     superset.insert(22);
     superset.insert(75);
     superset.insert(33);
 
-    let mut subset = ChunkedBitSet::new_empty(100);
+    let mut subset = BitSet::new_empty(100);
     subset.insert(22);
 
     // SparseBitMatrix::remove