URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [cxa/] [cxa3001.a] - Rev 720
Compare with Previous | Blame | View Log
-- CXA3001.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 character classification functions defined in-- package Ada.Characters.Handling produce correct results when provided-- constant arguments from package Ada.Characters.Latin_1.---- TEST DESCRIPTION:-- This test checks the character classification functions of package-- Ada.Characters.Handling. In the evaluation of each function, loops-- are constructed to examine the function with as many values of type-- Character (Ada.Characters.Latin_1 constants) as possible in an-- amount of code that is about equal to the amount of code required-- to examine the function with a few representative input values and-- endpoint values.-- The usage paradigm being demonstrated by this test is that of the-- functions being used to assign to boolean variables, as well as-- serving as boolean conditions.------ CHANGE HISTORY:-- 06 Dec 94 SAIC ACVC 2.0-- 29 Apr 95 SAIC Fixed subtest checking Is_Graphic function.----!with Ada.Characters.Latin_1;with Ada.Characters.Handling;with Report;procedure CXA3001 isbeginReport.Test ("CXA3001", "Check that the character classification " &"functions defined in package " &"Ada.Characters.Handling produce " &"correct results when provided constant " &"arguments from package Ada.Characters.Latin_1");Test_Block:declarepackage AC renames Ada.Characters;package ACH renames Ada.Characters.Handling;TC_Boolean : Boolean := False;begin-- Over the next six statements/blocks of code, evaluate functions-- Is_Control and Is_Graphic with control character and non-control-- character values.for i in Character'Pos(AC.Latin_1.NUL) ..Character'Pos(AC.Latin_1.US) loopif not ACH.Is_Control(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Control - 1");end if;if ACH.Is_Graphic(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Graphic - 1");end if;end loop;for i in Character'Pos(AC.Latin_1.Space) ..Character'Pos(AC.Latin_1.Tilde) loopif not ACH.Is_Graphic(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Graphic - 2");end if;if ACH.Is_Control(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Control - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.Reserved_128) ..Character'Pos(AC.Latin_1.APC) loopif not ACH.Is_Control(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Control - 3");end if;TC_Boolean := ACH.Is_Graphic(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect result from function Is_Graphic - 3");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.No_Break_Space) ..Character'Pos(AC.Latin_1.LC_Y_Diaeresis) loopTC_Boolean := ACH.Is_Control(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect result from function Is_Control - 4");TC_Boolean := False;end if;if not ACH.Is_Graphic(Character'Val(i)) thenReport.Failed ("Incorrect result from function Is_Graphic - 4");end if;end loop;-- Check renamed constants.if not (ACH.Is_Control(AC.Latin_1.IS4) andACH.Is_Control(AC.Latin_1.IS3) andACH.Is_Control(AC.Latin_1.IS2) andACH.Is_Control(AC.Latin_1.IS1)) or(ACH.Is_Control(AC.Latin_1.NBSP) orACH.Is_Control(AC.Latin_1.Paragraph_Sign) orACH.Is_Control(AC.Latin_1.Minus_Sign) orACH.Is_Control(AC.Latin_1.Ring_Above))thenReport.Failed ("Incorrect result from function Is_Control - 5");end if;if (ACH.Is_Graphic(AC.Latin_1.IS4) orACH.Is_Graphic(AC.Latin_1.IS3) orACH.Is_Graphic(AC.Latin_1.IS2) orACH.Is_Graphic(AC.Latin_1.IS1)) ornot (ACH.Is_Graphic(AC.Latin_1.NBSP) andACH.Is_Graphic(AC.Latin_1.Paragraph_Sign) andACH.Is_Graphic(AC.Latin_1.Minus_Sign) andACH.Is_Graphic(AC.Latin_1.Ring_Above))thenReport.Failed ("Incorrect result from function Is_Graphic - 5");end if;-- Evaluate function Is_Letter with letter/non-letter inputs.for i in Character'Pos('A') .. Character'Pos('Z') loopif not ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 1");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_A) ..Character'Pos(AC.Latin_1.LC_Z) loopif not ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.UC_A_Grave) ..Character'Pos(AC.Latin_1.UC_O_Diaeresis) loopif not ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 3");end if;end loop;for i in Character'Pos(AC.Latin_1.UC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.LC_O_Diaeresis) loopif not ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 4");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.LC_Y_Diaeresis) loopif not ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 5");end if;end loop;-- Check for rejection of non-letters.for i in Character'Pos(AC.Latin_1.NUL) ..Character'Pos(AC.Latin_1.Commercial_At) loopif ACH.Is_Letter(Character'Val(i)) thenReport.Failed ("Incorrect Is_Letter result - 6");end if;end loop;-- Evaluate function Is_Lower with lower case/non-lower case inputs.for i in Character'Pos(AC.Latin_1.LC_A) ..Character'Pos(AC.Latin_1.LC_Z) loopif not ACH.Is_Lower(Character'Val(i)) thenReport.Failed ("Incorrect Is_Lower result - 1");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_A_Grave) ..Character'Pos(AC.Latin_1.LC_O_Diaeresis) loopif not ACH.Is_Lower(Character'Val(i)) thenReport.Failed ("Incorrect Is_Lower result - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.LC_Y_Diaeresis) loopif not ACH.Is_Lower(Character'Val(i)) thenReport.Failed ("Incorrect Is_Lower result - 3");end if;end loop;if ACH.Is_Lower('A') orACH.Is_Lower(AC.Latin_1.UC_Icelandic_Eth) orACH.Is_Lower(AC.Latin_1.Number_Sign) orACH.Is_Lower(AC.Latin_1.Cedilla) orACH.Is_Lower(AC.Latin_1.SYN) orACH.Is_Lower(AC.Latin_1.ESA)thenReport.Failed ("Incorrect Is_Lower result - 4");end if;-- Evaluate function Is_Upper with upper case/non-upper case inputs.for i in Character'Pos('A') .. Character'Pos('Z') loopif not ACH.Is_Upper(Character'Val(i)) thenReport.Failed ("Incorrect Is_Upper result - 1");end if;end loop;for i in Character'Pos(AC.Latin_1.UC_A_Grave) ..Character'Pos(AC.Latin_1.UC_O_Diaeresis) loopif not ACH.Is_Upper(Character'Val(i)) thenReport.Failed ("Incorrect Is_Upper result - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.UC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.UC_Icelandic_Thorn) loopif not ACH.Is_Upper(Character'Val(i)) thenReport.Failed ("Incorrect Is_Upper result - 3");end if;end loop;if ACH.Is_Upper('8') orACH.Is_Upper(AC.Latin_1.LC_A_Ring ) orACH.Is_Upper(AC.Latin_1.Dollar_Sign) orACH.Is_Upper(AC.Latin_1.Broken_Bar) orACH.Is_Upper(AC.Latin_1.ETB) orACH.Is_Upper(AC.Latin_1.VTS)thenReport.Failed ("Incorrect Is_Upper result - 4");end if;for i in Character'Pos('a') .. Character'Pos('z') loopif ACH.Is_Upper(Character'Val(i)) thenReport.Failed ("Incorrect Is_Upper result - 5");end if;end loop;-- Evaluate function Is_Basic with basic/non-basic inputs.-- (Note: Basic letters are those without diacritical marks.)for i in Character'Pos('A') .. Character'Pos('Z') loopif not ACH.Is_Basic(Character'Val(i)) thenReport.Failed ("Incorrect Is_Basic result - 1");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_A) ..Character'Pos(AC.Latin_1.LC_Z) loopif not ACH.Is_Basic(Character'Val(i)) thenReport.Failed ("Incorrect Is_Basic result - 2");end if;end loop;if not (ACH.Is_Basic(AC.Latin_1.UC_AE_Diphthong) andACH.Is_Basic(AC.Latin_1.LC_AE_Diphthong) andACH.Is_Basic(AC.Latin_1.LC_German_Sharp_S) andACH.Is_Basic(AC.Latin_1.LC_Icelandic_Eth) andACH.Is_Basic(AC.Latin_1.LC_Icelandic_Thorn) andACH.Is_Basic(AC.Latin_1.UC_Icelandic_Eth) andACH.Is_Basic(AC.Latin_1.UC_Icelandic_Thorn))thenReport.Failed ("Incorrect Is_Basic result - 3");end if;-- Check for rejection of non-basics.if ACH.Is_Basic(AC.Latin_1.UC_A_Tilde) orACH.Is_Basic(AC.Latin_1.LC_A_Grave) orACH.Is_Basic(AC.Latin_1.Ampersand) orACH.Is_Basic(AC.Latin_1.Yen_Sign) orACH.Is_Basic(AC.Latin_1.NAK) orACH.Is_Basic(AC.Latin_1.SS2)thenReport.Failed ("Incorrect Is_Basic result - 4");end if;for i in Character'Pos(AC.Latin_1.NUL) ..Character'Pos(AC.Latin_1.Commercial_At) loopif ACH.Is_Basic(Character'Val(i)) thenReport.Failed ("Incorrect Is_Basic result - 5");end if;end loop;-- Evaluate functions Is_Digit and Is_Decimal_Digit (a rename of-- Is_Digit) with decimal digit/non-digit inputs.if not (ACH.Is_Digit('0') andACH.Is_Decimal_Digit('9')) orACH.Is_Digit ('a') or -- Hex digits.ACH.Is_Decimal_Digit ('f') orACH.Is_Decimal_Digit ('A') orACH.Is_Digit ('F')thenReport.Failed ("Incorrect Is_Digit/Is_Decimal_Digit result - 1");end if;if ACH.Is_Digit (AC.Latin_1.Full_Stop) orACH.Is_Decimal_Digit (AC.Latin_1.Dollar_Sign) orACH.Is_Digit (AC.Latin_1.Number_Sign) orACH.Is_Decimal_Digit (AC.Latin_1.Left_Parenthesis) orACH.Is_Digit (AC.Latin_1.Right_Parenthesis)thenReport.Failed ("Incorrect Is_Digit/Is_Decimal_Digit result - 2");end if;-- Evaluate functions Is_Hexadecimal_Digit with hexadecimal digit and-- non-hexadecimal digit inputs.for i in Character'Pos('0') .. Character'Pos('9') loopif not ACH.Is_Hexadecimal_Digit(Character'Val(i)) thenReport.Failed ("Incorrect Is_Hexadecimal_Digit result - 1");end if;end loop;for i in Character'Pos('A') .. Character'Pos('F') loopif not ACH.Is_Hexadecimal_Digit(Character'Val(i)) thenReport.Failed ("Incorrect Is_Hexadecimal_Digit result - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.LC_A) ..Character'Pos(AC.Latin_1.LC_F) loopif not ACH.Is_Hexadecimal_Digit(Character'Val(i)) thenReport.Failed ("Incorrect Is_Hexadecimal_Digit result - 3");end if;end loop;if ACH.Is_Hexadecimal_Digit (AC.Latin_1.Minus_Sign) orACH.Is_Hexadecimal_Digit (AC.Latin_1.Hyphen) orACH.Is_Hexadecimal_Digit (AC.Latin_1.LC_G) orACH.Is_Hexadecimal_Digit (AC.Latin_1.LC_Z) orACH.Is_Hexadecimal_Digit ('G') orACH.Is_Hexadecimal_Digit (AC.Latin_1.Cent_Sign) orACH.Is_Hexadecimal_Digit (AC.Latin_1.Pound_Sign)thenReport.Failed ("Incorrect Is_HexaDecimal_Digit result - 4");end if;-- Evaluate functions Is_Alphanumeric and Is_Special with-- letters, digits, and non-alphanumeric inputs.for i in Character'Pos(AC.Latin_1.NUL) ..Character'Pos(AC.Latin_1.US) loopif ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 1");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 1");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.Reserved_128) ..Character'Pos(AC.Latin_1.APC) loopTC_Boolean := ACH.Is_Alphanumeric(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Alphanumeric result - 2");TC_Boolean := False;end if;if ACH.Is_Special(Character'Val(i)) thenReport.Failed ("Incorrect Is_Special result - 2");end if;end loop;for i in Character'Pos(AC.Latin_1.Space) ..Character'Pos(AC.Latin_1.Solidus) loopTC_Boolean := ACH.Is_Alphanumeric(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Alphanumeric result - 3");TC_Boolean := False;end if;if not ACH.Is_Special(Character'Val(i)) thenReport.Failed ("Incorrect Is_Special result - 3");end if;end loop;for i in Character'Pos('A') .. Character'Pos('Z') loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 4");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 4");TC_Boolean := False;end if;end loop;for i in Character'Pos('0') .. Character'Pos('9') loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 5");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 5");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.LC_A) ..Character'Pos(AC.Latin_1.LC_Z) loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 6");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 6");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.No_Break_Space) ..Character'Pos(AC.Latin_1.Inverted_Question) loopTC_Boolean := ACH.Is_Alphanumeric(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Alphanumeric result - 7");TC_Boolean := False;end if;if not ACH.Is_Special(Character'Val(i)) thenReport.Failed ("Incorrect Is_Special result - 7");end if;end loop;for i in Character'Pos(AC.Latin_1.UC_A_Grave) ..Character'Pos(AC.Latin_1.UC_O_Diaeresis) loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 8");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 8");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.UC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.LC_O_Diaeresis) loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 9");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 9");TC_Boolean := False;end if;end loop;for i in Character'Pos(AC.Latin_1.LC_O_Oblique_Stroke) ..Character'Pos(AC.Latin_1.LC_Y_Diaeresis) loopif not ACH.Is_Alphanumeric(Character'Val(i)) thenReport.Failed ("Incorrect Is_Alphanumeric result - 10");end if;TC_Boolean := ACH.Is_Special(Character'Val(i));if TC_Boolean thenReport.Failed ("Incorrect Is_Special result - 10");TC_Boolean := False;end if;end loop;exceptionwhen others => Report.Failed ("Exception raised during processing");end Test_Block;Report.Result;end CXA3001;
