diff options
author | Tristan Gingold <tgingold@free.fr> | 2019-10-05 08:04:37 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2019-10-05 08:04:37 +0200 |
commit | b574ebd8a8e74b45d2680366e2a3c478ee388a9c (patch) | |
tree | 9d23092796c2b5c62fe6fae66bc7bcbb8a36f425 /src | |
parent | c4ce356d19626e4218399ed1b52fc6194f8b739f (diff) | |
download | ghdl-b574ebd8a8e74b45d2680366e2a3c478ee388a9c.tar.gz ghdl-b574ebd8a8e74b45d2680366e2a3c478ee388a9c.tar.bz2 ghdl-b574ebd8a8e74b45d2680366e2a3c478ee388a9c.zip |
synth: support block declarations.
Diffstat (limited to 'src')
-rw-r--r-- | src/synth/synth-stmts.adb | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/src/synth/synth-stmts.adb b/src/synth/synth-stmts.adb index 9c84e5de6..48be812bd 100644 --- a/src/synth/synth-stmts.adb +++ b/src/synth/synth-stmts.adb @@ -1999,6 +1999,11 @@ package body Synth.Stmts is procedure Synth_Block_Statement (Syn_Inst : Synth_Instance_Acc; Blk : Node) is + use Areapools; + Prev_Instance_Pool : constant Areapool_Acc := Instance_Pool; + Blk_Inst : Synth_Instance_Acc; + Blk_Sname : Sname; + M : Areapools.Mark_Type; begin -- No support for guard or header. if Get_Block_Header (Blk) /= Null_Node @@ -2007,9 +2012,18 @@ package body Synth.Stmts is raise Internal_Error; end if; - Synth_Declarations (Syn_Inst, Get_Declaration_Chain (Blk)); + Blk_Sname := New_Sname (Get_Sname (Syn_Inst), Get_Identifier (Blk)); + Blk_Inst := Make_Instance (Syn_Inst, Blk, Blk_Sname); + Mark (M, Proc_Pool); + Instance_Pool := Proc_Pool'Access; + + Synth_Declarations (Blk_Inst, Get_Declaration_Chain (Blk)); Synth_Concurrent_Statements - (Syn_Inst, Get_Concurrent_Statement_Chain (Blk)); + (Blk_Inst, Get_Concurrent_Statement_Chain (Blk)); + + Free_Instance (Blk_Inst); + Release (M, Proc_Pool); + Instance_Pool := Prev_Instance_Pool; end Synth_Block_Statement; function Synth_PSL_Expression |