X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/blast.git/blobdiff_plain/f311fbc3e1436bf248c54225f0743cfa671c4bd7..2019e5afdaf7fd0ad21607848710348bbc3be256:/Graph.h diff --git a/Graph.h b/Graph.h index 723e8eb..f3e9923 100644 --- a/Graph.h +++ b/Graph.h @@ -21,16 +21,44 @@ public: Graph(); ~Graph(); - QList getOutsideInterfaces(); + // getters inline GroupBlock* getTopGroup() { return topGroup; } - - GroupBlock* createChildBlock(GroupBlock* parent); - FunctionalBlock* addFunctionalBlock(GroupBlock *group, ReferenceBlock *ref); - bool removeFunctionalBlock(FunctionalBlock* block, GroupBlock *group); + inline QList getAllGroups() { return groups; } + + // methods for group blocks + GroupBlock* createChildGroupBlock(GroupBlock* parent); bool removeGroupBlock(GroupBlock *group); + GroupBlock* getGroupBlockByName(QString name); + + // methods for functional blocks + FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref); + FunctionalBlock* duplicateFunctionalBlock(FunctionalBlock *block); + bool removeFunctionalBlock(FunctionalBlock* block); + FunctionalBlock* getFunctionalBlockByName(QString name, GroupBlock* parent = NULL); //! if parent = NULL, search in the whole graph + // methods for source blocks + FunctionalBlock* createSourceBlock(ReferenceBlock *ref); + FunctionalBlock* duplicateSourceBlock(FunctionalBlock *block); + FunctionalBlock* getSourceBlockByName(QString name); + bool removeSourceBlock(FunctionalBlock* block); + + // others + QList getOutsideInterfaces(); + /*! + * \brief initPatterns + * initPatterns() crosses the graph and for each functional block, it computes + * the consumptionPattern, the productionPattern, the production counter and delta + * using the parameters fo the block. + */ + bool createPatterns(); + void resetPatternComputed(); + bool computeOutputPatterns(int nbExec); + + private: GroupBlock* topGroup; + QList groups; //! usefull to avoid recursive methods to find a particular group. + QList sources; //! source for the top group };