⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cxa3003.a

📁 linux下编程用 编译软件
💻 A
字号:
-- CXA3003.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 functions defined in package Ada.Characters.Handling--      for use in classifying and converting characters between the ISO 646--      and type Character sets produce the correct results with both--      Character and String input values.---- TEST DESCRIPTION:--      This test is designed to exercise the classification and conversion--      functions (between Character and ISO_646 types) found in package --      Ada.Characters.Handling.  Two subprograms are defined, a procedure for--      characters, a function for strings, that will utilize these functions--      to validate and change characters in variables.  In the procedure, if--      a character argument is found to be outside the subtype ISO_646, this --      character is evaluated to determine whether it is also a letter.  --      If it is a letter, the character is converted to a basic character and --      returned.  If it is not a letter, the character is exchanged with an --      asterisk.  In the case of the function subprogram designed for strings, --      if a character component of a string argument is outside the subtype--      ISO_646, that character is substituted with an asterisk.--      --      Arguments for the defined subprograms consist of ISO_646 characters,--      non-ISO_646 characters, strings with only ISO_646 characters, and--      strings with non-ISO_646 characters. The character and string values --      are then validated to determine that the expected results were --      obtained.--      --       -- CHANGE HISTORY:--      06 Dec 94   SAIC    ACVC 2.0--      29 Apr 95   SAIC    Modified identifier string lengths.--      31 Oct 95   SAIC    Update and repair for ACVC 2.0.1.----!with Ada.Characters.Latin_1;with Ada.Characters.Handling;with Report;procedure CXA3003 isbegin   Report.Test ("CXA3003", "Check that the functions defined in package " &                           "Ada.Characters.Handling for use in "          &                           "classifying and converting characters "       &                           "between the ISO 646 and type Character sets " &                           "produce the correct results with both "       &                           "Character and String input values" );   Test_Block:   declare      -- ISO_646 Characters      Char_1,      TC_Char_1  : Character := Ada.Characters.Latin_1.NUL;    -- Control Char      Char_2,      TC_Char_2  : Character := Ada.Characters.Latin_1.Colon;  -- Graphic Char      Char_3,      TC_Char_3  : Character := '4';      Char_4,      TC_Char_4  : Character := 'Z';      Char_5,      TC_Char_5  : Character := Ada.Characters.Latin_1.LC_W;   -- w      New_ISO_646_Char : Character := '*';      -- Non-ISO_646 Characters      Char_Array : array (6..10) of Character :=                                        (Ada.Characters.Latin_1.SSA,                                        Ada.Characters.Latin_1.Cent_Sign,                                        Ada.Characters.Latin_1.Cedilla,                                        Ada.Characters.Latin_1.UC_A_Ring,                                        Ada.Characters.Latin_1.LC_A_Ring);      TC_Char : constant Character := '*';      -- ISO_646 Strings      Str_1,       TC_Str_1 : String (1..5) := "ABCDE";      Str_2,      TC_Str_2 : String (1..5) := "#$%^&";      -- Non-ISO_646 Strings      Str_3    : String (1..8) := "$123.45" &                                   Ada.Characters.Latin_1.Cent_Sign;      TC_Str_3 : String (1..8) := "$123.45*";      Str_4    : String (1..7) := "abc" &                                   Ada.Characters.Latin_1.Cedilla &                                  "efg";      TC_Str_4 : String (1..7) := "abc*efg";      Str_5    : String (1..3) := Ada.Characters.Latin_1.LC_E_Grave &                                   Ada.Characters.Latin_1.LC_T       &                                  Ada.Characters.Latin_1.LC_E_Acute;      TC_Str_5 : String (1..3) := "*t*";      ---      procedure Validate_Character (Char : in out Character) is         -- If parameter Char is an ISO_646 character, Char will be returned,         -- otherwise the following constant will be returned.         Star : constant Ada.Characters.Handling.ISO_646 :=            Ada.Characters.Latin_1.Asterisk;                          begin         if Ada.Characters.Handling.Is_ISO_646(Char) then            -- Check that the Is_ISO_646 function provide a correct result.            if Character'Pos(Char) > 127 then               Report.Failed("Is_ISO_646 returns a false positive result");            end if;         else            if Character'Pos(Char) < 128 then               Report.Failed("Is_ISO_646 returns a false negative result");            end if;         end if;         -- Cross-check Is_ISO_646 with To_ISO_646.  '*' will be returned         -- if Char is not in the ISO_646 set.         Char := Ada.Characters.Handling.To_ISO_646(Char, Star);      exception         when others => Report.Failed ("Exception in Validate_Character");      end Validate_Character;      ---      function Validate_String (Str : String) return String is         New_ISO_646_Char : constant Ada.Characters.Handling.ISO_646 :=            Ada.Characters.Latin_1.Asterisk;                          begin         -- Checking that the string contains non-ISO_646 characters at this         -- point is not strictly necessary, since the function To_ISO_646         -- will perform that check as part of its processing, and would          -- return the original string if no modification were necessary.           -- However, this format allows for the testing of both functions.         if not Ada.Characters.Handling.Is_ISO_646(Str) then            return Ada.Characters.Handling.To_ISO_646                     (Item => Str, Substitute => New_ISO_646_Char);         else            return Str;         end if;      exception         when others => Report.Failed ("Exception in Validate_String");                        return Str;      end Validate_String;   begin      -- Check each character in turn, and if the character does not belong      -- to the ISO_646 subset of type Character, replace it with an      -- asterisk.  If the character is a member of the subset, the character      -- should be returned unchanged.      Validate_Character (Char_1);      Validate_Character (Char_2);      Validate_Character (Char_3);      Validate_Character (Char_4);      Validate_Character (Char_5);      if Char_1 /= TC_Char_1 or Char_2 /= TC_Char_2 or         Char_3 /= TC_Char_3 or Char_4 /= TC_Char_4 or         Char_5 /= TC_Char_5      then         Report.Failed ("Incorrect ISO_646 character substitution");      end if;      -- Non-ISO_646 characters      for i in 6..10 loop         Validate_Character (Char_Array(i));      end loop;      for i in 6..10 loop         if Char_Array(i) /= TC_Char then            Report.Failed ("Character position " & Integer'Image(i) &                           " not replaced correctly");         end if;      end loop;      -- Check each string, and if the string contains characters that do not      -- belong to the ISO_646 subset of type Character, replace that character      -- in the string with an asterisk.  If the string is comprised of only      -- ISO_646 characters, the string should be returned unchanged.      Str_1 := Validate_String (Str_1);      Str_2 := Validate_String (Str_2);      Str_3 := Validate_String (Str_3);      Str_4 := Validate_String (Str_4);      Str_5 := Validate_String (Str_5);      if Str_1 /= TC_Str_1 or         Str_2 /= TC_Str_2 or         Str_3 /= TC_Str_3 or         Str_4 /= TC_Str_4 or         Str_5 /= TC_Str_5      then         Report.Failed ("Incorrect ISO_646 character substitution in string");      end if;   exception      when others => Report.Failed ("Exception raised in Test_Block");   end Test_Block;   Report.Result;end CXA3003;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -