| -- CXAA002.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 procedures New_Page, Set_Line, Set_Col, and New_Line |
| -- subprograms perform properly on a text file created with mode |
| -- Append_File. |
| -- Check that the attributes Page, Line, and Column are all set to 1 |
| -- following the creation of a text file with mode Append_File. |
| -- Check that the functions Page, Line, and Col perform properly on a |
| -- text file created with mode Append_File. |
| -- Check that the procedures Put and Put_Line perform properly on text |
| -- files created with mode Append_File. |
| -- Check that the procedure Set_Line sets the current line number to |
| -- the value specified by the parameter "To" for text files created with |
| -- mode Append_File. |
| -- Check that the procedure Set_Col sets the current column number to |
| -- the value specified by the parameter "To" for text files created with |
| -- mode Append_File. |
| -- |
| -- TEST DESCRIPTION: |
| -- This test is designed to simulate the text processing that could |
| -- occur with files that have been created in Append_File mode. Various |
| -- calls to Text_IO formatting subprograms are called to properly |
| -- position text appended to a document. The text content and position |
| -- are subsequently verified for accuracy. |
| -- |
| -- APPLICABILITY CRITERIA: |
| -- This test is applicable only to implementations that support text |
| -- files. |
| -- |
| -- |
| -- CHANGE HISTORY: |
| -- 06 Dec 94 SAIC ACVC 2.0 |
| -- 27 Feb 97 PWB.CTA Allowed for non-support of some IO operations |
| |
| --! |
| |
| with Ada.Text_IO; |
| with Report; |
| |
| procedure CXAA002 is |
| use Ada; |
| Data_File : Text_IO.File_Type; |
| Data_Filename : constant String := |
| Report.Legal_File_Name ( Nam => "CXAA002" ); |
| Incomplete : exception; |
| begin |
| |
| Report.Test ("CXAA002", "Check that page, line, and column formatting " & |
| "subprograms perform properly on text files " & |
| "created with mode Append_File"); |
| |
| Test_for_Text_IO_Support: |
| begin |
| |
| -- An implementation that does not support Text_IO in a particular |
| -- environment will raise Use_Error on calls to various |
| -- Text_IO operations. This block statement encloses a call to |
| -- Create, which should raise the exception in a non-supportive |
| -- environment. This exception will be handled to produce a |
| -- Not_Applicable result. |
| |
| Text_IO.Create (File => Data_File, |
| Mode => Text_IO.Append_File, |
| Name => Data_Filename); |
| |
| exception |
| |
| when Text_IO.Use_Error | Text_IO.Name_Error => |
| Report.Not_Applicable |
| ( "Files not supported - Create as Append_File for Text_IO" ); |
| raise Incomplete; |
| |
| end Test_for_Text_IO_Support; |
| |
| Operational_Test_Block: |
| declare |
| Default_Position : constant Text_IO.Positive_Count := 1; |
| Section_Header : constant String := "VII. "; |
| Appendix_Title : constant String := "Appendix A"; |
| Appendix_Content : constant String := "TBD"; |
| |
| -- The following procedure simulates the addition of an Appendix page |
| -- to an existing text file. |
| procedure Position_Appendix_Text is |
| use Text_IO; -- To provide visibility to the "/=" operator. |
| begin |
| |
| -- Test control code. |
| -- Verify initial page, line, column number. |
| if "/="(Text_IO.Page (Data_File), Default_Position) then |
| Report.Failed ("Incorrect default page number"); |
| end if; |
| if Text_IO.Line (Data_File) /= Default_Position then |
| Report.Failed ("Incorrect default line number"); |
| end if; |
| if "/="(Text_IO.Col (Data_File), Default_Position) then |
| Report.Failed ("Incorrect default column number"); |
| end if; |
| |
| -- Simulated usage code. |
| -- Set new page/line positions. |
| Text_IO.Put_Line |
| (Data_File, "Add some optional data to the file here"); |
| Text_IO.New_Page (Data_File); |
| Text_IO.New_Line (File => Data_File, Spacing => 2); |
| |
| -- Test control code. |
| if Integer(Text_IO.Page (Data_File)) /= Report.Ident_Int(2) or else |
| Integer(Text_IO.Line (Data_File)) /= Report.Ident_Int(3) then |
| Report.Failed ("Incorrect results from page/line positioning"); |
| end if; |
| |
| -- Simulated usage code. |
| Text_IO.Put (Data_File, Section_Header); -- Position title |
| Text_IO.Put_Line (Data_File, Appendix_Title); -- of Appendix. |
| |
| Text_IO.Set_Line (File => Data_File, To => 5); -- Set new |
| Text_IO.Set_Col (File => Data_File, To => 8); -- position. |
| |
| -- Test control code. |
| if (Integer(Text_IO.Line (Data_File)) /= Report.Ident_Int(5)) or |
| (Integer(Text_IO.Col (Data_File)) /= Report.Ident_Int(8)) then |
| Report.Failed ("Incorrect results from line/column positioning"); |
| end if; |
| |
| -- Simulated usage code. -- Position |
| Text_IO.Put_Line (Data_File, Appendix_Content); -- content of |
| -- Appendix. |
| end Position_Appendix_Text; |
| |
| begin |
| |
| -- This code section simulates a scenario that could occur in a |
| -- text processing environment: |
| -- A document is created/modified/edited Then... |
| -- Text is to be appended to the document. |
| -- A procedure is called to perform that operation. |
| -- The position on the appended page is set, verified, and text is |
| -- appended to the existing file. |
| -- |
| -- Note: The text file has been originally created in Append_File |
| -- mode, and has not been closed prior to this processing. |
| |
| Position_Appendix_Text; |
| |
| Test_Verification_Block: |
| declare |
| TC_Page, |
| TC_Line, |
| TC_Column : Text_IO.Positive_Count; |
| TC_Position : Natural := 0; |
| Blanks : constant String := " "; |
| TC_String : String (1 .. 17) := Blanks; |
| begin |
| |
| Reset1: |
| begin |
| Text_IO.Reset (Data_File, Text_IO.In_File); |
| exception |
| when Text_IO.Use_Error => |
| Report.Not_Applicable |
| ( "Reset to In_File not supported for Text_IO" ); |
| raise Incomplete; |
| end Reset1; |
| |
| Text_IO.Skip_Page (Data_File); |
| -- Loop to the third line |
| for I in 1 .. 3 loop -- and read the contents. |
| Text_IO.Get_Line (Data_File, TC_String, TC_Position); |
| end loop; |
| |
| if (TC_Position /= 16) or else -- Verify the title line. |
| (TC_String (1..4) /= "VII.") or else |
| (TC_String (3..16) /= ("I. " & Appendix_Title)) then |
| Report.Failed ("Incorrect positioning of title line"); |
| end if; |
| |
| TC_String := Blanks; -- Clear string. |
| -- Loop to the fifth line |
| for I in 4 .. 5 loop -- and read the contents. |
| Text_IO.Get_Line (Data_File, TC_String, TC_Position); |
| end loop; |
| |
| if (TC_Position /= 10) or -- Verify the contents. |
| (TC_String (8..10) /= Appendix_Content) then |
| Report.Failed ("Incorrect positioning of contents line"); |
| end if; |
| |
| exception |
| |
| when Incomplete => |
| raise; |
| |
| when others => |
| Report.Failed ("Error raised during data verification"); |
| |
| end Test_Verification_Block; |
| |
| exception |
| |
| when Incomplete => |
| raise; |
| |
| when others => |
| Report.Failed ("Exception raised during Text_IO processing"); |
| |
| end Operational_Test_Block; |
| |
| Deletion: |
| begin |
| -- Delete the external file. |
| if Text_IO.Is_Open(Data_File) then |
| Text_IO.Delete(Data_File); |
| else |
| Text_IO.Open(Data_File, Text_IO.In_File, Data_Filename); |
| Text_IO.Delete(Data_File); |
| end if; |
| exception |
| when others => |
| Report.Failed |
| ( "Delete not properly implemented for Text_IO" ); |
| end Deletion; |
| |
| Report.Result; |
| |
| exception |
| when Incomplete => |
| Report.Result; |
| when others => |
| Report.Failed ( "Unexpected exception" ); |
| Report.Result; |
| |
| end CXAA002; |