Medical Imaging Interaction Toolkit  2018.4.99-389bf124
Medical Imaging Interaction Toolkit
mitk::GenericIDRelationRule Class Reference

#include <mitkGenericIDRelationRule.h>

Inheritance diagram for mitk::GenericIDRelationRule:
Collaboration diagram for mitk::GenericIDRelationRule:

Public Types

typedef GenericIDRelationRule Self
 
typedef PropertyRelationRuleBase Superclass
 
typedef itk::SmartPointer< SelfPointer
 
typedef itk::SmartPointer< const SelfConstPointer
 
using RuleIDType = PropertyRelationRuleBase::RuleIDType
 
using RelationUIDType = PropertyRelationRuleBase::RelationUIDType
 
using RelationUIDVectorType = PropertyRelationRuleBase::RelationUIDVectorType
 
- Public Types inherited from mitk::PropertyRelationRuleBase
enum  RelationType { RelationType::None, RelationType::Implicit_Data, RelationType::Connected_Data, RelationType::Connected_ID }
 
typedef PropertyRelationRuleBase Self
 
typedef itk::Object Superclass
 
typedef itk::SmartPointer< SelfPointer
 
typedef itk::SmartPointer< const SelfConstPointer
 
using RuleIDType = std::string
 
using RelationUIDType = Identifiable::UIDType
 
using RelationUIDVectorType = std::vector< RelationUIDType >
 

Public Member Functions

virtual std::vector< std::string > GetClassHierarchy () const override
 
virtual const char * GetClassName () const
 
Pointer Clone () const
 
RuleIDType GetRuleID () const override
 
bool IsAbstract () const override
 
std::string GetDisplayName () const override
 
std::string GetSourceRoleName () const override
 
std::string GetDestinationRoleName () const override
 
RelationUIDType Connect (IPropertyOwner *source, const IPropertyProvider *destination) const
 
- Public Member Functions inherited from mitk::PropertyRelationRuleBase
Pointer Clone () const
 
 itkCreateAnotherMacro (Self)
 
virtual bool IsSourceCandidate (const IPropertyProvider *owner) const
 
virtual bool IsDestinationCandidate (const IPropertyProvider *owner) const
 
bool IsSource (const IPropertyProvider *owner) const
 
RelationType HasRelation (const IPropertyProvider *source, const IPropertyProvider *destination) const
 
RelationUIDVectorType GetExistingRelations (const IPropertyProvider *source) const
 
RelationUIDVectorType GetRelationUIDs (const IPropertyProvider *source, const IPropertyProvider *destination) const
 
RelationUIDType GetRelationUID (const IPropertyProvider *source, const IPropertyProvider *destination) const
 
NodePredicateBase::ConstPointer GetSourceCandidateIndicator () const
 
NodePredicateBase::ConstPointer GetDestinationCandidateIndicator () const
 
NodePredicateBase::ConstPointer GetConnectedSourcesDetector () const
 
NodePredicateBase::ConstPointer GetSourcesDetector (const IPropertyProvider *destination, RelationType minimalRelation=RelationType::Implicit_Data) const
 
NodePredicateBase::ConstPointer GetDestinationsDetector (const IPropertyProvider *source, RelationType minimalRelation=RelationType::Implicit_Data) const
 
NodePredicateBase::ConstPointer GetDestinationDetector (const IPropertyProvider *source, RelationUIDType relationUID) const
 
void Disconnect (IPropertyOwner *source, const IPropertyProvider *destination) const
 
void Disconnect (IPropertyOwner *source, RelationUIDType relationUID) const
 

Static Public Member Functions

static const char * GetStaticNameOfClass ()
 
static Pointer New (const RuleIDType &_arg)
 
static Pointer New (const RuleIDType &_arga, const std::string &_argb)
 
static Pointer New (const RuleIDType &_arga, const std::string &_argb, const std::string &_argc, const std::string &_argd)
 
- Static Public Member Functions inherited from mitk::PropertyRelationRuleBase
static const char * GetStaticNameOfClass ()
 
static PropertyKeyPath GetRootKeyPath ()
 

Protected Types

using InstanceIDType = PropertyRelationRuleBase::InstanceIDType
 
