LArSoft
v09_90_00
Liquid Argon Software toolkit - https://larsoft.org/
|
Forward iterator browsing all geometry elements in the detector. More...
#include "geometry_iterators.h"
Public Types | |
using | id_iterator_t = GEOIDITER |
using | iterator = geometry_element_iterator< Element, id_iterator_t > |
this type More... | |
Types mirrored from the ID iterator | |
using | LocalID_t = typename id_iterator_t::LocalID_t |
using | GeoID_t = typename id_iterator_t::GeoID_t |
using | ElementPtr_t = Element const * |
Iterator traits | |
using | difference_type = std::ptrdiff_t |
using | value_type = Element |
using | reference = value_type const & |
using | pointer = value_type const * |
using | iterator_category = std::forward_iterator_tag |
Public Member Functions | |
geometry_element_iterator ()=default | |
Default constructor; effect not defined: assign to it before using! More... | |
geometry_element_iterator (GeometryCore const *geo, id_iterator_t const &iter) | |
Constructor: points to the same element as the specified ID iterator. More... | |
geometry_element_iterator (GeometryCore const *geo, id_iterator_t &&iter) | |
Constructor: points to the same element as the specified ID iterator. More... | |
geometry_element_iterator (GeometryCore const *geo, GeoID_t const &start_from) | |
Constructor: points to the specified geometry element. More... | |
bool | operator== (iterator const &as) const |
Returns true if the two iterators point to the same object. More... | |
bool | operator!= (iterator const &as) const |
Returns true if the two iterators point to different objects. More... | |
reference | operator* () const |
Returns the geometry element the iterator points to. More... | |
pointer | operator-> () const |
Returns a pointer to the element the iterator points to (or nullptr) More... | |
iterator & | operator++ () |
Prefix increment: returns this iterator pointing to the next element. More... | |
iterator | operator++ (int) |
Postfix increment: returns the current iterator, then increments it. More... | |
operator bool () const | |
Returns whether the iterator is pointing to a valid geometry element. More... | |
ElementPtr_t | get () const |
Returns a pointer to the geometry element, or nullptr if invalid. More... | |
LocalID_t const & | ID () const |
Returns the ID of the pointed geometry element. More... | |
Private Attributes | |
geo::GeometryCore const * | geom |
id_iterator_t | id_iterator |
Forward iterator browsing all geometry elements in the detector.
GEOITER | type of geometry ID iterator |
This iterator works as the corresponding ID iterator in the template argument. The difference is the dereferenciation operator: this one obtains the geometry element directly, or throws on failure. The boolean conversion operator checks that it can obtain a pointer to the geometry element.
In particular, get() and ID() methods still return the pointer to the geometry element and its ID, respectively.
It can also be initialized and compare with the corresponding ID iterator.
Definition at line 283 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::difference_type = std::ptrdiff_t |
Definition at line 302 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::ElementPtr_t = Element const* |
Definition at line 297 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::GeoID_t = typename id_iterator_t::GeoID_t |
Definition at line 296 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::id_iterator_t = GEOIDITER |
Definition at line 285 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::iterator = geometry_element_iterator<Element, id_iterator_t> |
this type
Definition at line 291 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::iterator_category = std::forward_iterator_tag |
Definition at line 306 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::LocalID_t = typename id_iterator_t::LocalID_t |
Definition at line 295 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::pointer = value_type const* |
Definition at line 305 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::reference = value_type const& |
Definition at line 304 of file geometry_iterators.h.
using geo::details::geometry_element_iterator< Element, GEOIDITER >::value_type = Element |
Definition at line 303 of file geometry_iterators.h.
|
default |
Default constructor; effect not defined: assign to it before using!
|
inline |
Constructor: points to the same element as the specified ID iterator.
Definition at line 313 of file geometry_iterators.h.
|
inline |
Constructor: points to the same element as the specified ID iterator.
Definition at line 318 of file geometry_iterators.h.
|
inline |
Constructor: points to the specified geometry element.
Definition at line 323 of file geometry_iterators.h.
|
inline |
Returns a pointer to the geometry element, or nullptr if invalid.
Definition at line 369 of file geometry_iterators.h.
References geo::details::getElementPtr().
|
inline |
Returns the ID of the pointed geometry element.
Definition at line 372 of file geometry_iterators.h.
|
inline |
Returns whether the iterator is pointing to a valid geometry element.
Definition at line 366 of file geometry_iterators.h.
References geo::details::validElement().
|
inline |
Returns true if the two iterators point to different objects.
Definition at line 331 of file geometry_iterators.h.
References geo::details::geometry_element_iterator< Element, GEOIDITER >::id_iterator.
|
inline |
Returns the geometry element the iterator points to.
cet::exception | (category "geometry_iterator") if no valid geometry element is currently pointed by the iterator |
Definition at line 339 of file geometry_iterators.h.
|
inline |
Prefix increment: returns this iterator pointing to the next element.
Definition at line 351 of file geometry_iterators.h.
|
inline |
Postfix increment: returns the current iterator, then increments it.
Definition at line 358 of file geometry_iterators.h.
|
inline |
Returns a pointer to the element the iterator points to (or nullptr)
Definition at line 348 of file geometry_iterators.h.
|
inline |
Returns true if the two iterators point to the same object.
Definition at line 328 of file geometry_iterators.h.
References geo::details::geometry_element_iterator< Element, GEOIDITER >::id_iterator.
|
private |
Definition at line 375 of file geometry_iterators.h.
|
private |
Definition at line 376 of file geometry_iterators.h.
Referenced by geo::details::geometry_element_iterator< Element, GEOIDITER >::operator!=(), and geo::details::geometry_element_iterator< Element, GEOIDITER >::operator==().