blob: cd51ee073c0cc59b44d9f8e98863efe11baeb3c8 [file] [log] [blame]
Jari Aaltof73dda02001-11-13 17:56:06 +00001/* arrayfunc.h -- declarations for miscellaneous array functions in arrayfunc.c */
2
Chet Ramey495aee42011-11-22 19:11:26 -05003/* Copyright (C) 2001-2010 Free Software Foundation, Inc.
Jari Aaltof73dda02001-11-13 17:56:06 +00004
5 This file is part of GNU Bash, the Bourne Again SHell.
6
Jari Aalto31859422009-01-12 13:36:28 +00007 Bash is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
Jari Aaltof73dda02001-11-13 17:56:06 +000011
Jari Aalto31859422009-01-12 13:36:28 +000012 Bash is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
Jari Aaltof73dda02001-11-13 17:56:06 +000016
17 You should have received a copy of the GNU General Public License
Jari Aalto31859422009-01-12 13:36:28 +000018 along with Bash. If not, see <http://www.gnu.org/licenses/>.
19*/
Jari Aaltof73dda02001-11-13 17:56:06 +000020
21#if !defined (_ARRAYFUNC_H_)
22#define _ARRAYFUNC_H_
23
24/* Must include variables.h before including this file. */
25
26#if defined (ARRAY_VARS)
27
Chet Rameyd233b482019-01-07 09:27:52 -050028/* This variable means to not expand associative array subscripts more than
29 once, when performing variable expansion. */
30extern int assoc_expand_once;
31
32/* The analog for indexed array subscripts */
33extern int array_expand_once;
34
Chet Ramey495aee42011-11-22 19:11:26 -050035/* Flags for array_value_internal and callers array_value/get_array_value */
36#define AV_ALLOWALL 0x001
37#define AV_QUOTED 0x002
38#define AV_USEIND 0x004
Chet Rameya0c0a002016-09-15 16:59:08 -040039#define AV_USEVAL 0x008 /* XXX - should move this */
40#define AV_ASSIGNRHS 0x010 /* no splitting, special case ${a[@]} */
Chet Rameyd233b482019-01-07 09:27:52 -050041#define AV_NOEXPAND 0x020 /* don't run assoc subscripts through word expansion */
42
43/* Flags for valid_array_reference. Value 1 is reserved for skipsubscript() */
44#define VA_NOEXPAND 0x001
45#define VA_ONEWORD 0x002
Chet Ramey495aee42011-11-22 19:11:26 -050046
Jari Aaltof73dda02001-11-13 17:56:06 +000047extern SHELL_VAR *convert_var_to_array __P((SHELL_VAR *));
Jari Aalto31859422009-01-12 13:36:28 +000048extern SHELL_VAR *convert_var_to_assoc __P((SHELL_VAR *));
Jari Aaltof73dda02001-11-13 17:56:06 +000049
Chet Rameyac50fba2014-02-26 09:36:43 -050050extern char *make_array_variable_value __P((SHELL_VAR *, arrayind_t, char *, char *, int));
51
Jari Aalto95732b42005-12-07 14:08:12 +000052extern SHELL_VAR *bind_array_variable __P((char *, arrayind_t, char *, int));
Jari Aalto31859422009-01-12 13:36:28 +000053extern SHELL_VAR *bind_array_element __P((SHELL_VAR *, arrayind_t, char *, int));
Jari Aalto95732b42005-12-07 14:08:12 +000054extern SHELL_VAR *assign_array_element __P((char *, char *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +000055
Chet Ramey00018032011-11-21 20:51:19 -050056extern SHELL_VAR *bind_assoc_variable __P((SHELL_VAR *, char *, char *, char *, int));
57
Jari Aaltof73dda02001-11-13 17:56:06 +000058extern SHELL_VAR *find_or_make_array_variable __P((char *, int));
59
Jari Aalto95732b42005-12-07 14:08:12 +000060extern SHELL_VAR *assign_array_from_string __P((char *, char *, int));
61extern SHELL_VAR *assign_array_var_from_word_list __P((SHELL_VAR *, WORD_LIST *, int));
Jari Aalto06285672006-10-10 14:15:34 +000062
Jari Aalto31859422009-01-12 13:36:28 +000063extern WORD_LIST *expand_compound_array_assignment __P((SHELL_VAR *, char *, int));
Jari Aalto06285672006-10-10 14:15:34 +000064extern void assign_compound_array_list __P((SHELL_VAR *, WORD_LIST *, int));
Jari Aalto95732b42005-12-07 14:08:12 +000065extern SHELL_VAR *assign_array_var_from_string __P((SHELL_VAR *, char *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +000066
Chet Rameyd233b482019-01-07 09:27:52 -050067extern int unbind_array_element __P((SHELL_VAR *, char *, int));
Chet Ramey00018032011-11-21 20:51:19 -050068extern int skipsubscript __P((const char *, int, int));
Jari Aalto31859422009-01-12 13:36:28 +000069
Jari Aaltof73dda02001-11-13 17:56:06 +000070extern void print_array_assignment __P((SHELL_VAR *, int));
Jari Aalto31859422009-01-12 13:36:28 +000071extern void print_assoc_assignment __P((SHELL_VAR *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +000072
Chet Rameyd233b482019-01-07 09:27:52 -050073extern arrayind_t array_expand_index __P((SHELL_VAR *, char *, int, int));
Chet Rameya0c0a002016-09-15 16:59:08 -040074extern int valid_array_reference __P((const char *, int));
75extern char *array_value __P((const char *, int, int, int *, arrayind_t *));
76extern char *get_array_value __P((const char *, int, int *, arrayind_t *));
Jari Aaltof73dda02001-11-13 17:56:06 +000077
Jari Aaltob80f6442004-07-27 13:29:18 +000078extern char *array_keys __P((char *, int));
79
Chet Rameyd233b482019-01-07 09:27:52 -050080extern char *array_variable_name __P((const char *, int, char **, int *));
81extern SHELL_VAR *array_variable_part __P((const char *, int, char **, int *));
Jari Aaltof73dda02001-11-13 17:56:06 +000082
Chet Rameyac50fba2014-02-26 09:36:43 -050083#else
84
85#define AV_ALLOWALL 0
86#define AV_QUOTED 0
87#define AV_USEIND 0
Chet Rameya0c0a002016-09-15 16:59:08 -040088#define AV_ASSIGNRHS 0
Chet Rameyac50fba2014-02-26 09:36:43 -050089
Chet Rameyd233b482019-01-07 09:27:52 -050090#define VA_ONEWORD 0
91
Jari Aaltof73dda02001-11-13 17:56:06 +000092#endif
93
94#endif /* !_ARRAYFUNC_H_ */