maekawatoshiki opened PR #5978 from develop
to main
:
As discussed on https://github.com/bytecodealliance/wasmtime/issues/5804, this PR replaces
u8
elements inEntitySet
withusize
elements.I didn't add doc-tests. If I did so, I needed to add a piece of code like below to doc-tests for every method, which looks redundant to me. I think there's no need to remove the existing tests.
Let me know if something in my opinion is wrong.// `EntityRef` impl for testing. #[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord)] struct E(u32); impl EntityRef for E { fn new(i: usize) -> Self { E(i as u32) } fn index(self) -> usize { self.0 as usize } } let mut m = EntitySet::new(); ...
I realized that, in
wasmtime/cranelift/entity
,cargo test
fails on some tests below.running 52 tests ...omitted... failures: ---- tests::basic_entity::cannot_construct_from_reserved_u32 stdout ---- note: test did not panic as expected ---- tests::basic_entity::cannot_construct_from_reserved_usize stdout ---- note: test did not panic as expected ---- tests::other_entity::cannot_construct_from_reserved_u32 stdout ---- note: test did not panic as expected ---- tests::other_entity::cannot_construct_from_reserved_usize stdout ---- note: test did not panic as expected ---- tests::prefix_entity::cannot_construct_from_reserved_u32 stdout ---- note: test did not panic as expected ---- tests::prefix_entity::cannot_construct_from_reserved_usize stdout ---- note: test did not panic as expected failures: tests::basic_entity::cannot_construct_from_reserved_u32 tests::basic_entity::cannot_construct_from_reserved_usize tests::other_entity::cannot_construct_from_reserved_u32 tests::other_entity::cannot_construct_from_reserved_usize tests::prefix_entity::cannot_construct_from_reserved_u32 tests::prefix_entity::cannot_construct_from_reserved_usize test result: FAILED. 46 passed; 6 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Is this an expected behavior?
jameysharp submitted PR review.
jameysharp submitted PR review.
jameysharp created PR review comment:
While reviewing this patch I noticed that I'm not sure why the
cardinality
function was written the way it was. This is nothing wrong with your changes, but if you'd like to make another PR I think this function can be cleaned up.As far as I can tell,
self.len
is supposed to always track the position of the last 1 bit in the set. If that's working correctly, then the firstcount_ones
loop should work fine in all cases and we don't need a special case for the last element. The only trick is that instead of looping toself.len/BITS
, we need to round up to the next element boundary with(self.len + (BITS - 1)) / BITS
, like we've done elsewhere.I don't want to make that change in this PR because it's possible that
self.len
is not being managed correctly and I'd want to think about that separately.
jameysharp created PR review comment:
I see a couple of places where variables have
byte
in their names, which is confusing now that they aren't actually bytes. Could you search for the wordbyte
in this file and pick new names? In this case, I thinkbyte_ix
could beidx
instead.As future work, this loop could be replaced with something like
self.elems[..self.len / BITS].iter().map(|x| x.count_ones() as usize).sum()
. That should be faster by avoiding bounds checks. But I'd want that in a separate PR. I like that you've kept this PR simple, making only one change.
maekawatoshiki updated PR #5978 from develop
to main
.
maekawatoshiki requested jameysharp for a review on PR #5978.
jameysharp submitted PR review.
jameysharp merged PR #5978.
Last updated: Jan 24 2025 at 00:11 UTC