3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-07-22 20:32:07 +00:00

hashlib, rtlil: Add operator+=() to dict<>::iterator and dict<>::const_iterator and add operator+() and operator+=() to ObjIterator.

This commit is contained in:
Alberto Gonzalez 2020-06-17 22:32:34 +00:00
parent d5d0cc88d2
commit e5a2d17b5d
No known key found for this signature in database
GPG key ID: 8395A8BA109708B2
2 changed files with 25 additions and 0 deletions

View file

@ -554,6 +554,29 @@ namespace RTLIL
return *this;
}
inline ObjIterator<T>& operator+=(int amt) {
log_assert(list_p != nullptr);
it += amt;
if (it == list_p->end()) {
(*refcount_p)--;
list_p = nullptr;
refcount_p = nullptr;
}
return *this;
}
inline ObjIterator<T> operator+(int amt) {
log_assert(list_p != nullptr);
ObjIterator<T> new_obj(*this);
new_obj.it += amt;
if (new_obj.it == list_p->end()) {
(*(new_obj.refcount_p))--;
new_obj.list_p = nullptr;
new_obj.refcount_p = nullptr;
}
return new_obj;
}
inline const ObjIterator<T> operator++(int) {
ObjIterator<T> result(*this);
++(*this);