
This language feature is available from Ada 95 on. Ada.Sequential_IO is a unit of the Predefined Language Environment since Ada 95.
Background
Not all data read or written is in text format. For storage or inter-process communication, it is more space- and processing time-efficient to store data in binary format.
Binary input and output for sequential data (that is, read/written one after another) is managed by the generic Ada package Ada.Sequential_IO.
The generic package must be instantiated with some Element_Type, and provides a limited private File_Type.
The file mode, In_File or Out_File, is established on open or create.
The package provides the basic input/output (I/O) operations:
Open,CreateClose,Delete, andResetRead,Write
In addition, the package provides status and information functions:
Is_OpenEnd_Of_FileName,Mode, andForm
One important restriction is that every element of a file must be the same element type.
Ada Code Example
For example, suppose that a student has collected information on trees in a 10 meter by 10 meter plot, and wishes a report generated from the data.
The following is a simple program to read the sequential data, previously recorded:
withAda.Text_IO; -- Text I/O librarywithAda.Float_Text_IO; -- Float I/O librarywithAda.Sequential_IO; -- Sequential I/O libraryprocedureTree_Reportis-- First, define the contents of the data recordtypeTree_RecordisrecordCommon_Name : String(1..20) := (others=> ' '); Scientific_Name : String(1..20) := (others=> ' '); Diameter : Float := 0.0; -- at breast height (DBH)endrecord; -- Tree_Record -- Now, instantiate the I/O package for the data recordpackageTree_IOisnewAda.Sequential_IO(Tree_Record); Tree_File : Tree_IO.File_Type; -- Input data file Tree_Data : Tree_Record; -- Individual data recordbegin-- Tree_Report -- Open the input data file. Tree_IO.Open(File => Tree_File, Mode => Tree_IO.In_File, Name => "tree.dat"); -- Write report heading Ada.Text_IO.Set_Col(To => 1); Ada.Text_IO.Put("COMMON NAME"); Ada.Text_IO.Set_Col(To => 21); Ada.Text_IO.Put("SCIENTIFIC NAME"); Ada.Text_IO.Set_Col(To => 41); Ada.Text_IO.Put("DBH"); Ada.Text_IO.New_Line; Process_Tree_Data:whilenotTree_IO.End_Of_File(Tree_File)loopTree_IO.Read(Tree_File, Tree_Data); -- Read tree data -- Write tree inventory Ada.Text_IO.Put(Tree_Data.Common_Name); Ada.Text_IO.Put(Tree_Data.Scientific_Name); Ada.Float_Text_IO.Put(Tree_Data.Diameter,Fore=>2,Aft=>2,Exp=>0); Ada.Text_IO.New_Line;endloopProcess_Tree_Data; -- All data records have been read, and end_of_file detected. Tree_IO.Close(Tree_File); -- Done, close fileendTree_Report;
Specification
-- Standard Ada library specification -- Copyright (c) 2003-2018 Maxim Reznik <reznikmm@gmail.com> -- Copyright (c) 2004-2016 AXE Consultants -- Copyright (c) 2004, 2005, 2006 Ada-Europe -- Copyright (c) 2000 The MITRE Corporation, Inc. -- Copyright (c) 1992, 1993, 1994, 1995 Intermetrics, Inc. -- SPDX-License-Identifier: BSD-3-Clause and LicenseRef-AdaReferenceManual -- -------------------------------------------------------------------------withAda.IO_Exceptions;generictypeElement_Type (<>)isprivate;packageAda.Sequential_IOistypeFile_Typeislimitedprivate;typeFile_Modeis(In_File, Out_File, Append_File); -- File managementprocedureCreate (File :inoutFile_Type; Mode :inFile_Mode := Out_File; Name :inString := ""; Form :inString := "");procedureOpen (File :inoutFile_Type; Mode :inFile_Mode; Name :inString; Form :inString := "");procedureClose (File :inoutFile_Type);procedureDelete (File :inoutFile_Type);procedureReset (File :inoutFile_Type; Mode :inFile_Mode);procedureReset (File :inoutFile_Type);functionMode (File :inFile_Type)returnFile_Mode;functionName (File :inFile_Type)returnString;functionForm (File :inFile_Type)returnString;functionIs_Open (File :inFile_Type)returnBoolean; -- Input and output operationsprocedureRead (File :inFile_Type; Item :outElement_Type);procedureWrite (File :inFile_Type; Item :inElement_Type);functionEnd_Of_File (File :inFile_Type)returnBoolean; -- Exceptions Status_Error :exceptionrenamesIO_Exceptions.Status_Error; Mode_Error :exceptionrenamesIO_Exceptions.Mode_Error; Name_Error :exceptionrenamesIO_Exceptions.Name_Error; Use_Error :exceptionrenamesIO_Exceptions.Use_Error; Device_Error :exceptionrenamesIO_Exceptions.Device_Error; End_Error :exceptionrenamesIO_Exceptions.End_Error; Data_Error :exceptionrenamesIO_Exceptions.Data_Error;privatetypeFile_Typeislimitednullrecord;endAda.Sequential_IO;
See also
Wikibook
External examples
- Search for examples of
Ada.Sequential_IOin: Rosetta Code, GitHub or this Wikibook. - Search for any post related to
Ada.Sequential_IOin: Stack Overflow, comp.lang.ada or any Ada related page.
Ada Reference Manual
Ada 95
Ada 2005
Ada 2012
Open-Source Implementations
FSF GNAT
- Specification: a-sequio.ads
- Body: a-sequio.adb
drake
- Specification: streams/a-sequio.ads
- Body: streams/a-sequio.adb