]> AND Private Git Repository - blast.git/blob - BlockImplementation.h
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
start modifying read/write blocks and project to take into account control ifaces
[blast.git] / BlockImplementation.h
1 #ifndef __BLOCKIMPLEMENTATION_H__\r
2 #define __BLOCKIMPLEMENTATION_H__\r
3 \r
4 #include <iostream>\r
5 #include <fstream>\r
6 \r
7 #include <QtCore>\r
8 #include <QtXml>\r
9 \r
10 class ReferenceBlock;\r
11 class FunctionalBlock;\r
12 class AbstractInterface;\r
13 \r
14 #include "ArithmeticEvaluator.h"\r
15 class ArithmeticEvaluator;\r
16 \r
17 #include "Exception.h"\r
18 class Exception;\r
19 \r
20 \r
21 using namespace std;\r
22 using namespace Qt;\r
23 \r
24 class BlockImplementation {\r
25 \r
26 public:\r
27 \r
28   BlockImplementation(const QString& _xmlFile);\r
29   BlockImplementation(const QString& _xmlFile, const QString& _referenceXml, const QString& _referenceMd5);\r
30 \r
31   inline QString getXmlFile() { return xmlFile; }\r
32   inline QString getReferenceXml() { return referenceXml; }\r
33   inline QString getReferenceMd5() { return referenceMd5; }\r
34   QString eval(QString line, QTextStream& out);\r
35   QString evalComplex(QString line, int num);\r
36   QString evalString(QString s);\r
37   QList<AbstractInterface*>* evalStringComplex(QString s);\r
38   QString evalValue(QString s);\r
39   QString calculateWidth(QString s);\r
40 \r
41   inline void setReference(ReferenceBlock* _reference) { reference = _reference; }\r
42 \r
43   void generateVHDL(FunctionalBlock* _block, const QString& path) throw(Exception); // main entry to generate the VHDL code\r
44 \r
45 private:  \r
46   QString xmlFile;\r
47   QString referenceXml;\r
48   QString referenceMd5;\r
49   QString nameEnt, line;\r
50   QMap<QString, int> paramMap;\r
51   ArithmeticEvaluator* evaluator;\r
52   ReferenceBlock* reference;\r
53   FunctionalBlock* block; // the current functional block for which this implementation is used.\r
54 \r
55   void generateComments(QDomElement &elt,QString coreFile, QTextStream& out) throw(Exception); // generates comments from <comments> element\r
56   void generateLibraries(QDomElement &elt, QTextStream& out) throw(Exception); // generates libraries from <libraries> element\r
57   void generateEntity(QTextStream& out, bool hasController=false) throw(Exception); // generate the entity using reference\r
58   void generateArchitecture(QDomElement &elt, QTextStream& out) throw(Exception); // generate the architecture using <architecture> element\r
59   void generateController(QTextStream& out) throw(Exception); // generate the wishbone controller of the block\r
60 \r
61   QString getIfaceUserName(AbstractInterface* refIface); // get the name of an interface given by the user, from the reference interface\r
62 \r
63   friend QDataStream &operator<<(QDataStream &out, const BlockImplementation &impl);\r
64   friend QDataStream &operator>>(QDataStream &in, BlockImplementation &impl);\r
65 };\r
66 \r
67 #endif // __BLOCKIMPLEMENTATION_H__\r
68 \r