-- CA11021.A
|
-- CA11021.A
|
--
|
--
|
-- Grant of Unlimited Rights
|
-- Grant of Unlimited Rights
|
--
|
--
|
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
|
-- 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
|
-- 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 in the software and documentation contained herein.
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- this public release, the Government intends to confer upon all
|
-- this public release, the Government intends to confer upon all
|
-- recipients unlimited rights equal to those held by the Government.
|
-- recipients unlimited rights equal to those held by the Government.
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- released technical data and computer software in whole or in part, in
|
-- 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
|
-- any manner and for any purpose whatsoever, and to have or permit others
|
-- to do so.
|
-- to do so.
|
--
|
--
|
-- DISCLAIMER
|
-- DISCLAIMER
|
--
|
--
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
--*
|
--*
|
--
|
--
|
-- OBJECTIVE:
|
-- OBJECTIVE:
|
-- Check that body of the generic parent package can depend on one of
|
-- Check that body of the generic parent package can depend on one of
|
-- its own private generic children.
|
-- its own private generic children.
|
--
|
--
|
-- TEST DESCRIPTION:
|
-- TEST DESCRIPTION:
|
-- A scenario is created that demonstrates the potential of adding a
|
-- A scenario is created that demonstrates the potential of adding a
|
-- public generic child during code maintenance without distubing a large
|
-- public generic child during code maintenance without distubing a large
|
-- subsystem. After child is added to the subsystem, a maintainer
|
-- subsystem. After child is added to the subsystem, a maintainer
|
-- decides to take advantage of the new functionality and rewrites
|
-- decides to take advantage of the new functionality and rewrites
|
-- the parent's body.
|
-- the parent's body.
|
--
|
--
|
-- Declare a generic package which declares high level operations for a
|
-- Declare a generic package which declares high level operations for a
|
-- complex number abstraction. Declare a private generic child package
|
-- complex number abstraction. Declare a private generic child package
|
-- of this package which defines low level complex operations. In the
|
-- of this package which defines low level complex operations. In the
|
-- parent body, instantiate the private child. Use the low level
|
-- parent body, instantiate the private child. Use the low level
|
-- operation to complete the high level operation.
|
-- operation to complete the high level operation.
|
--
|
--
|
-- In the main program, instantiate the parent generic package.
|
-- In the main program, instantiate the parent generic package.
|
-- Check that the operations in both packages perform as expected.
|
-- Check that the operations in both packages perform as expected.
|
--
|
--
|
--
|
--
|
-- CHANGE HISTORY:
|
-- CHANGE HISTORY:
|
-- 06 Dec 94 SAIC ACVC 2.0
|
-- 06 Dec 94 SAIC ACVC 2.0
|
--
|
--
|
--!
|
--!
|
|
|
generic -- Complex number abstraction.
|
generic -- Complex number abstraction.
|
type Int_Type is range <>;
|
type Int_Type is range <>;
|
|
|
package CA11021_0 is
|
package CA11021_0 is
|
|
|
-- Simulate a generic complex number support package. Complex numbers
|
-- Simulate a generic complex number support package. Complex numbers
|
-- are treated as coordinates in the Cartesian plane.
|
-- are treated as coordinates in the Cartesian plane.
|
|
|
type Complex_Type is private;
|
type Complex_Type is private;
|
|
|
Zero : constant Complex_Type; -- Real number (0,0).
|
Zero : constant Complex_Type; -- Real number (0,0).
|
|
|
function Real_Part (Complex_No : Complex_Type)
|
function Real_Part (Complex_No : Complex_Type)
|
return Int_Type;
|
return Int_Type;
|
|
|
function Imag_Part (Complex_No : Complex_Type)
|
function Imag_Part (Complex_No : Complex_Type)
|
return Int_Type;
|
return Int_Type;
|
|
|
function Complex (Real, Imag : Int_Type)
|
function Complex (Real, Imag : Int_Type)
|
return Complex_Type;
|
return Complex_Type;
|
|
|
-- High level operation for complex number.
|
-- High level operation for complex number.
|
function "*" (Factor : Int_Type;
|
function "*" (Factor : Int_Type;
|
C : Complex_Type) return Complex_Type;
|
C : Complex_Type) return Complex_Type;
|
|
|
-- ... and other complicated ones.
|
-- ... and other complicated ones.
|
|
|
private
|
private
|
type Complex_Type is record
|
type Complex_Type is record
|
Real : Int_Type;
|
Real : Int_Type;
|
Imag : Int_Type;
|
Imag : Int_Type;
|
end record;
|
end record;
|
|
|
Zero : constant Complex_Type := (Real => 0, Imag => 0);
|
Zero : constant Complex_Type := (Real => 0, Imag => 0);
|
|
|
end CA11021_0;
|
end CA11021_0;
|
|
|
--==================================================================--
|
--==================================================================--
|
|
|
-- Private generic child of Complex_Number.
|
-- Private generic child of Complex_Number.
|
|
|
private
|
private
|
|
|
generic
|
generic
|
|
|
-- No parameter.
|
-- No parameter.
|
|
|
package CA11021_0.CA11021_1 is
|
package CA11021_0.CA11021_1 is
|
|
|
-- ... Other declarations.
|
-- ... Other declarations.
|
|
|
-- Low level operation on complex number.
|
-- Low level operation on complex number.
|
function "+" (Left, Right : Complex_Type)
|
function "+" (Left, Right : Complex_Type)
|
return Complex_Type;
|
return Complex_Type;
|
|
|
function "-" (Right : Complex_Type)
|
function "-" (Right : Complex_Type)
|
return Complex_Type;
|
return Complex_Type;
|
|
|
-- ... Various other operations in real application.
|
-- ... Various other operations in real application.
|
|
|
end CA11021_0.CA11021_1;
|
end CA11021_0.CA11021_1;
|
|
|
--==================================================================--
|
--==================================================================--
|
|
|
package body CA11021_0.CA11021_1 is
|
package body CA11021_0.CA11021_1 is
|
|
|
function "+" (Left, Right : Complex_Type)
|
function "+" (Left, Right : Complex_Type)
|
return Complex_Type is
|
return Complex_Type is
|
|
|
begin
|
begin
|
return ( (Left.Real + Right.Real, Left.Imag + Right.Imag) );
|
return ( (Left.Real + Right.Real, Left.Imag + Right.Imag) );
|
end "+";
|
end "+";
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
function "-" (Right : Complex_Type) return Complex_Type is
|
function "-" (Right : Complex_Type) return Complex_Type is
|
begin
|
begin
|
return (-Right.Real, -Right.Imag);
|
return (-Right.Real, -Right.Imag);
|
end "-";
|
end "-";
|
|
|
end CA11021_0.CA11021_1;
|
end CA11021_0.CA11021_1;
|
|
|
--==================================================================--
|
--==================================================================--
|
|
|
with CA11021_0.CA11021_1; -- Private generic child package.
|
with CA11021_0.CA11021_1; -- Private generic child package.
|
|
|
package body CA11021_0 is
|
package body CA11021_0 is
|
|
|
-----------------------------------------------------
|
-----------------------------------------------------
|
-- Parent's body depends on private generic child. --
|
-- Parent's body depends on private generic child. --
|
-----------------------------------------------------
|
-----------------------------------------------------
|
|
|
-- Instantiate the private child.
|
-- Instantiate the private child.
|
|
|
package Complex_Ops is new CA11021_1;
|
package Complex_Ops is new CA11021_1;
|
use Complex_Ops; -- All user-defined operators
|
use Complex_Ops; -- All user-defined operators
|
-- directly visible.
|
-- directly visible.
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
function "*" (Factor : Int_Type;
|
function "*" (Factor : Int_Type;
|
C : Complex_Type) return Complex_Type is
|
C : Complex_Type) return Complex_Type is
|
Result : Complex_Type := Zero;
|
Result : Complex_Type := Zero;
|
|
|
begin
|
begin
|
for I in 1 .. abs (Factor) loop
|
for I in 1 .. abs (Factor) loop
|
Result := Result + C; -- Private generic child "+".
|
Result := Result + C; -- Private generic child "+".
|
end loop;
|
end loop;
|
|
|
if Factor < 0 then
|
if Factor < 0 then
|
Result := - Result; -- Private generic child "-".
|
Result := - Result; -- Private generic child "-".
|
end if;
|
end if;
|
|
|
return Result;
|
return Result;
|
end "*";
|
end "*";
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
function Real_Part (Complex_No : Complex_Type) return Int_Type is
|
function Real_Part (Complex_No : Complex_Type) return Int_Type is
|
begin
|
begin
|
return (Complex_No.Real);
|
return (Complex_No.Real);
|
end Real_Part;
|
end Real_Part;
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
function Imag_Part (Complex_No : Complex_Type) return Int_Type is
|
function Imag_Part (Complex_No : Complex_Type) return Int_Type is
|
begin
|
begin
|
return (Complex_No.Imag);
|
return (Complex_No.Imag);
|
end Imag_Part;
|
end Imag_Part;
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
function Complex (Real, Imag : Int_Type) return Complex_Type is
|
function Complex (Real, Imag : Int_Type) return Complex_Type is
|
begin
|
begin
|
return (Real, Imag);
|
return (Real, Imag);
|
end Complex;
|
end Complex;
|
|
|
end CA11021_0;
|
end CA11021_0;
|
|
|
--==================================================================--
|
--==================================================================--
|
|
|
with CA11021_0; -- Complex number abstraction.
|
with CA11021_0; -- Complex number abstraction.
|
|
|
with Report;
|
with Report;
|
|
|
procedure CA11021 is
|
procedure CA11021 is
|
|
|
type My_Integer is range -100 .. 100;
|
type My_Integer is range -100 .. 100;
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
-- Declare instance of the generic complex package for one particular
|
-- Declare instance of the generic complex package for one particular
|
-- integer type.
|
-- integer type.
|
|
|
package My_Complex_Pkg is new
|
package My_Complex_Pkg is new
|
CA11021_0 (Int_Type => My_Integer);
|
CA11021_0 (Int_Type => My_Integer);
|
|
|
use My_Complex_Pkg; -- All user-defined operators
|
use My_Complex_Pkg; -- All user-defined operators
|
-- directly visible.
|
-- directly visible.
|
|
|
--------------------------------------------------
|
--------------------------------------------------
|
|
|
Complex_One, Complex_Two : Complex_Type;
|
Complex_One, Complex_Two : Complex_Type;
|
|
|
My_Literal : My_Integer := -3;
|
My_Literal : My_Integer := -3;
|
|
|
begin
|
begin
|
|
|
Report.Test ("CA11021", "Check that body of the generic parent package " &
|
Report.Test ("CA11021", "Check that body of the generic parent package " &
|
"can depend on its private generic child");
|
"can depend on its private generic child");
|
|
|
Complex_One := Complex (11, 6);
|
Complex_One := Complex (11, 6);
|
|
|
Complex_Two := 5 * Complex_One;
|
Complex_Two := 5 * Complex_One;
|
|
|
if Real_Part (Complex_Two) /= 55
|
if Real_Part (Complex_Two) /= 55
|
and Imag_Part (Complex_Two) /= 30
|
and Imag_Part (Complex_Two) /= 30
|
then
|
then
|
Report.Failed ("Incorrect results from complex operation");
|
Report.Failed ("Incorrect results from complex operation");
|
end if;
|
end if;
|
|
|
Complex_One := Complex (-4, 7);
|
Complex_One := Complex (-4, 7);
|
|
|
Complex_Two := My_Literal * Complex_One;
|
Complex_Two := My_Literal * Complex_One;
|
|
|
if Real_Part (Complex_Two) /= 12
|
if Real_Part (Complex_Two) /= 12
|
and Imag_Part (Complex_Two) /= -21
|
and Imag_Part (Complex_Two) /= -21
|
then
|
then
|
Report.Failed ("Incorrect results from complex operation");
|
Report.Failed ("Incorrect results from complex operation");
|
end if;
|
end if;
|
|
|
Report.Result;
|
Report.Result;
|
|
|
end CA11021;
|
end CA11021;
|
|
|