X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/blast.git/blobdiff_plain/cf93fd850a8b6e9a6f40faed9f796a0e2fb0cedb..2bdaa0aa3fab52f0808f60d9bbdabcd56d0efae9:/Graph.h?ds=inline diff --git a/Graph.h b/Graph.h index b9c598a..a9b90aa 100644 --- a/Graph.h +++ b/Graph.h @@ -19,7 +19,7 @@ using namespace Qt; class Graph { public: - Graph(); + Graph(bool createTopGroupIface = true); ~Graph(); // getters @@ -27,24 +27,26 @@ public: inline QList getAllGroups() { return groups; } // methods for group blocks - GroupBlock* createChildGroupBlock(GroupBlock* parent); + GroupBlock* createChildGroupBlock(GroupBlock* parent, bool createGroupIface = true); void removeGroupBlock(GroupBlock *group); GroupBlock* getGroupBlockByName(QString name); // methods for functional blocks - FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref); + FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref, bool createIfaces = true); 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* createSourceBlock(ReferenceBlock *ref, bool createIfaces = true); FunctionalBlock* duplicateSourceBlock(FunctionalBlock *block); FunctionalBlock* getSourceBlockByName(QString name); bool removeSourceBlock(FunctionalBlock* block); // others QList getOutsideInterfaces(); + QList getExternalResources(); // returns the list of all external files needed for VHDL generation + /*! * \brief createPatterns * createPatterns() crosses the graph and for each functional block, it computes @@ -55,7 +57,8 @@ public: void resetPatternComputed(); void computeOutputPatterns(int nbExec) throw(Exception); - + void generateVHDL(const QString& path) throw(Exception); + private: GroupBlock* topGroup; QList groups; //! usefull to avoid recursive methods to find a particular group.