cd72a02.a
来自「linux下编程用 编译软件」· A 代码 · 共 226 行
A
226 行
-- CD72A02.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 package System.Address_To_Access_Conversions may be-- instantiated for various composite types.---- Check that To_Pointer and To_Address are inverse operations.---- Check that To_Pointer(X'Address) equals X'Unchecked_Access for an-- X that allows Unchecked_Access.---- Check that To_Pointer(Null_Address) returns null.---- TEST DESCRIPTION:-- This test is identical to CD72A01 with the exception that it tests-- the composite types where CD72A01 tests "simple" types.---- This test checks that the semantics provided in-- Address_To_Access_Conversions are present and operate-- within expectations (to the best extent possible in a portable-- implementation independent fashion).---- The functions Address_To_Hex and Hex_To_Address test the invertability-- of the To_Integer and To_Address functions, along with a great deal-- of optimizer chaff and protection from the fact that type-- Storage_Elements.Integer_Address may be either a modular or a signed-- integer type.---- This test has some interesting usage paradigms in that users-- occasionally want to store address information in a transportable-- fashion, and often resort to some textual representation of values.---- APPLICABILITY CRITERIA:-- All implementations must attempt to compile this test.---- For implementations validating against Systems Programming Annex (C):-- this test must execute and report PASSED.---- For implementations not validating against Annex C:-- this test may report compile time errors at one or more points-- indicated by "-- ANX-C RQMT", in which case it may be graded as inapplicable.-- Otherwise, the test must execute and report PASSED.------ CHANGE HISTORY:-- 13 JUL 95 SAIC Initial version (CD72001)-- 08 FEB 96 SAIC Split from CD72001 by reviewer request for 2.1-- 12 NOV 96 SAIC Corrected typo in RM ref-- 16 FEB 98 EDS Modified documentation.-- 22 JAN 02 RLB Corrected test description.--!with Report;with Impdef;with FD72A00;with System.Storage_Elements;with System.Address_To_Access_Conversions;procedure CD72A02 is use System; use FD72A00; type Tagged_Record is tagged record Value : Natural; end record; package Class_ATAC is new System.Address_To_Access_Conversions(Tagged_Record'Class); -- ANX-C RQMT use type Class_ATAC.Object_Pointer; task type TC_Task_Type is entry E; entry F; end TC_Task_Type; package Task_ATAC is new System.Address_To_Access_Conversions(TC_Task_Type); -- ANX-C RQMT use type Task_ATAC.Object_Pointer; task body TC_Task_Type is begin select accept E; or accept F; Report.Failed("Task rendezvoused on wrong path"); end select; end TC_Task_Type; protected type TC_Protec is procedure E; procedure F; private Visited : Boolean := False; end TC_Protec; package Protected_ATAC is new System.Address_To_Access_Conversions(TC_Protec); -- ANX-C RQMT use type Protected_ATAC.Object_Pointer; protected body TC_Protec is procedure E is begin Visited := True; end E; procedure F is begin if not Visited then Report.Failed("Protected Object took wrong path"); end if; end F; end TC_Protec; type Test_Cases is ( Tagged_Type, Task_Type, Protected_Type ); type Naive_Dynamic_String is access String; type String_Store is array(Test_Cases) of Naive_Dynamic_String; The_Strings : String_Store; -- create several aliased objects with distinct values My_Rec : aliased Tagged_Record := (Value => Natural'Last); My_Task : aliased TC_Task_Type; My_Prot : aliased TC_Protec; use type System.Storage_Elements.Integer_Address;begin -- Main test procedure. Report.Test ("CD72A02", "Check package " & "System.Address_To_Access_Conversions " & "for composite types" ); -- take several pointer objects, convert them to addresses, and store -- the address as a hexadecimal representation for later reconversion The_Strings(Tagged_Type) := new String'( Address_To_Hex(Class_ATAC.To_Address(My_Rec'Access)) ); The_Strings(Task_Type) := new String'( Address_To_Hex(Task_ATAC.To_Address(My_Task'Access)) ); The_Strings(Protected_Type) := new String'( Address_To_Hex(Protected_ATAC.To_Address(My_Prot'Access)) ); -- now, reconvert the hexadecimal address values back to pointers, -- and check that the dereferenced pointer still designates the -- value placed at that location. The use of the intermediate -- string representation should foil even the cleverest of optimizers if Tagged_Record(Class_ATAC.To_Pointer( Hex_To_Address(The_Strings(Tagged_Type))).all) /= Tagged_Record'(Value => Natural'Last) then Report.Failed("Tagged_Record reconversion"); end if; Task_ATAC.To_Pointer(Hex_To_Address(The_Strings(Task_Type))).E; begin select -- allow for task to have completed. My_Task.F; -- should not happen, will call Report.Fail in task else null; -- expected case, "Report.Pass;" end select; exception when Tasking_Error => null; -- task terminated, which is OK end; Protected_ATAC.To_Pointer( Hex_To_Address(The_Strings(Protected_Type))).E; My_Prot.F; -- checks that call to E occurred -- check that the resulting values are equal to the 'Unchecked_Access -- of the value if Class_ATAC.To_Pointer(Hex_To_Address(The_Strings(Tagged_Type))) /= My_Rec'Unchecked_Access then Report.Failed("Tagged_Record Unchecked_Access"); end if; if Task_ATAC.To_Pointer(Hex_To_Address(The_Strings(Task_Type))) /= My_Task'Unchecked_Access then Report.Failed("Task Unchecked_Access"); end if; if Protected_ATAC.To_Pointer( Hex_To_Address(The_Strings(Protected_Type))) /= My_Prot'Unchecked_Access then Report.Failed("Protected Unchecked_Access"); end if; Report.Result;end CD72A02;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?