Without this fix, DenseSet crashes with an assertion if constructed with an
initializer_list whose length is not a power of two.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
unittests/ADT/DenseSetTest.cpp | ||
---|---|---|
83–87 | "Don't crash" tests always look a bit suspect to me (like "test that this does anything other than crash" is not a particularly strong constraint). Maybe test that it contains the desired contents after such construction, and/or that the capacity or buckets or whatever is the expected power of two? |
include/llvm/ADT/DenseSet.h | ||
---|---|---|
71 | Shouldn’t this be PowerOf2Ceil? NextPowerOf2 will change a number that is already a power of 2. |
include/llvm/ADT/DenseSet.h | ||
---|---|---|
71 | Yes it should. Thanks! | |
unittests/ADT/DenseSetTest.cpp | ||
83–87 | I only use a "don't crash" test if the other aspects are tested elsewhere. In this case they're covered by the test above, which just happened to have a power-of-two length initializer (or we would have noticed this bug earlier). I do not suppose there's any harm in doing a sanity check on the content in the non power-of-two case though. I'll add one. |
Use PowerOf2Ceil as per Craig's suggestion, and validate set contents in the non power-of-two length initializer list unit test as per Dave's suggestion.
Looks good to me (I guess the capacity thing there could be tested too - ensuring that it didn't roll up to a larger capacity than intended?)
Committed as r344542.
Unfortunately DenseSet / DenseMap do not expose a capacity function at the moment. I believe it's just getNumBuckets, so unless there is some reason not to I would be in favor of adding a public 'capacity' function that returns that. Then we could add that check to the unit test.
Capacity is the number of elements that can be held without additional allocation, right? So that would be closer to getNumBuckets()/4*3.
Shouldn’t this be PowerOf2Ceil? NextPowerOf2 will change a number that is already a power of 2.