4 #include "base/src/callback.h" 14 class IContainerContact;
23 class IRBlockTemplate;
31 virtual TType getRBlockType()
const=0;
33 virtual TType getRBlockTemplateType()
const=0;
35 virtual TType getGhostRBlockType()
const=0;
37 virtual uint getRBlockGeometryNotice()
const=0;
39 virtual uint getRBlockHideNotice()
const=0;
41 virtual uint getRBlockSelectNotice()
const=0;
43 virtual uint getRBlockCycleNotice()
const=0;
45 virtual uint getRBlockFixNotice()
const=0;
47 virtual uint getRBlockPropertyNotice()
const=0;
49 virtual uint getRBlockExtraNotice()
const=0;
51 virtual uint getRBlockGroupNotice()
const=0;
53 virtual const IContainer * getIContainerRBlock()
const=0;
57 virtual const IContainer * getIContainerRBlockTemplate()
const=0;
59 virtual IContainer * getIContainerRBlockTemplate()=0;
61 virtual const IContainer * getIContainerGhostRBlock()
const=0;
63 virtual IContainer * getIContainerGhostRBlock()=0;
70 virtual const ICellSpace * getRBlockCellSpace()
const=0;
74 virtual const IRBlock * findIRBlockWithID(quint64
id)
const=0;
76 virtual IRBlock * findIRBlockWithID(quint64
id) =0;
78 virtual const IRBlockTemplate * findIRBlockTemplateWithID(quint64
id)
const=0;
82 virtual const IRBlockTemplate * findIRBlockTemplateWithName(
const QString &s)
const=0;
84 virtual IRBlockTemplate * findIRBlockTemplateWithName(
const QString &s) =0;
86 virtual const IGhostRBlock * findIGhostRBlockWithID(quint64
id)
const=0;
88 virtual IGhostRBlock * findIGhostRBlockWithID(quint64
id) =0;
94 virtual const IRBlock * findIRBlockContaining(
const DVect &v,QSet<quint64> *skip=
nullptr)
const=0;
96 virtual IRBlock * findIRBlockContaining(
const DVect &v,QSet<quint64> *skip=
nullptr)=0;
101 virtual const IEnergyMap * getIRBlockEnergies()
const=0;
108 virtual void populateAttributeSets(QStringList *scalarAtts,
FArray<uint> *scalarNotices,QStringList *stringAtts,
FArray<uint> *stringNotices,QStringList *vectorAtts,
FArray<uint> *vectorNotices)
const=0;
110 virtual void populatePropertySets(QStringList *valueProps,QStringList *labelProps,QStringList *vectorProps)
const=0;
112 virtual prop_signal * getPropertySignal()
const = 0;
118 template <
class S,
void (S::*MFP)(IRBlock *,qu
int32,qu
int32,
void *)>
121 threadedCallbackObject(callback,v,useThreads);
Definition: callback.h:30
namespace Itasca
Definition: basememory.cpp:9
Definition of a Signal2 object, holding a list of ISlot2 objects.
Definition: isignalbase.h:76
Definition: irblockmodule.h:25
Interface for the small-granularity callback utility.
An array class that attempts to minimize unnecessary heap access.
debug checked shorthand for std::numeric_limits<T>::
Definition: limit.h:25
Definition: irblocktemplate.h:11
Signal2< const QString &, const QVariant & > prop_signal
Typedef for the small granularity signal used to indicate to the gui that a propery has been added.
Definition: irblockmodule.h:28
unsigned int TType
class type indicator
Definition: basedef.h:41
DExtent3 DExtent
A DExtent2 in 2D, a DExtent3 in 3D.
Definition: dim.h:149
Definition: callback.h:122
Definition: ighostrblock.h:16
Itasca Library standard namespace, specific to 2D or 3D.
Definition: icontactmodule.h:4
An array class that attempts to minimize unnecessary heap access.
Definition: farray.h:27
Interface for containers of IThings.
Definition: icontainer.h:23
DVect3 DVect
Vector of doubles, either 2D or 3D.
Definition: dim.h:145
Interface to a "refining" cell space.
Definition: icellspace.h:24
void threadedCallbackMethod(S *s, void *v=nullptr, bool useThreads=true) const
Implementation of the multithreaded loop using the threadedCallbackObjectRBlock.
Definition: irblockmodule.h:119
Interface to EnergyMap class.
Definition: ienergymap.h:15