1#ifndef included_AMP_libmeshNodeIterator
2#define included_AMP_libmeshNodeIterator
4#include "AMP/mesh/MeshIterator.h"
5#include "AMP/mesh/libmesh/libmeshMesh.h"
6#include "AMP/mesh/libmesh/libmeshMeshElement.h"
9#include "libmesh/libmesh_config.h"
10#undef LIBMESH_ENABLE_REFERENCE_COUNTING
11#include "libmesh/elem.h"
33 std::string
className()
const override {
return "libmeshNodeIterator"; }
57 std::unique_ptr<MeshIteratorBase>
clone()
const override;
59 using MeshIteratorBase::operator==;
60 using MeshIteratorBase::operator!=;
76 const libMesh::Mesh::node_iterator &
begin,
77 const libMesh::Mesh::node_iterator &
end );
88 const libMesh::Mesh::node_iterator &
begin,
89 const libMesh::Mesh::node_iterator &
end,
90 const libMesh::Mesh::node_iterator &
pos,
Class to manage reading/writing restart data.
A base class used to iterate over elements in a Mesh.
size_t pos() const
Return the current position (from the beginning) in the iterator.
size_t size() const
Return the number of elements in the iterator.
MeshIteratorEnd end() const
Return an iterator to the end (use tombstone class)
A class used to iterate over elements in a Mesh.
A derived class used to define a mesh element.
A concrete mesh class for libMesh.
void writeRestart(int64_t fid) const override
std::string className() const override
Return the class name.
libmeshNodeIterator(const libmeshNodeIterator &)
Copy constructor.
libMesh::Mesh::node_iterator d_end2
std::unique_ptr< MeshIteratorBase > clone() const override
Clone the iterator.
libmeshNodeIterator(const AMP::Mesh::libmeshMesh *mesh, const libMesh::Mesh::node_iterator &begin, const libMesh::Mesh::node_iterator &end, const libMesh::Mesh::node_iterator &pos, int size, int pos2)
void registerChildObjects(AMP::IO::RestartManager *manager) const override
const AMP::Mesh::libmeshMesh * d_mesh
bool operator!=(const MeshIteratorBase &rhs) const override
Check if two iterators are not equal.
libmeshNodeIterator & operator=(const libmeshNodeIterator &)
Assignment operator.
MeshIteratorBase & operator--() override
libmeshNodeIterator(const AMP::Mesh::libmeshMesh *mesh, const libMesh::Mesh::node_iterator &begin, const libMesh::Mesh::node_iterator &end)
libMesh::Mesh::node_iterator d_pos2
libmeshNodeIterator()=delete
Empty MeshIterator constructor.
libMesh::Mesh::node_iterator d_begin2
bool operator==(const MeshIteratorBase &rhs) const override
Check if two iterators are equal.
MeshIterator begin() const override
Return an iterator to the beginning.
virtual ~libmeshNodeIterator()=default
Deconstructor.
libmeshMeshElement d_cur_element
void setPos(size_t) override
Set the position in the iterator.
MeshIteratorBase & operator++() override
MeshIteratorBase & operator+=(int N) override
A structure used to identify the mesh.