aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2022-09-16 04:24:58 +0200
committerTristan Gingold <tgingold@free.fr>2022-09-16 04:24:58 +0200
commitdaa29e96da7ee3557d71005cd31c554f5fd74f34 (patch)
treecbb43b15b54d6763f2ff4f0e9d6812a9df1393d6 /src
parenta8fae0fb11d5dbe0a196af689301f48f5cca64ee (diff)
downloadghdl-daa29e96da7ee3557d71005cd31c554f5fd74f34.tar.gz
ghdl-daa29e96da7ee3557d71005cd31c554f5fd74f34.tar.bz2
ghdl-daa29e96da7ee3557d71005cd31c554f5fd74f34.zip
simul: improve error handling during elaboration
Diffstat (limited to 'src')
-rw-r--r--src/ghdldrv/ghdlsimul.adb10
-rw-r--r--src/simul/simul-vhdl_elab.adb1
2 files changed, 6 insertions, 5 deletions
diff --git a/src/ghdldrv/ghdlsimul.adb b/src/ghdldrv/ghdlsimul.adb
index 41dac66d2..bdc5ef6c8 100644
--- a/src/ghdldrv/ghdlsimul.adb
+++ b/src/ghdldrv/ghdlsimul.adb
@@ -94,16 +94,16 @@ package body Ghdlsimul is
Inst := Elab.Vhdl_Insts.Elab_Top_Unit (Lib_Unit);
if Errorout.Nbr_Errors > 0 then
- if Grt.Errors.Expect_Failure then
- return;
- else
- raise Errorout.Compilation_Error;
- end if;
+ raise Errorout.Compilation_Error;
end if;
Simul.Vhdl_Elab.Gather_Processes (Inst);
Simul.Vhdl_Elab.Elab_Processes;
+ if Errorout.Nbr_Errors > 0 then
+ raise Errorout.Compilation_Error;
+ end if;
+
if False then
Elab.Vhdl_Debug.Disp_Hierarchy (Inst, False, True);
end if;
diff --git a/src/simul/simul-vhdl_elab.adb b/src/simul/simul-vhdl_elab.adb
index 4296008eb..01cfc6b9a 100644
--- a/src/simul/simul-vhdl_elab.adb
+++ b/src/simul/simul-vhdl_elab.adb
@@ -984,6 +984,7 @@ package body Simul.Vhdl_Elab is
Processes_Table.Table (I).Inst := Proc_Inst;
Elab.Vhdl_Decls.Elab_Declarations
(Proc_Inst, Get_Declaration_Chain (Proc), True);
+ exit when Is_Error (Proc_Inst);
end if;
end loop;
Instance_Pool := null;