Ada Programming/Libraries/Ada.Containers.Indefinite Ordered Maps
This language feature is only available from Ada 2005 on.
Ada.Containers.Indefinite_Ordered_Maps is a unit of the Predefined Language Environment since Ada 2005.
Specification
edit-- 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 -- -------------------------------------------------------------------------generic
type
Key_Type (<>)is
private
;type
Element_Type (<>)is
private
;with
function
"<" (Left :in
Key_Type; Right :in
Key_Type)return
Booleanis
<>;with
function
"=" (Left :in
Element_Type; Right :in
Element_Type)return
Booleanis
<>;package
Ada.Containers.Indefinite_Ordered_Mapsis
pragma
Preelaborate (Indefinite_Ordered_Maps);function
Equivalent_Keys (Left :in
Key_Type; Right :in
Key_Type)return
Boolean;type
Mapis
tagged
private
;pragma
Preelaborable_Initialization (Map);type
Cursoris
private
;pragma
Preelaborable_Initialization (Cursor); Empty_Map :constant
Map; No_Element :constant
Cursor;function
"=" (Left :in
Map; Right :in
Map)return
Boolean;function
Length (Container :in
Map)return
Count_Type;function
Is_Empty (Container :in
Map)return
Boolean;procedure
Clear (Container :in
out
Map);function
Key (Position :in
Cursor)return
Key_Type;function
Element (Position :in
Cursor)return
Element_Type;procedure
Replace_Element (Container :in
out
Map; Position :in
Cursor; New_Item :in
Element_Type);procedure
Query_Element (Position :in
Cursor; Process :not
null
access
procedure
(Key :in
Key_Type; Element :in
Element_Type));procedure
Update_Element (Container :in
out
Map; Position :in
Cursor; Process :not
null
access
procedure
(Key :in
Key_Type; Element :in
out
Element_Type));procedure
Move (Target :in
out
Map; Source :in
out
Map);procedure
Insert (Container :in
out
Map; Key :in
Key_Type; New_Item :in
Element_Type; Position :out
Cursor; Inserted :out
Boolean);procedure
Insert (Container :in
out
Map; Key :in
Key_Type; New_Item :in
Element_Type);procedure
Include (Container :in
out
Map; Key :in
Key_Type; New_Item :in
Element_Type);procedure
Replace (Container :in
out
Map; Key :in
Key_Type; New_Item :in
Element_Type);procedure
Exclude (Container :in
out
Map; Key :in
Key_Type);procedure
Delete (Container :in
out
Map; Key :in
Key_Type);procedure
Delete (Container :in
out
Map; Position :in
out
Cursor);procedure
Delete_First (Container :in
out
Map);procedure
Delete_Last (Container :in
out
Map);function
First (Container :in
Map)return
Cursor;function
First_Element (Container :in
Map)return
Element_Type;function
First_Key (Container :in
Map)return
Key_Type;function
Last (Container :in
Map)return
Cursor;function
Last_Element (Container :in
Map)return
Element_Type;function
Last_Key (Container :in
Map)return
Key_Type;function
Next (Position :in
Cursor)return
Cursor;procedure
Next (Position :in
out
Cursor);function
Previous (Position :in
Cursor)return
Cursor;procedure
Previous (Position :in
out
Cursor);function
Find (Container :in
Map; Key :in
Key_Type)return
Cursor;function
Element (Container :in
Map; Key :in
Key_Type)return
Element_Type;function
Floor (Container :in
Map; Key :in
Key_Type)return
Cursor;function
Ceiling (Container :in
Map; Key :in
Key_Type)return
Cursor;function
Contains (Container :in
Map; Key :in
Key_Type)return
Boolean;function
Has_Element (Position :in
Cursor)return
Boolean;function
"<" (Left :in
Cursor; Right :in
Cursor)return
Boolean;function
">" (Left :in
Cursor; Right :in
Cursor)return
Boolean;function
"<" (Left :in
Cursor; Right :in
Key_Type)return
Boolean;function
">" (Left :in
Cursor; Right :in
Key_Type)return
Boolean;function
"<" (Left :in
Key_Type; Right :in
Cursor)return
Boolean;function
">" (Left :in
Key_Type; Right :in
Cursor)return
Boolean;procedure
Iterate (Container :in
Map; Process :not
null
access
procedure
(Position :in
Cursor));procedure
Reverse_Iterate (Container :in
Map; Process :not
null
access
procedure
(Position :in
Cursor));private
type
Mapis
tagged
null
record
; Empty_Map :constant
Map := (null
record
);type
Cursoris
null
record
; No_Element :constant
Cursor := (null
record
);end
Ada.Containers.Indefinite_Ordered_Maps;
See also
editWikibook
editExternal examples
edit- Search for examples of
Ada.Containers.Indefinite_Ordered_Maps
in: Rosetta Code, GitHub (gists), any Alire crate or this Wikibook. - Search for posts related to
Ada.Containers.Indefinite_Ordered_Maps
in: Stack Overflow, comp.lang.ada or any Ada related page.
Ada Reference Manual
editAda 2005
editAda 2012
editOpen-Source Implementations
editFSF GNAT
- Specification: a-ciorma.ads
- Body: a-ciorma.adb
drake
- Specification: containers/a-ciorma.ads
- Body: containers/a-ciorma.adb