The Gaudi Framework  master (ff829712)
Loading...
Searching...
No Matches
concurrency::DataNode Class Reference

#include </builds/gaudi/Gaudi/GaudiHive/src/PRGraph/PrecedenceRulesGraph.h>

Inheritance diagram for concurrency::DataNode:
Collaboration diagram for concurrency::DataNode:

Public Member Functions

 DataNode (PrecedenceRulesGraph &graph, const DataObjID &path)
 Constructor.
 
virtual ~DataNode ()=default
 Destructor.
 
const DataObjIDname () const
 
virtual bool accept (IGraphVisitor &visitor)
 Entry point for a visitor.
 
void addProducerNode (AlgorithmNode *node)
 Add relationship to producer AlgorithmNode.
 
void addConsumerNode (AlgorithmNode *node)
 Add relationship to consumer AlgorithmNode.
 
const std::vector< AlgorithmNode * > & getProducers () const
 Get all data object producers.
 
const std::vector< AlgorithmNode * > & getConsumers () const
 Get all data object consumers.
 

Public Attributes

PrecedenceRulesGraphm_graph
 

Private Attributes

DataObjID m_data_object_path
 
std::vector< AlgorithmNode * > m_producers
 
std::vector< AlgorithmNode * > m_consumers
 

Detailed Description

Definition at line 554 of file PrecedenceRulesGraph.h.

Constructor & Destructor Documentation

◆ DataNode()

concurrency::DataNode::DataNode ( PrecedenceRulesGraph & graph,
const DataObjID & path )
inline

Constructor.

Definition at line 557 of file PrecedenceRulesGraph.h.

557: m_graph( &graph ), m_data_object_path( path ) {}
PrecedenceRulesGraph * m_graph

◆ ~DataNode()

virtual concurrency::DataNode::~DataNode ( )
virtualdefault

Destructor.

Member Function Documentation

◆ accept()

virtual bool concurrency::DataNode::accept ( IGraphVisitor & visitor)
inlinevirtual

Entry point for a visitor.

Reimplemented in concurrency::ConditionNode.

Definition at line 565 of file PrecedenceRulesGraph.h.

565 {
566 return visitor.visitEnter( *this ) ? visitor.visit( *this ) : true;
567 }

◆ addConsumerNode()

void concurrency::DataNode::addConsumerNode ( AlgorithmNode * node)
inline

Add relationship to consumer AlgorithmNode.

Definition at line 574 of file PrecedenceRulesGraph.h.

574 {
575 if ( std::find( m_consumers.begin(), m_consumers.end(), node ) == m_consumers.end() )
576 m_consumers.push_back( node );
577 }
std::vector< AlgorithmNode * > m_consumers

◆ addProducerNode()

void concurrency::DataNode::addProducerNode ( AlgorithmNode * node)
inline

Add relationship to producer AlgorithmNode.

Definition at line 569 of file PrecedenceRulesGraph.h.

569 {
570 if ( std::find( m_producers.begin(), m_producers.end(), node ) == m_producers.end() )
571 m_producers.push_back( node );
572 }
std::vector< AlgorithmNode * > m_producers

◆ getConsumers()

const std::vector< AlgorithmNode * > & concurrency::DataNode::getConsumers ( ) const
inline

Get all data object consumers.

Definition at line 581 of file PrecedenceRulesGraph.h.

581{ return m_consumers; }

◆ getProducers()

const std::vector< AlgorithmNode * > & concurrency::DataNode::getProducers ( ) const
inline

Get all data object producers.

Definition at line 579 of file PrecedenceRulesGraph.h.

579{ return m_producers; }

◆ name()

const DataObjID & concurrency::DataNode::name ( ) const
inline

Definition at line 562 of file PrecedenceRulesGraph.h.

562{ return m_data_object_path; }

Member Data Documentation

◆ m_consumers

std::vector<AlgorithmNode*> concurrency::DataNode::m_consumers
private

Definition at line 589 of file PrecedenceRulesGraph.h.

◆ m_data_object_path

DataObjID concurrency::DataNode::m_data_object_path
private

Definition at line 587 of file PrecedenceRulesGraph.h.

◆ m_graph

PrecedenceRulesGraph* concurrency::DataNode::m_graph

Definition at line 584 of file PrecedenceRulesGraph.h.

◆ m_producers

std::vector<AlgorithmNode*> concurrency::DataNode::m_producers
private

Definition at line 588 of file PrecedenceRulesGraph.h.


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