mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 14:48:21 +00:00
Merge remote-tracking branch 'origin/topic/timw/dict-iterator-construction'
* origin/topic/timw/dict-iterator-construction: GH-1546: Make DictIterator() public, add copy/move operators
This commit is contained in:
commit
f66b4f5340
4 changed files with 94 additions and 4 deletions
3
CHANGES
3
CHANGES
|
@ -1,3 +1,6 @@
|
|||
4.1.0-dev.643 | 2021-05-17 11:57:58 -0700
|
||||
|
||||
* GH-1546: Make DictIterator() public, add copy/move operators (Tim Wojtulewicz, Corelight)
|
||||
|
||||
4.1.0-dev.641 | 2021-05-17 11:28:11 -0700
|
||||
|
||||
|
|
2
VERSION
2
VERSION
|
@ -1 +1 @@
|
|||
4.1.0-dev.641
|
||||
4.1.0-dev.643
|
||||
|
|
82
src/Dict.cc
82
src/Dict.cc
|
@ -265,6 +265,11 @@ TEST_CASE("dict new iteration")
|
|||
count++;
|
||||
}
|
||||
|
||||
PDict<uint32_t>::iterator it;
|
||||
it = dict.begin();
|
||||
it = dict.end();
|
||||
PDict<uint32_t>::iterator it2 = it;
|
||||
|
||||
CHECK(count == 2);
|
||||
|
||||
delete key;
|
||||
|
@ -1557,10 +1562,13 @@ DictIterator::DictIterator(const Dictionary* d, detail::DictEntry* begin, detail
|
|||
}
|
||||
|
||||
DictIterator::~DictIterator()
|
||||
{
|
||||
if ( dict )
|
||||
{
|
||||
assert(dict->num_iterators > 0);
|
||||
dict->num_iterators--;
|
||||
}
|
||||
}
|
||||
|
||||
DictIterator& DictIterator::operator++()
|
||||
{
|
||||
|
@ -1574,6 +1582,80 @@ DictIterator& DictIterator::operator++()
|
|||
return *this;
|
||||
}
|
||||
|
||||
DictIterator::DictIterator(const DictIterator& that)
|
||||
{
|
||||
if ( this == &that )
|
||||
return;
|
||||
|
||||
if ( dict )
|
||||
{
|
||||
assert(dict->num_iterators > 0);
|
||||
dict->num_iterators--;
|
||||
}
|
||||
|
||||
dict = that.dict;
|
||||
curr = that.curr;
|
||||
end = that.end;
|
||||
dict->num_iterators++;
|
||||
}
|
||||
|
||||
DictIterator& DictIterator::operator=(const DictIterator& that)
|
||||
{
|
||||
if ( this == &that )
|
||||
return *this;
|
||||
|
||||
if ( dict )
|
||||
{
|
||||
assert(dict->num_iterators > 0);
|
||||
dict->num_iterators--;
|
||||
}
|
||||
|
||||
dict = that.dict;
|
||||
curr = that.curr;
|
||||
end = that.end;
|
||||
dict->num_iterators++;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
DictIterator::DictIterator(DictIterator&& that)
|
||||
{
|
||||
if ( this == &that )
|
||||
return;
|
||||
|
||||
if ( dict )
|
||||
{
|
||||
assert(dict->num_iterators > 0);
|
||||
dict->num_iterators--;
|
||||
}
|
||||
|
||||
dict = that.dict;
|
||||
curr = that.curr;
|
||||
end = that.end;
|
||||
|
||||
that.dict = nullptr;
|
||||
}
|
||||
|
||||
DictIterator& DictIterator::operator=(DictIterator&& that)
|
||||
{
|
||||
if ( this == &that )
|
||||
return *this;
|
||||
|
||||
if ( dict )
|
||||
{
|
||||
assert(dict->num_iterators > 0);
|
||||
dict->num_iterators--;
|
||||
}
|
||||
|
||||
dict = that.dict;
|
||||
curr = that.curr;
|
||||
end = that.end;
|
||||
|
||||
that.dict = nullptr;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -159,8 +159,14 @@ public:
|
|||
using difference_type = std::ptrdiff_t;
|
||||
using iterator_category = std::forward_iterator_tag;
|
||||
|
||||
DictIterator() = default;
|
||||
~DictIterator();
|
||||
|
||||
DictIterator(const DictIterator& that);
|
||||
DictIterator& operator=(const DictIterator& that);
|
||||
DictIterator(DictIterator&& that);
|
||||
DictIterator& operator=(DictIterator&& that);
|
||||
|
||||
reference operator*() { return *curr; }
|
||||
pointer operator->() { return curr; }
|
||||
|
||||
|
@ -173,7 +179,6 @@ public:
|
|||
private:
|
||||
friend class Dictionary;
|
||||
|
||||
DictIterator() = default;
|
||||
DictIterator(const Dictionary* d, detail::DictEntry* begin, detail::DictEntry* end);
|
||||
|
||||
Dictionary* dict = nullptr;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue