From 628582294c3695f271c738d1459d57b239e04487 Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Wed, 21 Mar 2018 06:21:36 +0100 Subject: Add test for architecture declarative region nested in entity's one. --- src/vhdl/sem.adb | 2 ++ testsuite/gna/issue542/nest.vhdl | 9 +++++++++ testsuite/gna/issue542/testsuite.sh | 10 ++++++++++ 3 files changed, 21 insertions(+) create mode 100644 testsuite/gna/issue542/nest.vhdl diff --git a/src/vhdl/sem.adb b/src/vhdl/sem.adb index 6c2810d53..a19d66179 100644 --- a/src/vhdl/sem.adb +++ b/src/vhdl/sem.adb @@ -198,6 +198,8 @@ package body Sem is -- considered to occur immediatly within the declarative region -- associated with the entity declaration corresponding to the given -- architecture body. + -- + -- GHDL: this is only in vhdl-2002. if Vhdl_Std = Vhdl_02 then Open_Declarative_Region; end if; diff --git a/testsuite/gna/issue542/nest.vhdl b/testsuite/gna/issue542/nest.vhdl new file mode 100644 index 000000000..0becf0fe2 --- /dev/null +++ b/testsuite/gna/issue542/nest.vhdl @@ -0,0 +1,9 @@ +entity nest is + constant c : natural := 1; +end nest; + +architecture behav of nest is + -- Not valid in vhdl-02. + signal c : boolean; +begin +end behav; diff --git a/testsuite/gna/issue542/testsuite.sh b/testsuite/gna/issue542/testsuite.sh index b132693a1..300b24e3a 100755 --- a/testsuite/gna/issue542/testsuite.sh +++ b/testsuite/gna/issue542/testsuite.sh @@ -6,12 +6,22 @@ export GHDL_STD_FLAGS=--std=93 analyze write.vhd analyze_failure wrapper.vhd +analyze_failure nest.vhdl + +clean + + +export GHDL_STD_FLAGS=--std=02 +analyze nest.vhdl + clean export GHDL_STD_FLAGS=--std=08 analyze write.vhd analyze_failure wrapper.vhd +analyze_failure nest.vhdl + clean echo "Test successful" -- cgit v1.2.3