1 /* do not edit automatically generated by mc from Indexing. */
2 /* Indexing.def provides a dynamic indexing mechanism for CARDINAL.
4 Copyright (C) 2003-2021 Free Software Foundation, Inc.
5 Contributed by Gaius Mulley <gaius.mulley@southwales.ac.uk>.
7 This file is part of GNU Modula-2.
9 GNU Modula-2 is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3, or (at your option)
14 GNU Modula-2 is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 General Public License for more details.
19 Under Section 7 of GPL version 3, you are granted additional
20 permissions described in the GCC Runtime Library Exception, version
21 3.1, as published by the Free Software Foundation.
23 You should have received a copy of the GNU General Public License and
24 a copy of the GCC Runtime Library Exception along with this program;
25 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
26 <http://www.gnu.org/licenses/>. */
29 #if !defined (_Indexing_H)
37 # if !defined (PROC_D)
39 typedef void (*PROC_t
) (void);
40 typedef struct { PROC_t proc
; } PROC
;
45 # if defined (_Indexing_C)
48 # define EXTERN extern
51 #if !defined (Indexing_Index_D)
52 # define Indexing_Index_D
53 typedef void *Indexing_Index
;
56 typedef struct Indexing_IndexProcedure_p Indexing_IndexProcedure
;
58 typedef void (*Indexing_IndexProcedure_t
) (void *);
59 struct Indexing_IndexProcedure_p
{ Indexing_IndexProcedure_t proc
; };
63 InitIndex - creates and returns an Index.
66 EXTERN Indexing_Index
Indexing_InitIndex (unsigned int low
);
69 KillIndex - returns Index to free storage.
72 EXTERN Indexing_Index
Indexing_KillIndex (Indexing_Index i
);
75 DebugIndex - turns on debugging within an index.
78 EXTERN Indexing_Index
Indexing_DebugIndex (Indexing_Index i
);
81 InBounds - returns TRUE if indice, n, is within the bounds
85 EXTERN
unsigned int Indexing_InBounds (Indexing_Index i
, unsigned int n
);
88 HighIndice - returns the last legally accessible indice of this array.
91 EXTERN
unsigned int Indexing_HighIndice (Indexing_Index i
);
94 LowIndice - returns the first legally accessible indice of this array.
97 EXTERN
unsigned int Indexing_LowIndice (Indexing_Index i
);
100 PutIndice - places, a, into the dynamic array at position i[n]
103 EXTERN
void Indexing_PutIndice (Indexing_Index i
, unsigned int n
, void * a
);
106 GetIndice - retrieves, element i[n] from the dynamic array.
109 EXTERN
void * Indexing_GetIndice (Indexing_Index i
, unsigned int n
);
112 IsIndiceInIndex - returns TRUE if, a, is in the index, i.
115 EXTERN
unsigned int Indexing_IsIndiceInIndex (Indexing_Index i
, void * a
);
118 RemoveIndiceFromIndex - removes, a, from Index, i.
121 EXTERN
void Indexing_RemoveIndiceFromIndex (Indexing_Index i
, void * a
);
124 DeleteIndice - delete i[j] from the array.
127 EXTERN
void Indexing_DeleteIndice (Indexing_Index i
, unsigned int j
);
130 IncludeIndiceIntoIndex - if the indice is not in the index, then
134 EXTERN
void Indexing_IncludeIndiceIntoIndex (Indexing_Index i
, void * a
);
137 ForeachIndiceInIndexDo - for each j indice of i, call procedure p(i[j])
140 EXTERN
void Indexing_ForeachIndiceInIndexDo (Indexing_Index i
, Indexing_IndexProcedure p
);