class Graph {
public:
- Graph(bool createTopGroupIface = true);
+ Graph();
~Graph();
// getters
inline GroupBlock* getTopGroup() { return topGroup; }
inline QList<GroupBlock*> getAllGroups() { return groups; }
+ inline double getClock(int id) { return clocks.at(id); }
+ inline QList<double>& getClocks() { return clocks; }
+ //setters
+ inline void resetClocks() { clocks.clear(); }
+
// methods for group blocks
GroupBlock* createChildGroupBlock(GroupBlock* parent, bool createGroupIface = true);
void removeGroupBlock(GroupBlock *group);
bool removeStimuliBlock(FunctionalBlock* block);
// others
+ void createTopGroup(bool createTopGroupIfaces = true);
+ inline void addClock(double freq) { clocks.append(freq); }
QList<AbstractInterface *> getOutsideInterfaces();
QList<QString> getExternalResources(); // returns the list of all external files needed for VHDL generation
GroupBlock* topGroup;
QList<GroupBlock *> groups; //! usefull to avoid recursive methods to find a particular group.
QList<FunctionalBlock*> stimulis; //! source for the top group
+ QList<double> clocks; // clocks[0] is the main clock.
};