using InstanceIDVectorType = PropertyRelationRuleBase::InstanceIDVectorType
 
- Protected Types inherited from mitk::PropertyRelationRuleBase
using InstanceIDType = std::string
 
using InstanceIDVectorType = std::vector< InstanceIDType >
 

Protected Member Functions

 GenericIDRelationRule (const RuleIDType &ruleIDTag)
 
 GenericIDRelationRule (const RuleIDType &ruleIDTag, const std::string &displayName)
 
 GenericIDRelationRule (const RuleIDType &ruleIDTag, const std::string &displayName, const std::string &sourceRole, const std::string &destinationRole)
 
 ~GenericIDRelationRule () override=default
 
InstanceIDVectorType GetInstanceID_datalayer (const IPropertyProvider *source, const IPropertyProvider *destination) const override
 
bool HasImplicitDataRelation (const IPropertyProvider *source, const IPropertyProvider *destination) const override
 
void Connect_datalayer (IPropertyOwner *source, const IPropertyProvider *destination, const InstanceIDType &instanceID) const override
 
void Disconnect_datalayer (IPropertyOwner *source, const InstanceIDType &instanceID) const override
 
bool IsSupportedRuleID (const RuleIDType &ruleID) const override
 
itk::LightObject::Pointer InternalClone () const override
 
- Protected Member Functions inherited from mitk::PropertyRelationRuleBase
 PropertyRelationRuleBase ()=default
 
 ~PropertyRelationRuleBase () override=default
 
InstanceIDVectorType GetInstanceID_IDLayer (const IPropertyProvider *source, const IPropertyProvider *destination) const
 
RelationUIDType GetRelationUIDByInstanceID (const IPropertyProvider *source, const InstanceIDType &instanceID) const
 
InstanceIDType GetInstanceIDByRelationUID (const IPropertyProvider *source, const RelationUIDType &relationUID) const
 
RelationUIDType Connect (IPropertyOwner *source, const IPropertyProvider *destination) const
 
std::string GetRIIPropertyRegEx (const std::string propName="", const InstanceIDType &instanceID="") const
 
RuleIDType GetRuleIDByInstanceID (const IPropertyProvider *source, const InstanceIDType &instanceID) const
 
itk::LightObject::Pointer InternalClone () const override
 

Additional Inherited Members

- Static Protected Member Functions inherited from mitk::PropertyRelationRuleBase
static InstanceIDType NULL_INSTANCE_ID ()
 
static InstanceIDType GetInstanceIDByPropertyName (const std::string propName)
 
static std::vector< std::string > GetPropertyKeys (const mitk::IPropertyProvider *owner)
 

Detailed Description

This rule class can be used for relations that are only defined on the ID-layer and where no connection on the Data-layer can be defined or deduced. So it can be used for all ID based relations between PropertyProviders that also implement the interface identifiable. In order to be able to use this class for different relation types based on ID, the ruleIDTag is used. It must be specified when creating a rule instance. The ruleIDTag will be used as suffix for the rule ID of the instance and therefore allows to create specific and distinguishable rules instances based on this class. One may also specify the display name and the role names of the instance. If not speficied the default values are used (display name: "<ruleIDTag> relation", source role name: "source of <ruleIDTag> relation", destination role name: "destination <ruleIDTag> of relation")

Definition at line 32 of file mitkGenericIDRelationRule.h.

Member Typedef Documentation

◆ ConstPointer

◆ InstanceIDType

◆ InstanceIDVectorType

◆ Pointer

◆ RelationUIDType

◆ RelationUIDVectorType

◆ RuleIDType

◆ Self

◆ Superclass

Constructor & Destructor Documentation

◆ GenericIDRelationRule() [1/3]

mitk::GenericIDRelationRule::GenericIDRelationRule ( const RuleIDType ruleIDTag)
protected

Definition at line 50 of file mitkGenericIDRelationRule.cpp.

◆ GenericIDRelationRule() [2/3]

mitk::GenericIDRelationRule::GenericIDRelationRule ( const RuleIDType ruleIDTag,
const std::string &  displayName 
)
protected

Definition at line 53 of file mitkGenericIDRelationRule.cpp.

