aboutsummaryrefslogtreecommitdiffstats
path: root/src/vhdl/vhdl-std_env.adb
diff options
context:
space:
mode:
Diffstat (limited to 'src/vhdl/vhdl-std_env.adb')
-rw-r--r--src/vhdl/vhdl-std_env.adb59
1 files changed, 59 insertions, 0 deletions
diff --git a/src/vhdl/vhdl-std_env.adb b/src/vhdl/vhdl-std_env.adb
new file mode 100644
index 000000000..03b3c364f
--- /dev/null
+++ b/src/vhdl/vhdl-std_env.adb
@@ -0,0 +1,59 @@
+-- Nodes recognizer for ieee.math_real.
+-- Copyright (C) 2019 Tristan Gingold
+--
+-- This program is free software: you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation, either version 2 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program. If not, see <gnu.org/licenses>.
+
+with Types; use Types;
+with Std_Names; use Std_Names;
+
+package body Vhdl.Std_Env is
+ procedure Extract_Declarations (Pkg : Iir_Package_Declaration)
+ is
+ Decl : Iir;
+ Predef : Iir_Predefined_Functions;
+ Inter : Iir;
+ begin
+ Std_Env_Pkg := Pkg;
+
+ Decl := Get_Declaration_Chain (Pkg);
+
+ while Decl /= Null_Iir loop
+ pragma Assert (Get_Kind (Decl) in Iir_Kinds_Subprogram_Declaration);
+ Inter := Get_Interface_Declaration_Chain (Decl);
+ case Get_Identifier (Decl) is
+ when Name_Stop =>
+ if Inter = Null_Iir then
+ Predef := Iir_Predefined_Std_Env_Stop;
+ else
+ Predef := Iir_Predefined_Std_Env_Stop_Status;
+ pragma Assert (Get_Chain (Inter) = Null_Iir);
+ end if;
+ when Name_Finish =>
+ if Inter = Null_Iir then
+ Predef := Iir_Predefined_Std_Env_Finish;
+ else
+ Predef := Iir_Predefined_Std_Env_Finish_Status;
+ pragma Assert (Get_Chain (Inter) = Null_Iir);
+ end if;
+ when Name_Resolution_Limit =>
+ pragma Assert (Inter = Null_Iir);
+ Predef := Iir_Predefined_Std_Env_Resolution_Limit;
+ when others =>
+ raise Internal_Error;
+ end case;
+ Set_Implicit_Definition (Decl, Predef);
+ Decl := Get_Chain (Decl);
+ end loop;
+ end Extract_Declarations;
+end Vhdl.Std_Env;