cc70a02.a
来自「linux下编程用 编译软件」· A 代码 · 共 194 行
A
194 行
-- CC70A02.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 visible part of a generic formal package includes the-- first list of basic declarative items of the package specification.-- Check for a generic subprogram which declares a formal package with-- (<>) as its actual part.---- TEST DESCRIPTION:-- The "first list of basic declarative items" of a package specification-- is the visible part of the package. Thus, the declarations in the-- visible part of the actual instance corresponding to a formal-- package are available in the generic which declares the formal package.-- -- Declare a generic package which simulates a complex integer abstraction-- (foundation code).---- Declare a second generic package which defines a "signature" for-- mathematical groups. Declare a generic function within a package-- which utilizes the second generic package as a generic formal package-- (with a (<>) actual_part).---- In the main program, instantiate the first generic package, then-- instantiate the second generic package with objects, types, and-- operations declared in the first instance.---- Instantiate the generic function and pass the second instance-- to it as a generic actual parameter. Check that the instance of the-- generic function performs as expected.------ CHANGE HISTORY:-- 06 Dec 94 SAIC ACVC 2.0----!generic -- Mathematical group signature. type Group_Type is private; Identity : in Group_Type; with function Operation (Left, Right : Group_Type) return Group_Type; with function Inverse (Right : Group_Type) return Group_Type;package CC70A02_0 is end;-- No body for CC70A02_0. --==================================================================--with CC70A02_0; -- Mathematical group signature.package CC70A02_1 is -- Mathematical group operations. -- -- -- Generic formal package used here -- -- -- generic -- Powers for mathematical groups. with package Group is new CC70A02_0 (<>); function Power (Left : Group.Group_Type; Right : Integer) return Group.Group_Type;end CC70A02_1; --==================================================================--package body CC70A02_1 is -- Mathematical group operations. function Power (Left : Group.Group_Type; Right : Integer) return Group.Group_Type is Result : Group.Group_Type := Group.Identity; begin for I in 1 .. abs(Right) loop -- Repeat group operations Result := Group.Operation (Result, Left); -- the specified number of end loop; -- times. if Right < 0 then -- If specified power is return Group.Inverse (Result); -- negative, return the else -- inverse of the result. return Result; -- If it is zero, return end if; -- the identity. end Power;end CC70A02_1; --==================================================================--with Report;with FC70A00; -- Complex integer abstraction.with CC70A02_0; -- Mathematical group signature.with CC70A02_1; -- Mathematical group operations.procedure CC70A02 is -- Declare an instance of complex integers: type My_Integer is range -100 .. 100; package Complex_Integers is new FC70A00 (My_Integer); -- Define an addition group for complex integers: package Complex_Addition_Group is new CC70A02_0 (Group_Type => Complex_Integers.Complex_Type, -- For complex integers... Identity => Complex_Integers.Zero, -- Additive identity. Operation => Complex_Integers."+", -- Additive operation. Inverse => Complex_Integers."-"); -- Additive inverse. function Complex_Multiplication is new -- Multiplication of a CC70A02_1.Power(Complex_Addition_Group); -- complex integer by a -- constant. -- Define a multiplication group for complex integers: package Complex_Multiplication_Group is new CC70A02_0 (Group_Type => Complex_Integers.Complex_Type, -- For complex integers... Identity => Complex_Integers.One, -- Multiplicative identity. Operation => Complex_Integers."*", -- Multiplicative oper. Inverse => Complex_Integers.Reciprocal); -- Multiplicative inverse. function Complex_Exponentiation is new -- Exponentiation of a CC70A02_1.Power(Complex_Multiplication_Group); -- complex integer by a -- constant. use Complex_Integers;begin -- Main program. Report.Test ("CC70A02", "Check that the visible part of a generic " & "formal package includes the first list of basic " & "declarative items of the package specification. Check " & "for a generic subprogram where formal package has (<>) " & "actual part"); declare Mult_Operand : constant Complex_Type := Complex ( -4, 9); Exp_Operand : constant Complex_Type := Complex ( 0, -7); Expected_Mult_Result : constant Complex_Type := Complex ( 28, -63); Expected_Exp_Result : constant Complex_Type := Complex (-49, 0); begin if Complex_Multiplication (Mult_Operand, -7) /= Expected_Mult_Result then Report.Failed ("Incorrect results from complex multiplication"); end if; if Complex_Exponentiation (Exp_Operand, 2) /= Expected_Exp_Result then Report.Failed ("Incorrect results from complex exponentiation"); end if; end; Report.Result;end CC70A02;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?