mirror of
https://github.com/cclassic/model-ghdl
synced 2024-11-29 09:13:28 +01:00
Changed startup behavior of GtkWave to improve usability
This commit is contained in:
parent
e269810c6a
commit
0a243ddd1e
@ -2,6 +2,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
|
||||||
@ -150,22 +151,36 @@ int main(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//bool ex = false;
|
||||||
|
//while (!ex) {
|
||||||
string cargs = "cd " + string(tempdir) + "; ghdl -m --ieee=synopsys --warn-no-vital-generic --workdir=" + string(tempdir) + " --work=" + work + " " + top;
|
string cargs = "cd " + string(tempdir) + "; ghdl -m --ieee=synopsys --warn-no-vital-generic --workdir=" + string(tempdir) + " --work=" + work + " " + top;
|
||||||
if (run(cargs)) {
|
if (run(cargs)) {
|
||||||
cerr << "Error: Compilation failed." << endl;
|
cerr << "Error: Compilation failed." << endl;
|
||||||
|
run("zenity --error --text \"Compilation failed.\"");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
cargs = "";
|
cargs = "";
|
||||||
if (run("cd " + string(tempdir) + "; ./" + top + " --stop-time=" + getSimulationTime() + " --vcd=" + top + ".vcd")) {
|
string st = getSimulationTime();
|
||||||
|
if (st != "") {
|
||||||
|
if (run("cd " + string(tempdir) + "; ./" + top + " --stop-time=" + st + " --vcd=" + top + ".vcd")) {
|
||||||
cerr << "Error: Simulation failed." << endl;
|
cerr << "Error: Simulation failed." << endl;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (run("gtkwave " + string(tempdir) + "/" + top + ".vcd")) {
|
string wv = "gtkwave " + string(tempdir) + "/" + top + ".vcd &";
|
||||||
|
if (run("pidof gtkwave")) {
|
||||||
|
if (system(wv.c_str())) {
|
||||||
cerr << "Error: GtkWave failed.";
|
cerr << "Error: GtkWave failed.";
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
cout << "GtkWave started." << endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
|
||||||
|
//cout << "Simulation ended." << endl;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user