blob: a681c5f13e28dd3d0bfd192a11b096673aa0e8b3 [file] [log] [blame]
-- CXB5001.A
--
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
--
-- OBJECTIVE:
-- Check that the specification of the package Interfaces.Fortran
-- are available for use.
--
-- TEST DESCRIPTION:
-- This test verifies that the types and subprograms specified for the
-- interface are present
--
-- APPLICABILITY CRITERIA:
-- If an implementation provides package Interfaces.Fortran, this test
-- must compile, execute, and report "PASSED".
--
--
-- CHANGE HISTORY:
-- 06 Dec 94 SAIC ACVC 2.0
-- 28 Feb 96 SAIC Added applicability criteria.
-- 27 Oct 96 SAIC Incorporated reviewer comments.
--
--!
with Report;
with Interfaces.Fortran; -- N/A => ERROR
procedure CXB5001 is
package Fortran renames Interfaces.FORTRAN;
begin
Report.Test ("CXB5001", "Check the specification of Interfaces.Fortran");
declare -- encapsulate the test
TC_Int : integer := 1;
TC_Natural : natural;
TC_String : String := "ABCD";
TC_Character : Character := 'a';
TST_Fortran_Integer : FORTRAN.Fortran_Integer;
TST_Real : Fortran.Real;
TST_Double_Precision : Fortran.Double_Precision;
TST_Logical : Fortran.Logical := FORTRAN.true;
-- verify it is a Boolean
TST_Complex : Fortran.Complex;
TST_Imaginary_i : Fortran.Imaginary := FORTRAN.i;
TST_Imaginary_j : Fortran.Imaginary := FORTRAN.j;
-- Initialize it so we can use it below
TST_Character_Set : Fortran.Character_Set :=
Fortran.Character_Set'First;
TST_Fortran_Character : FORTRAN.Fortran_Character (1..5) :=
(others => TST_Character_Set);
begin -- encapsulation
-- Arrange that the calls to the subprograms are compiled but
-- not executed
--
if not Report.Equal ( TC_Int, TC_Int ) then
TST_Character_Set := Fortran.To_Fortran (TC_Character);
TC_Character := Fortran.To_Ada (TST_Character_Set);
TST_Fortran_Character := FORTRAN.To_Fortran ("TEST STRING");
Report.Comment ( Fortran.To_Ada (TST_Fortran_Character) );
Fortran.To_Fortran ( TC_String, TST_Fortran_Character, TC_Natural );
Fortran.To_Ada ( TST_Fortran_Character, TC_String, TC_Natural );
end if;
end; -- encapsulation
Report.Result;
end CXB5001;