◆ GenericIDRelationRule() [3/3]

mitk::GenericIDRelationRule::GenericIDRelationRule ( const RuleIDType ruleIDTag,
const std::string &  displayName,
const std::string &  sourceRole,
const std::string &  destinationRole 
)
protected

Definition at line 57 of file mitkGenericIDRelationRule.cpp.

◆ ~GenericIDRelationRule()

mitk::GenericIDRelationRule::~GenericIDRelationRule ( )
overrideprotecteddefault

Member Function Documentation

◆ Clone()

Pointer mitk::GenericIDRelationRule::Clone ( ) const

◆ Connect()

mitk::GenericIDRelationRule::RelationUIDType mitk::GenericIDRelationRule::Connect ( IPropertyOwner source,
const IPropertyProvider destination 
) const

Pass through to base implementation of PropertyRelationRuleBase. See PropertyRelationRuleBase::connect documentation for more information.

Definition at line 45 of file mitkGenericIDRelationRule.cpp.

References mitk::PropertyRelationRuleBase::Connect().

◆ Connect_datalayer()

void mitk::GenericIDRelationRule::Connect_datalayer ( IPropertyOwner source,
const IPropertyProvider destination,
const InstanceIDType instanceID 
) const
overrideprotectedvirtual

Is called by Connect() to ensure that source has correctly set properties to resemble the relation on the data layer. This means that the method should set the properties that describe and encode the relation on the data layer (data-layer-specific relation properties). If the passed instance are already connected, the old settings should be overwritten. Connect() will ensure that source and destination are valid pointers.

Parameters
instanceIDis the ID for the relation instance that should be connected. Existance of the relation instance is ensured.
Precondition
source must be a valid instance.
destination must be a valid instance.

Implements mitk::PropertyRelationRuleBase.

Definition at line 77 of file mitkGenericIDRelationRule.cpp.

◆ Disconnect_datalayer()

void mitk::GenericIDRelationRule::Disconnect_datalayer ( IPropertyOwner source,
const InstanceIDType instanceID 
) const
overrideprotectedvirtual

This method is called by Disconnect() to remove all properties of the relation from the source that are set by Connect_datalayer().

Remarks
All RII-properties of this relation will removed by Disconnect() after this method call. If the relationUID is not part of the source. Nothing will be changed. Disconnect() ensures that source is a valid pointer if called.
Disconnect() ensures that sourece is valid and only invokes if instance exists.

Implements mitk::PropertyRelationRuleBase.

Definition at line 83 of file mitkGenericIDRelationRule.cpp.

◆ GetClassHierarchy()

virtual std::vector<std::string> mitk::GenericIDRelationRule::GetClassHierarchy ( ) const
inlineoverridevirtual

Reimplemented from mitk::PropertyRelationRuleBase.

Definition at line 35 of file mitkGenericIDRelationRule.h.

◆ GetClassName()

virtual const char* mitk::GenericIDRelationRule::GetClassName ( ) const
virtual

Reimplemented from mitk::PropertyRelationRuleBase.

◆ GetDestinationRoleName()

std::string mitk::GenericIDRelationRule::GetDestinationRoleName ( ) const
overridevirtual

Returns a human readable string that can be used to describe the role of a destination in context of the rule instance.

Implements mitk::PropertyRelationRuleBase.

Definition at line 40 of file mitkGenericIDRelationRule.cpp.

◆ GetDisplayName()

std::string mitk::GenericIDRelationRule::GetDisplayName ( ) const
overridevirtual

Returns a human readable string that can be used to describe the rule. Does not need to be unique.

Implements mitk::PropertyRelationRuleBase.

Definition at line 30 of file mitkGenericIDRelationRule.cpp.

◆ GetInstanceID_datalayer()

mitk::GenericIDRelationRule::InstanceIDVectorType mitk::GenericIDRelationRule::GetInstanceID_datalayer ( const IPropertyProvider source,
const IPropertyProvider destination 
) const
overrideprotectedvirtual

Is called if a instance ID cannot be deduced on the ID-layer. Implement this method to check which existing relation(s) as Connected_Data exists between both passed instances. If the passed instances have no explicit relation of type Connected_Data, an empty vector will be returned.

