1#ifndef ALUGRID_ENTITY_INLINE_HH
2#define ALUGRID_ENTITY_INLINE_HH
3#include <dune/common/exceptions.hh>
16 template<
int dim,
class Gr
idImp>
25 template<
int dim,
class Gr
idImp>
27 reset (
int walkLevel )
37 template<
int dim,
class Gr
idImp>
48 template<
int dim,
class Gr
idImp>
54 setElement( *key.interior() );
56 setGhost( *key.ghost() );
59 template<
int dim,
class Gr
idImp>
64 item_ =
static_cast<IMPLElementType *
> (&element);
74 template<
int dim,
class Gr
idImp>
79 item_ =
static_cast<IMPLElementType *
> ( ghost.getGhost().first );
86 ghost_ =
static_cast<BNDFaceType *
> (&ghost);
98 template<
int dim,
class Gr
idImp>
103 return item_->level();
106 template<
int dim,
class Gr
idImp>
110 return (item_ == org.item_);
113 template<
int dim,
class Gr
idImp>
120 template<
int dim,
class Gr
idImp>
124 return (*item_).getIndex();
127 template<
int dim,
class Gr
idImp>
131 return subEntities( cc );
134 template<
int dim,
class Gr
idImp>
137 return GridImp::referenceElement().size( codim );
140 template<
int dim,
class Gr
idImp>
147 return (isGhost() ? GhostEntity : InteriorEntity);
150 template<
int dim,
class Gr
idImp>
159 BNDFaceType * dwn =
static_cast<BNDFaceType *
> (ghost_->down());
160 return ( dwn ) ? (dwn->ghostLevel() == level()) :
true;
165 return ! item_->down();
169 template<
int dim,
class Gr
idImp>
183 template<
int dim,
class Gr
idImp>
191 template<
int dim,
class Gr
idImp>
195 return item_->hasBeenRefined();
198 template<
int dim,
class Gr
idImp>
202 return ((*item_).requestrule() == coarse_element_t);
211 template<
int codim,
class Gr
idImp >
219 template<
int codim,
class Gr
idImp >
227 template<
int codim,
class Gr
idImp >
236 template<
int codim,
class Gr
idImp >
244 template<
int codim,
class Gr
idImp >
248 , entity_( GridImp::getRealImplementation(org.entity_) )
254 template<
int codim,
class Gr
idImp >
263 template<
int codim,
class Gr
idImp >
271 if( seed_.isValid() )
274 entityImp().setEntity( org.
entityImp() );
282 template<
int codim,
class Gr
idImp >
288 template<
int codim,
class Gr
idImp >
293 return (seed_.equals( i.
seed_ ));
296 template<
int codim,
class Gr
idImp >
300 seed_.set( ghostFace );
301 if( seed_.isValid() )
303 entityImp().setGhost( ghostFace );
307 template<
int codim,
class Gr
idImp >
312 if( seed_.isValid() )
314 entityImp().setElement( *item );
324 template<
int codim,
class Gr
idImp >
328 seed_.set( *item, level );
329 if( seed_.isValid() )
331 entityImp().setElement( seed_ );
#define alugrid_assert(EX)
Definition alugrid_assert.hh:20
Definition alu3dinclude.hh:80
GeometryType type() const
type of geometry of this entity
Definition entity.hh:113
void setElement(const HItemType &item)
Definition entity_imp.cc:48
void updateEntityPointer(HElementType *item, int level)
Definition entity_inline.hh:326
ImplTraits::template Codim< dim, cd >::InterfaceType HElementType
Definition entity.hh:643
Definition iterator.hh:709
GridImp::template Codim< 0 >::EntitySeed EntitySeed
typedef of my type
Definition entity.hh:260
void updateGhostPointer(HBndSegType &ghostFace)
Definition entity_inline.hh:298
ALU3dGridEntitySeedType seed_
Definition entity.hh:543
bool equals(const ALU3dGridEntityPointerType &i) const
equality
Definition entity_inline.hh:290
EntityObject entity_
Definition entity.hh:546
EntityImp & entityImp() const
Definition entity.hh:549
void done()
has to be called when iterator is finished
Definition entity_inline.hh:283
ALU3dGridEntity< codimension, dim, GridImp > EntityImp
Definition entity.hh:480
void updateEntityPointer(HElementType *item, int level=-1)
Definition entity_inline.hh:309