URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c3/] [c3a0006.a] - Rev 720
Compare with Previous | Blame | View Log
-- C3A0006.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 access to subprogram may be stored within data-- structures, and that the access to subprogram can subsequently-- be called.---- TEST DESCRIPTION:-- Declare an access to function type in a package specification.-- Declare an array of the access type. Declare three different-- functions that can be referred to by the access to function type.---- In the main program, declare a key function that builds the array-- by calling each function indirectly through the access value.------ CHANGE HISTORY:-- 06 Dec 94 SAIC ACVC 2.0----!package C3A0006_0 isTC_Sine_Call : Integer := 0;TC_Cos_Call : Integer := 0;TC_Tan_Call : Integer := 0;Sine_Value : Float := 4.0;Cos_Value : Float := 8.0;Tan_Value : Float := 10.0;-- Type accesses to any functiontype Trig_Function_Ptr is access function(Angle : in Float) return Float;function Sine (Angle : in Float) return Float;function Cos (Angle : in Float) return Float;function Tan (Angle : in Float) return Float;end C3A0006_0;-----------------------------------------------------------------------------package body C3A0006_0 isfunction Sine (Angle : in Float) return Float isbeginTC_Sine_Call := TC_Sine_Call + 1;Sine_Value := Sine_Value + Angle;return Sine_Value;end Sine;function Cos (Angle: in Float) return Float isbeginTC_Cos_Call := TC_Cos_Call + 1;Cos_Value := Cos_Value - Angle;return Cos_Value;end Cos;function Tan (Angle : in Float) return Float isbeginTC_Tan_Call := TC_Tan_Call + 1;Tan_Value := (Tan_Value + (Tan_Value * Angle));return Tan_Value;end Tan;end C3A0006_0;-----------------------------------------------------------------------------with Report;with C3A0006_0;procedure C3A0006 isTrig_Value, Theta : Float := 0.0;Total_Routines : constant := 3;Sine_Total : constant := 7.0;Cos_Total : constant := 5.0;Tan_Total : constant := 75.0;Trig_Table : array (1 .. Total_Routines) of C3A0006_0.Trig_Function_Ptr;-- Key function to build the tablefunction Call_Trig_Func (Func : C3A0006_0.Trig_Function_Ptr;Operand : Float) return Float isbeginreturn (Func(Operand));end Call_Trig_Func;beginReport.Test ("C3A0006", "Check that access to subprogram may be " &"stored within data structures, and that the access " &"to subprogram can subsequently be called");Trig_Table := (C3A0006_0.Sine'Access, C3A0006_0.Cos'Access,C3A0006_0.Tan'Access);-- increase the value of Theta to build the tablefor I in 1 .. Total_Routines loopTheta := Theta + 0.5;for J in 1 .. Total_Routines loopTrig_Value := Call_Trig_Func (Trig_Table(J), Theta);end loop;end loop;if C3A0006_0.TC_Sine_Call /= Total_Routinesor C3A0006_0.TC_Cos_Call /= Total_Routinesor C3A0006_0.TC_Tan_Call /= Total_Routines thenReport.Failed ("Incorrect subprograms result");end if;if C3A0006_0.Sine_Value /= Sine_Totalor C3A0006_0.Cos_Value /= Cos_Totalor C3A0006_0.Tan_Value /= Tan_Total thenReport.Failed ("Incorrect values returned from subprograms");end if;if Trig_Value /= Tan_Total thenReport.Failed ("Incorrect call order.");end if;Report.Result;end C3A0006;
