Newer
Older
Rodrigo Cortes
committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/* Copyright or (C) or Copr. GET / ENST, Telecom-Paris, Ludovic Apvrille
* Daniela Genius, Lip6, UMR 7606
*
* ludovic.apvrille AT enst.fr
* daniela.genius@lip6.fr
*
* This software is a computer program whose purpose is to allow the
* edition of TURTLE analysis, design and deployment diagrams, to
* allow the generation of RT-LOTOS or Java code from this diagram,
* and at last to allow the analysis of formal validation traces
* obtained from external tools, e.g. RTL from LAAS-CNRS and CADP
* from INRIA Rhone-Alpes.
*
* This software is governed by the CeCILL license under French law and
* abiding by the rules of distribution of free software. You can use,
* modify and/ or redistribute the software under the terms of the CeCILL
* license as circulated by CEA, CNRS and INRIA at the following URL
* "http://www.cecill.info".
*
* As a counterpart to the access to the source code and rights to copy,
* modify and redistribute granted by the license, users are provided only
* with a limited warranty and the software's author, the holder of the
* economic rights, and the successive licensors have only limited
* liability.
*
* In this respect, the user's attention is drawn to the risks associated
* with loading, using, modifying and/or developing or reproducing the
* software by the user in light of its specific status of free software,
* that may mean that it is complicated to manipulate, and that also
* therefore means that it is reserved for developers and experienced
* professionals having in-depth computer knowledge. Users are therefore
* encouraged to load and test the software's suitability as regards their
* requirements in conditions enabling the security of their systems and/or
* data to be ensured and, more generally, to use and operate it in the
* same conditions as regards security.
*
* The fact that you are presently reading this means that you have had
* knowledge of the CeCILL license and that you accept its terms.
*/
/* this class produces the lines containing essentially the initial #includes; we include all potential components event if they are not used in the deployment diagram*/
/* authors: v1.0 Raja GATGOUT 2014
v2.0 Daniela GENIUS, Julien HENON 2015 */
package syscamstranslator.toSysCAMS;
import java.util.LinkedList;
import syscamstranslator.*;
/**
* Class MakefileCode Principal code of a makefile Creation: 02/06/2018
*
* @version 1.0 02/06/2018
* @author Irina Kit Yan LEE
*/
public class MakefileCode {
static private String corpsMakefile;
private final static String CR = "\n";
private final static String CR2 = "\n\n";
MakefileCode() {
}
public static String getMakefileCode(LinkedList<SysCAMSTCluster> clusters) {
if (clusters != null) {
corpsMakefile = "# Compiler and linker flags" + CR + "CXXFLAGS = -g -Wall -I. $(SYSTEMC_INCLUDE_DIRS)" + CR
+ "LDFLAGS = $(SYSTEMC_LIBRARY_DIRS)" + CR2 + "# List of all ecutables to be compiled" + CR
+ "EXECUTABLES = ";
for (int i = 0; i < clusters.size(); i++) {
if (i == 0) {
corpsMakefile = corpsMakefile + clusters.get(i).getClusterName() + "_tb";
}
if (i > 0) {
corpsMakefile = corpsMakefile + " " + clusters.get(i).getClusterName() + "_tb";
}
if (i == clusters.size() - 1) {
corpsMakefile = corpsMakefile + CR2;
}
}
corpsMakefile = corpsMakefile + "# .PHONY targets don't generate files" + CR + ".PHONY: all clean" + CR2
+ "# Default targets" + CR + "all: $(EXECUTABLES)" + CR2;
for (int i = 0; i < clusters.size(); i++) {
LinkedList<SysCAMSTBlockTDF> tdf = clusters.get(i).getBlockTDF();
LinkedList<SysCAMSTBlockDE> de = clusters.get(i).getBlockDE();
corpsMakefile = corpsMakefile + clusters.get(i).getClusterName() + "_tb: "
+ clusters.get(i).getClusterName() + "_tb.cpp";
for (SysCAMSTBlockTDF t : tdf) {
corpsMakefile = corpsMakefile + " " + t.getName() + ".h";
}
for (SysCAMSTBlockDE t : de) {
corpsMakefile = corpsMakefile + " " + t.getName() + ".h";
}
corpsMakefile = corpsMakefile + CR
+ "\t$(CXX) $(CXXFLAGS) $(LDFLAGS) -o $@ $< -lsystemc-ams -lsystemc | c++filt" + CR2;
}
corpsMakefile = corpsMakefile + "# Clean rule to delete temporary and generated files" + CR + "clean:" + CR
+ "\trm -rf *~ *.o *.dat *.vcd *.dSYM $(EXECUTABLES)" + CR;
} else {
corpsMakefile = "";
}
return corpsMakefile;
}
}