PandA-2024.02
design_flow_aux_step.hpp
Go to the documentation of this file.
1 /*
2  *
3  * _/_/_/ _/_/ _/ _/ _/_/_/ _/_/
4  * _/ _/ _/ _/ _/_/ _/ _/ _/ _/ _/
5  * _/_/_/ _/_/_/_/ _/ _/_/ _/ _/ _/_/_/_/
6  * _/ _/ _/ _/ _/ _/ _/ _/ _/
7  * _/ _/ _/ _/ _/ _/_/_/ _/ _/
8  *
9  * ***********************************************
10  * PandA Project
11  * URL: http://panda.dei.polimi.it
12  * Politecnico di Milano - DEIB
13  * System Architectures Group
14  * ***********************************************
15  * Copyright (C) 2004-2024 Politecnico di Milano
16  *
17  * This file is part of the PandA framework.
18  *
19  * The PandA framework is free software; you can redistribute it and/or modify
20  * it under the terms of the GNU General Public License as published by
21  * the Free Software Foundation; either version 3 of the License, or
22  * (at your option) any later version.
23  *
24  * This program is distributed in the hope that it will be useful,
25  * but WITHOUT ANY WARRANTY; without even the implied warranty of
26  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
27  * GNU General Public License for more details.
28  *
29  * You should have received a copy of the GNU General Public License
30  * along with this program. If not, see <http://www.gnu.org/licenses/>.
31  *
32  */
44 #ifndef DESIGN_FLOW_AUX_STEP_HPP
45 #define DESIGN_FLOW_AUX_STEP_HPP
46 #include "design_flow_step.hpp" // for DesignFlowStep, DesignFlowManagerCon...
47 #include <iosfwd> // for ostream
48 #include <string> // for string
49 
52  DESIGN_FLOW_ENTRY,
53  DESIGN_FLOW_EXIT
54 };
55 
60 {
61  private:
64 
66  const std::string name;
67 
68  public:
76  AuxDesignFlowStep(std::string name, const AuxDesignFlowStepType type,
77  const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters);
78 
82  ~AuxDesignFlowStep() override;
83 
88  DesignFlowStep_Status Exec() override;
89 
94  bool HasToBeExecuted() const override;
95 
100  std::string GetSignature() const override;
101 
106  std::string GetName() const override;
107 
114  void ComputeRelationships(DesignFlowStepSet& relationship,
115  const DesignFlowStep::RelationshipType relationship_type) override;
116 
123  static const std::string ComputeSignature(const std::string& name, const AuxDesignFlowStepType type);
124 
129  void WriteDot(std::ostream& out) const override;
130 
134  DesignFlowStepFactoryConstRef CGetDesignFlowStepFactory() const override;
135 };
136 #endif
void WriteDot(std::ostream &out) const override
Write the label for a dot graph.
std::string GetSignature() const override
Return a unified identifier of this design step.
void ComputeRelationships(DesignFlowStepSet &relationship, const DesignFlowStep::RelationshipType relationship_type) override
Compute the relationships of a step with other steps.
const std::string name
The name of this auxiliary design flow step.
bool HasToBeExecuted() const override
Check if this step has actually to be executed.
RelationshipType
The relationship type.
DesignFlowStepFactoryConstRef CGetDesignFlowStepFactory() const override
Return the factory to create this type of steps.
The base class for design step.
std::string GetName() const override
Return the name of this design step.
~AuxDesignFlowStep() override
Destructor.
Base class for step of design flow.
DesignFlowStep_Status Exec() override
Execute the step.
AuxDesignFlowStep(std::string name, const AuxDesignFlowStepType type, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
Constructor.
const Wrefcount< const DesignFlowManager > design_flow_manager
The design flow manager.
const ParameterConstRef parameters
Set of input parameters.
DesignFlowStep_Status
The status of a step.
const AuxDesignFlowStepType type
The type of this auxiliary design flow step.
Class describing auxiliary steps in design flow.
enum AuxDesignFlowStepType { DESIGN_FLOW_ENTRY, DESIGN_FLOW_EXIT } AuxDesignFlowStepType
Identifier of the auxiliary design flow steps.
Template borrowed from the ANTLR library by Terence Parr (http://www.jGuru.com - Software rights: htt...
Definition: refcount.hpp:94
static const std::string ComputeSignature(const std::string &name, const AuxDesignFlowStepType type)
Compute the signature of a sdf design flow step.

Generated on Mon Feb 12 2024 13:02:51 for PandA-2024.02 by doxygen 1.8.13