You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
It appears that head and feet nodes has a data member which is not initialized in the case where tree is templated on primitives. In some cases those data seems to interfere with search algorithms based on value comparison (lower_bound, upper_bound) when they take 'head' level sibling_iterator (the algorithm then randomly returns what looks like a default iterators instead of an iterator at the end position). it can be fixed by manually initializing those data with proper values.
step to reproduce:
#include<algorithm>
#include"tree.hh"intmain(int argc, char* argv[]) {
typedef tree<char> Tree;
Tree tree;
// replace min by max to avoid the segfault
tree.head->data = std::numeric_limits<char>::min();
tree.feet->data = std::numeric_limits<char>::min();
Tree::sibling_iterator it = tree.begin();
it = tree.insert(it, 0);
for (char c = 0; ++c; c < std::numeric_limits<char>::max()) {
std::cout << "inserting char: " << (int) c << std::endl;
it = std::lower_bound(it, it.end(), std::numeric_limits<char>::max());
// here depending of what is c and what are head->data and feet->data the returned iterator// may be a default one instead of an iterator at it.end().
it = tree.insert(it, c);
}
return EXIT_SUCCESS;
}
Inspection of the iterator returned by std::lower_bound before the segfault:
It appears that
head
andfeet
nodes has adata
member which is not initialized in the case where tree is templated on primitives. In some cases those data seems to interfere with search algorithms based on value comparison (lower_bound, upper_bound) when they take 'head' levelsibling_iterator
(the algorithm then randomly returns what looks like a default iterators instead of an iterator at the end position). it can be fixed by manually initializing those data with proper values.step to reproduce:
Inspection of the iterator returned by
std::lower_bound
before the segfault:The text was updated successfully, but these errors were encountered: