1 /* do not edit automatically generated by mc from Indexing. */
2 /* Indexing.def provides a dynamic indexing mechanism for CARDINAL.
4 Copyright (C) 2003-2024 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)
38 # if !defined (PROC_D)
40 typedef void (*PROC_t
) (void);
41 typedef struct { PROC_t proc
; } PROC
;
46 # if defined (_Indexing_C)
49 # define EXTERN extern
52 #if !defined (Indexing_Index_D)
53 # define Indexing_Index_D
54 typedef void *Indexing_Index
;
57 typedef struct Indexing_IndexProcedure_p Indexing_IndexProcedure
;
59 typedef void (*Indexing_IndexProcedure_t
) (void *);
60 struct Indexing_IndexProcedure_p
{ Indexing_IndexProcedure_t proc
; };
64 InitIndex - creates and returns an Index.
67 EXTERN Indexing_Index
Indexing_InitIndex (unsigned int low
);
70 KillIndex - returns Index to free storage.
73 EXTERN Indexing_Index
Indexing_KillIndex (Indexing_Index i
);
76 DebugIndex - turns on debugging within an index.
79 EXTERN Indexing_Index
Indexing_DebugIndex (Indexing_Index i
);
82 InBounds - returns TRUE if indice, n, is within the bounds
86 EXTERN
bool Indexing_InBounds (Indexing_Index i
, unsigned int n
);
89 HighIndice - returns the last legally accessible indice of this array.
92 EXTERN
unsigned int Indexing_HighIndice (Indexing_Index i
);
95 LowIndice - returns the first legally accessible indice of this array.
98 EXTERN
unsigned int Indexing_LowIndice (Indexing_Index i
);
101 PutIndice - places, a, into the dynamic array at position i[n]
104 EXTERN
void Indexing_PutIndice (Indexing_Index i
, unsigned int n
, void * a
);
107 GetIndice - retrieves, element i[n] from the dynamic array.
110 EXTERN
void * Indexing_GetIndice (Indexing_Index i
, unsigned int n
);
113 IsIndiceInIndex - returns TRUE if, a, is in the index, i.
116 EXTERN
bool Indexing_IsIndiceInIndex (Indexing_Index i
, void * a
);
119 RemoveIndiceFromIndex - removes, a, from Index, i.
122 EXTERN
void Indexing_RemoveIndiceFromIndex (Indexing_Index i
, void * a
);
125 DeleteIndice - delete i[j] from the array.
128 EXTERN
void Indexing_DeleteIndice (Indexing_Index i
, unsigned int j
);
131 IncludeIndiceIntoIndex - if the indice is not in the index, then
135 EXTERN
void Indexing_IncludeIndiceIntoIndex (Indexing_Index i
, void * a
);
138 ForeachIndiceInIndexDo - for each j indice of i, call procedure p(i[j])
141 EXTERN
void Indexing_ForeachIndiceInIndexDo (Indexing_Index i
, Indexing_IndexProcedure p
);