1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
-------------------------------------------------------------------------------
-- (C) Altran Praxis Limited
-------------------------------------------------------------------------------
--
-- The SPARK toolset is free software; you can redistribute it and/or modify it
-- under terms of the GNU General Public License as published by the Free
-- Software Foundation; either version 3, or (at your option) any later
-- version. The SPARK toolset is distributed in the hope that it will be
-- useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
-- Public License for more details. You should have received a copy of the GNU
-- General Public License distributed with the SPARK toolset; see file
-- COPYING3. If not, go to http://www.gnu.org/licenses for a complete copy of
-- the license.
--
--=============================================================================
--------------------------------------------------------------------------------
--Synopsis: --
-- --
--Package providing a structure in which to store file details, in the form --
--of a full pathname (without extension) and a type, either PlainFile or --
--directory. --
-- --
--To be used in tandem with the Heap data structure, hence the use of --
--Heap.Atom as the array range --
--------------------------------------------------------------------------------
with E_Strings, HeapIndex;
use type E_Strings.Order_Types;
use type HeapIndex.IndexType;
--# inherit E_Strings,
--# HeapIndex,
--# OSFiling;
package FileDetails is
--ListLength : constant Integer := 20000;
--type IndexType is range 0 .. ListLength;
type FileTypes is (PlainFile, Directory, Invalid);
type DataType is private;
--------------------------------------------------------------------------
procedure Add
(Details : in out DataType;
Index : out HeapIndex.IndexType;
Success : out Boolean;
Name : in E_Strings.T;
FileType : in FileTypes);
--# derives Details from *,
--# FileType,
--# Name &
--# Index,
--# Success from Details;
--------------------------------------------------------------------------
procedure Initialize (Details : out DataType);
--# derives Details from ;
--------------------------------------------------------------------------
procedure MarkDirectoryResolved (Details : in out DataType;
Index : in HeapIndex.IndexType);
--# derives Details from *,
--# Index;
--------------------------------------------------------------------------
-- this compares the information given and returns
-- Result is as defined in section 5.4 of the specification
-- it works directly on values rather than on indices into the Details
-- structure so that information can be compared before insertion
-- NOTE : the procedure is successful iff neither Type is Invalid
--
procedure Order
(FirstName : in E_Strings.T;
FirstType : in FileTypes;
SecondName : in E_Strings.T;
SecondType : in FileTypes;
Success : out Boolean;
Result : out E_Strings.Order_Types);
--# derives Result from FirstName,
--# FirstType,
--# SecondName,
--# SecondType &
--# Success from FirstType,
--# SecondType;
--------------------------------------------------------------------------
procedure Retrieve
(Details : in DataType;
Index : in HeapIndex.IndexType;
Success : out Boolean;
Name : out E_Strings.T;
FileType : out FileTypes;
DirectoryIsResolved : out Boolean);
--# derives DirectoryIsResolved,
--# FileType,
--# Name,
--# Success from Details,
--# Index;
private
type DetailsElement is record
Name : E_Strings.T;
FileType : FileTypes;
DirectoryIsResolved : Boolean;
end record;
NullDetailsElement : constant DetailsElement :=
DetailsElement'(Name => E_Strings.Empty_String,
FileType => Invalid,
DirectoryIsResolved => False);
type ElementsArray is array (HeapIndex.IndexType) of DetailsElement;
-- HighMark is the number of the highest allocated atom - zero if the
-- structure is empty
type DataType is record
Details : ElementsArray;
HighMark : HeapIndex.IndexType;
end record;
end FileDetails;
|