Remarks
Per definition of property relation rules only 0 or 1 instance should be found for one provider pair and rule. But the data layer may be ambiguous and there for muliple relation instances of the rule instance could match. The implementation of this function should report all relation instances. The calling function will take care of this violation.
Precondition
source must be a pointer to a valid IPropertyProvider instance.
destination must be a pointer to a valid IPropertyProvider instance.

Implements mitk::PropertyRelationRuleBase.

Definition at line 63 of file mitkGenericIDRelationRule.cpp.

◆ GetRuleID()

mitk::GenericIDRelationRule::RuleIDType mitk::GenericIDRelationRule::GetRuleID ( ) const
overridevirtual

Returns an ID string that identifies the rule class

Implements mitk::PropertyRelationRuleBase.

Definition at line 25 of file mitkGenericIDRelationRule.cpp.

Referenced by IsSupportedRuleID().

◆ GetSourceRoleName()

std::string mitk::GenericIDRelationRule::GetSourceRoleName ( ) const
overridevirtual

Returns a human readable string that can be used to describe the role of a source in context of the rule instance.

Implements mitk::PropertyRelationRuleBase.

Definition at line 35 of file mitkGenericIDRelationRule.cpp.

◆ GetStaticNameOfClass()

static const char* mitk::GenericIDRelationRule::GetStaticNameOfClass ( )
inlinestatic

Definition at line 35 of file mitkGenericIDRelationRule.h.

◆ HasImplicitDataRelation()

bool mitk::GenericIDRelationRule::HasImplicitDataRelation ( const IPropertyProvider source,
const IPropertyProvider destination 
) const
overrideprotectedvirtual

Is called by HasRelation() if no relation of type Connected_ID (GetInstanceID_IDLayer()) or Connected_Data (GetInstanceID_datalayer()) is evident. Implement this method to deduce if the passed instances have a relation of type Implicit_Data.

Precondition
source must be a pointer to a valid IPropertyProvider instance.
destination must be a pointer to a valid IPropertyProvider instance.

Implements mitk::PropertyRelationRuleBase.

Definition at line 70 of file mitkGenericIDRelationRule.cpp.

◆ InternalClone()

itk::LightObject::Pointer mitk::GenericIDRelationRule::InternalClone ( ) const
overrideprotected

Definition at line 87 of file mitkGenericIDRelationRule.cpp.

References New().

◆ IsAbstract()

bool mitk::GenericIDRelationRule::IsAbstract ( ) const
overridevirtual

Returns if the instance is a abstract rule (true). Default implementation is true. Overwrite and reimplement if another behavior is needed.

Reimplemented from mitk::PropertyRelationRuleBase.

Definition at line 15 of file mitkGenericIDRelationRule.cpp.

Referenced by IsSupportedRuleID().

◆ IsSupportedRuleID()

bool mitk::GenericIDRelationRule::IsSupportedRuleID ( const RuleIDType ruleID) const
overrideprotectedvirtual

Returns if the passed rule ID is supported/relevant for the rule. Either because it is the very ID of the rule (default implementation) or because it is an abstract rule which also supports the rule ID.

Returns
true: If the rule ID can handle the rule ID. false: the rule does not support the rule ID.

Reimplemented from mitk::PropertyRelationRuleBase.

Definition at line 20 of file mitkGenericIDRelationRule.cpp.

References GetRuleID(), and IsAbstract().

◆ New() [1/3]

static Pointer mitk::GenericIDRelationRule::New ( const RuleIDType _arg)
inlinestatic

Definition at line 37 of file mitkGenericIDRelationRule.h.

Referenced by InternalClone().

◆ New() [2/3]

static Pointer mitk::GenericIDRelationRule::New ( const RuleIDType _arga,
const std::string &  _argb 
)
inlinestatic

Definition at line 38 of file mitkGenericIDRelationRule.h.

◆ New() [3/3]

static Pointer mitk::GenericIDRelationRule::New ( const RuleIDType _arga,
const std::string &  _argb,
const std::string &  _argc,
const std::string &  _argd 
)
inlinestatic

Definition at line 39 of file mitkGenericIDRelationRule.h.


The documentation for this class was generated from the following files: