ThePEG 2.3.0
|
The RefVector and its base class RefVectorBase defines an interface to a class derived from the InterfacedBase, through which vectors (or any other container) of pointers to other InterfacedBase objects may be manipulated. More...
#include <RefVector.h>
Public Member Functions | |
RefVectorBase (string newName, string newDescription, string newClassName, const type_info &newTypeInfo, string newRefClassName, const type_info &newRefTypeInfo, int newSize, bool depSafe, bool readonly, bool norebind, bool nullable, bool defnull) | |
Standard constructor. | |
virtual string | exec (InterfacedBase &ib, string action, string arguments) const |
The general interface method overriding the one in InterfaceBase. | |
virtual string | fullDescription (const InterfacedBase &ib) const |
Return a complete description of this reference vector. | |
virtual string | type () const |
Return a code for the type of this reference. | |
virtual string | doxygenType () const |
Return a string describing the type of interface to be included in the Doxygen documentation. | |
virtual void | set (InterfacedBase &ib, IBPtr ip, int i, bool chk=true) const =0 |
Set the i'th element of a container of pointers of ib to ip. | |
virtual void | insert (InterfacedBase &ib, IBPtr ip, int i, bool chk=true) const =0 |
Insert a new pointer before the i'th element of a container of pointers of ib and set it to ip. | |
virtual void | erase (InterfacedBase &ib, int i) const =0 |
Remove the i'th element of a container of pointers of ib. | |
virtual void | clear (InterfacedBase &ib) const =0 |
Clear the container of pointers of ib. | |
virtual IVector | get (const InterfacedBase &ib) const =0 |
Return a vector of pointers corresponding to the container of pointers of ib. | |
virtual bool | check (const InterfacedBase &ib, cIBPtr ip, int i) const =0 |
Check if set(ib, ip, i) will be successfull but do not do anything. | |
virtual void | rebind (InterfacedBase &ib, const TranslationMap &trans, const IVector &defs) const |
In the object ib, replace all pointers to objects in this interface with the translated ones provided by trans. | |
virtual IVector | getReferences (const InterfacedBase &ib) const |
Return pointers to other objects in ib. | |
int | size () const |
Get the size of the container being interfaced. | |
void | setSize (int sz) |
Set the size of the container being interfaced. | |
void | setVariableSize () |
Set the size of the container being interfaced to -1, i.e. | |
Public Member Functions inherited from ThePEG::RefInterfaceBase | |
RefInterfaceBase (string newName, string newDescription, string newClassName, const type_info &newTypeInfo, string newRefClassName, const type_info &newRefTypeInfo, bool depSafe, bool readonly, bool norebind, bool nullable, bool defnull) | |
Standard constructor. | |
string | refClassName () const |
Return the class name of the class referred to by this interface. | |
const type_info & | refTypeInfo () const |
Return the type_info object of the class referred to by this interface. | |
bool | noRebind () const |
Get the flag saying whether the interface is responsible for rebinding of the corresponding refenerces. | |
void | setNoRebind () |
Set the flag saying that the interface is not responsible for rebinding refenerces. | |
void | setRebind () |
Set the flag saying that the interface is responsible for rebinding refenerces. | |
bool | noNull () const |
Get the flag saying whether the interface is allowed to set the reference to null. | |
void | setNullable () |
Set the flag saying that the interface it is allowed to set the reference to null. | |
void | setNotNullable () |
Set the flag saying that the interface it is not allowed to set the reference to null. | |
bool | defaultIfNull () const |
Get the flag saying wether a null pointer should be replaced by a default of suitable class when rebind is called. | |
void | setDefaultIfNull () |
Set the flag saying that a null pointer should be replaced by a default of suitable class when rebind is called. | |
void | setNoDefaultIfNull () |
Set the flag saying that a null pointer should not be replaced by a default of suitable class when rebind is called. | |
Public Member Functions inherited from ThePEG::InterfaceBase | |
InterfaceBase (string newName, string newDescription, string newClassName, const type_info &newTypeInfo, bool depSafe, bool readonly) | |
Standard constructor. | |
virtual | ~InterfaceBase () |
The destructor. | |
string | tag (int pos=-1) const |
Create a tag for this interface using its name and optional poisitional argument. | |
virtual string | exec (InterfacedBase &ib, string action, string arguments) const =0 |
Manipulate an object of the corresponding class. | |
virtual string | type () const =0 |
Return a code for the type of this interface. | |
virtual bool | notDefault (InterfacedBase &) const |
Returns true if the setting for this interface has been changed from its default value. | |
map< string, string > & | objectDefaults (InterfacedBase &) const |
Returns the map of objectDefaults of the given object. | |
virtual void | rebind (InterfacedBase &, const TranslationMap &, const IVector &=IVector()) const |
Rebind all references in ib according to the translation map. | |
virtual IVector | getReferences (const InterfacedBase &) const |
For derived classes interfacing references between Interfaced objects, return the references for this interface. | |
string | description () const |
Return the description of this interface. | |
virtual string | fullDescription (const InterfacedBase &ib) const |
Return a complete description of this interface. | |
virtual void | doxygenDescription (ostream &stream) const |
Print a description to be included in the Doxygen documentation to the given stream. | |
virtual string | doxygenType () const =0 |
Return a string describing the type of interface to be included in the Doxygen documentation. | |
string | className () const |
Return the class name for the class this interface is defined for. | |
bool | dependencySafe () const |
Get the flag saying whether changing an object with this interface may change the state of a dependent object . | |
void | setDependencySafe () |
Set the flag saying whether changing an object with this interface may change the state of a dependent object . | |
void | setDependencySensitive () |
Set the flag saying whether changing an object with this interface may change the state of a dependent object . | |
bool | readOnly () const |
Get the flag saying whether this interface is allowed to change an object. | |
void | setReadOnly () |
Set the flag saying that this interface is allowed to change an object. | |
void | setReadWrite () |
Unset the flag saying that this interface is allowed to change an object. | |
bool | anonymous () const |
Return true if this interface is anonyous, ie. | |
double | rank () const |
Get the rank for this interface. | |
void | rank (double r) |
Set the rank for this interface. | |
void | setHasDefault (bool b) |
Indicate that this interface has a default value. | |
Public Member Functions inherited from ThePEG::Named | |
Named (const string &newName=string()) | |
Constructor with name. | |
Named (const Named &)=default | |
Explicit default copy-constructor (too avoid compiler warnings) | |
const string & | name () const |
Return name. | |
bool | operator== (const Named &other) const |
Test for equality. | |
bool | operator< (const Named &other) const |
Lexicographical comparison. | |
Private Attributes | |
int | theSize |
The size of the container being interfaced. | |
Additional Inherited Members | |
Static Public Attributes inherited from ThePEG::InterfaceBase | |
static bool | NoReadOnly |
If set to true, all read-only interfaces can be changed. | |
Protected Member Functions inherited from ThePEG::Named | |
const Named & | operator= (const Named &other) |
Assignment. | |
const string & | name (const string &newName) |
Set new name. | |
Protected Attributes inherited from ThePEG::InterfaceBase | |
bool | hasDefault |
A flag indicating whether this interface has a default setting. | |
bool | isDependencySafe |
The flag saying whether changing an object with this interface may change the state of a dependent object . | |
bool | isReadOnly |
The flag saying whether this interface is allowed to change an object. | |
The RefVector and its base class RefVectorBase defines an interface to a class derived from the InterfacedBase, through which vectors (or any other container) of pointers to other InterfacedBase objects may be manipulated.
RefVector is templated on the type of the class and the class of the objects pointed to, and is derived from the InterfaceBase class via RefVectorBase and RefInterfaceBase.
For each InterfacedBase class exactly one static RefVector object should created for each member variable of container type which should be interfaced. This object will automatically register itself with the BaseRepository class.
Definition at line 38 of file RefVector.h.
ThePEG::RefVectorBase::RefVectorBase | ( | string | newName, |
string | newDescription, | ||
string | newClassName, | ||
const type_info & | newTypeInfo, | ||
string | newRefClassName, | ||
const type_info & | newRefTypeInfo, | ||
int | newSize, | ||
bool | depSafe, | ||
bool | readonly, | ||
bool | norebind, | ||
bool | nullable, | ||
bool | defnull | ||
) |
Standard constructor.
newName | the name of the interface, may only contain letters [a-zA-z0-9_]. |
newDescription | a brief description of the interface. |
newClassName | the name of the corresponding class. |
newTypeInfo | the type_info object of the corresponding class. |
newRefClassName | the name of the class pointed to. |
newRefTypeInfo | the type_info object of the class pointed to. |
newSize | the size of the container or -1 if varying. |
depSafe | set to true if calls to this interface for one object does not influence other objects. |
readonly | if this is set true the interface will not be able to manipulate objects of the corresponding class, but will still be able to access information. |
norebind | if set to true, this interface is not responsible for the rebinding of corresponding objects. |
nullable | if set to true this corresponding references may be null. |
defnull | if set to true and a corresponding reference is null it may be given a a default value in the initialization of an EventGenerator. |
|
pure virtual |
Check if set(ib, ip, i) will be successfull but do not do anything.
Implemented in ThePEG::RefVector< T, R >.
|
pure virtual |
Clear the container of pointers of ib.
Implemented in ThePEG::RefVector< T, R >.
|
virtual |
Return a string describing the type of interface to be included in the Doxygen documentation.
Implements ThePEG::InterfaceBase.
|
pure virtual |
Remove the i'th element of a container of pointers of ib.
Implemented in ThePEG::RefVector< T, R >.
|
virtual |
The general interface method overriding the one in InterfaceBase.
For this class, action can be any of "set", "get", "erase" and "insert" and argument should be a something which can be read into an integer while the rest of argument should correspond to the name of an InterfacedBase object in the BaseRepository.
Implements ThePEG::InterfaceBase.
|
virtual |
Return a complete description of this reference vector.
Reimplemented from ThePEG::InterfaceBase.
|
pure virtual |
Return a vector of pointers corresponding to the container of pointers of ib.
Implemented in ThePEG::RefVector< T, R >.
|
virtual |
Return pointers to other objects in ib.
Reimplemented from ThePEG::InterfaceBase.
|
pure virtual |
Insert a new pointer before the i'th element of a container of pointers of ib and set it to ip.
Implemented in ThePEG::RefVector< T, R >.
|
virtual |
In the object ib, replace all pointers to objects in this interface with the translated ones provided by trans.
If a pointer is null, and defaultIfNull() is true, replace it with the first alowed object found in defs.
Reimplemented from ThePEG::InterfaceBase.
|
pure virtual |
Set the i'th element of a container of pointers of ib to ip.
Implemented in ThePEG::RefVector< T, R >.
|
inline |
Set the size of the container being interfaced.
If the size is less than 0, the size is allowed to vary.
Definition at line 178 of file RefVector.h.
References theSize.
|
inline |
Set the size of the container being interfaced to -1, i.e.
the size is allowed to vary.
Definition at line 184 of file RefVector.h.
References theSize.
|
inline |
Get the size of the container being interfaced.
If the size() is less than 0, the size is allowed to vary.
Definition at line 172 of file RefVector.h.
References theSize.
|
virtual |
Return a code for the type of this reference.
Implements ThePEG::InterfaceBase.
|
private |
The size of the container being interfaced.
Definition at line 191 of file RefVector.h.
Referenced by setSize(), setVariableSize(), and size().