blob: 69112b579cd23a22f1b93233178235841eb19a76 [file] [log] [blame]
Jari Aaltof73dda02001-11-13 17:56:06 +00001/* arrayfunc.h -- declarations for miscellaneous array functions in arrayfunc.c */
2
Chet Ramey74091dd2022-09-26 11:49:46 -04003/* Copyright (C) 2001-2021 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
Chet Ramey74091dd2022-09-26 11:49:46 -040026/* An object to encapsulate the state of an array element. It can describe
27 an array assignment A[KEY]=VALUE or a[IND]=VALUE depending on TYPE, or
28 for passing array subscript references around, where VALUE would be
29 ${a[IND]} or ${A[KEY]}. This is not dependent on ARRAY_VARS so we can
30 use it in function parameters. */
31
32/* values for `type' field */
33#define ARRAY_INVALID -1
34#define ARRAY_SCALAR 0
35#define ARRAY_INDEXED 1
36#define ARRAY_ASSOC 2
37
38/* KEY will contain allocated memory if called through the assign_array_element
39 code path because of how assoc_insert works. */
40typedef struct element_state
41{
42 short type; /* assoc or indexed, says which fields are valid */
43 short subtype; /* `*', `@', or something else */
44 arrayind_t ind;
45 char *key; /* can be allocated memory */
46 char *value;
47} array_eltstate_t;
48
Jari Aaltof73dda02001-11-13 17:56:06 +000049#if defined (ARRAY_VARS)
50
Chet Rameyd233b482019-01-07 09:27:52 -050051/* This variable means to not expand associative array subscripts more than
52 once, when performing variable expansion. */
53extern int assoc_expand_once;
54
55/* The analog for indexed array subscripts */
56extern int array_expand_once;
57
Chet Ramey74091dd2022-09-26 11:49:46 -040058/* Flags for array_value_internal and callers array_value/get_array_value; also
59 used by array_variable_name and array_variable_part. */
60#define AV_ALLOWALL 0x001 /* treat a[@] like $@ and a[*] like $* */
Chet Ramey495aee42011-11-22 19:11:26 -050061#define AV_QUOTED 0x002
62#define AV_USEIND 0x004
Chet Rameya0c0a002016-09-15 16:59:08 -040063#define AV_USEVAL 0x008 /* XXX - should move this */
64#define AV_ASSIGNRHS 0x010 /* no splitting, special case ${a[@]} */
Chet Rameyd233b482019-01-07 09:27:52 -050065#define AV_NOEXPAND 0x020 /* don't run assoc subscripts through word expansion */
Chet Ramey74091dd2022-09-26 11:49:46 -040066#define AV_ONEWORD 0x040 /* not used yet */
67#define AV_ATSTARKEYS 0x080 /* accept a[@] and a[*] but use them as keys, not special values */
Chet Rameyd233b482019-01-07 09:27:52 -050068
Chet Ramey74091dd2022-09-26 11:49:46 -040069/* Flags for valid_array_reference. Value 1 is reserved for skipsubscript().
70 Also used by unbind_array_element, which is currently the only function
71 that uses VA_ALLOWALL. */
Chet Rameyd233b482019-01-07 09:27:52 -050072#define VA_NOEXPAND 0x001
73#define VA_ONEWORD 0x002
Chet Ramey74091dd2022-09-26 11:49:46 -040074#define VA_ALLOWALL 0x004 /* allow @ to mean all elements of the array */
Chet Ramey495aee42011-11-22 19:11:26 -050075
Chet Ramey8868eda2020-12-06 15:51:17 -050076extern SHELL_VAR *convert_var_to_array PARAMS((SHELL_VAR *));
77extern SHELL_VAR *convert_var_to_assoc PARAMS((SHELL_VAR *));
Jari Aaltof73dda02001-11-13 17:56:06 +000078
Chet Ramey8868eda2020-12-06 15:51:17 -050079extern char *make_array_variable_value PARAMS((SHELL_VAR *, arrayind_t, char *, char *, int));
Chet Rameyac50fba2014-02-26 09:36:43 -050080
Chet Ramey8868eda2020-12-06 15:51:17 -050081extern SHELL_VAR *bind_array_variable PARAMS((char *, arrayind_t, char *, int));
82extern SHELL_VAR *bind_array_element PARAMS((SHELL_VAR *, arrayind_t, char *, int));
Chet Ramey74091dd2022-09-26 11:49:46 -040083extern SHELL_VAR *assign_array_element PARAMS((char *, char *, int, array_eltstate_t *));
Jari Aaltof73dda02001-11-13 17:56:06 +000084
Chet Ramey8868eda2020-12-06 15:51:17 -050085extern SHELL_VAR *bind_assoc_variable PARAMS((SHELL_VAR *, char *, char *, char *, int));
Chet Ramey00018032011-11-21 20:51:19 -050086
Chet Ramey8868eda2020-12-06 15:51:17 -050087extern SHELL_VAR *find_or_make_array_variable PARAMS((char *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +000088
Chet Ramey8868eda2020-12-06 15:51:17 -050089extern SHELL_VAR *assign_array_from_string PARAMS((char *, char *, int));
90extern SHELL_VAR *assign_array_var_from_word_list PARAMS((SHELL_VAR *, WORD_LIST *, int));
Jari Aalto06285672006-10-10 14:15:34 +000091
Chet Ramey8868eda2020-12-06 15:51:17 -050092extern WORD_LIST *expand_compound_array_assignment PARAMS((SHELL_VAR *, char *, int));
93extern void assign_compound_array_list PARAMS((SHELL_VAR *, WORD_LIST *, int));
94extern SHELL_VAR *assign_array_var_from_string PARAMS((SHELL_VAR *, char *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +000095
Chet Ramey8868eda2020-12-06 15:51:17 -050096extern char *expand_and_quote_assoc_word PARAMS((char *, int));
97extern void quote_compound_array_list PARAMS((WORD_LIST *, int));
Jari Aalto31859422009-01-12 13:36:28 +000098
Chet Ramey76404c82020-12-19 14:30:13 -050099extern int kvpair_assignment_p PARAMS((WORD_LIST *));
100extern char *expand_and_quote_kvpair_word PARAMS((char *));
101
Chet Ramey8868eda2020-12-06 15:51:17 -0500102extern int unbind_array_element PARAMS((SHELL_VAR *, char *, int));
103extern int skipsubscript PARAMS((const char *, int, int));
Jari Aaltof73dda02001-11-13 17:56:06 +0000104
Chet Ramey8868eda2020-12-06 15:51:17 -0500105extern void print_array_assignment PARAMS((SHELL_VAR *, int));
106extern void print_assoc_assignment PARAMS((SHELL_VAR *, int));
Jari Aaltof73dda02001-11-13 17:56:06 +0000107
Chet Ramey8868eda2020-12-06 15:51:17 -0500108extern arrayind_t array_expand_index PARAMS((SHELL_VAR *, char *, int, int));
109extern int valid_array_reference PARAMS((const char *, int));
Chet Ramey74091dd2022-09-26 11:49:46 -0400110extern int tokenize_array_reference PARAMS((char *, int, char **));
111
112extern char *array_value PARAMS((const char *, int, int, array_eltstate_t *));
113extern char *get_array_value PARAMS((const char *, int, array_eltstate_t *));
Jari Aaltob80f6442004-07-27 13:29:18 +0000114
Chet Ramey8868eda2020-12-06 15:51:17 -0500115extern char *array_keys PARAMS((char *, int, int));
116
117extern char *array_variable_name PARAMS((const char *, int, char **, int *));
118extern SHELL_VAR *array_variable_part PARAMS((const char *, int, char **, int *));
Jari Aaltof73dda02001-11-13 17:56:06 +0000119
Chet Ramey74091dd2022-09-26 11:49:46 -0400120extern void init_eltstate (array_eltstate_t *);
121extern void flush_eltstate (array_eltstate_t *);
122
Chet Rameyac50fba2014-02-26 09:36:43 -0500123#else
124
125#define AV_ALLOWALL 0
126#define AV_QUOTED 0
127#define AV_USEIND 0
Chet Ramey74091dd2022-09-26 11:49:46 -0400128#define AV_USEVAL 0
Chet Rameya0c0a002016-09-15 16:59:08 -0400129#define AV_ASSIGNRHS 0
Chet Ramey74091dd2022-09-26 11:49:46 -0400130#define AV_NOEXPAND 0
131#define AV_ONEWORD 0
132#define AV_ATSTARKEYS 0
Chet Rameyac50fba2014-02-26 09:36:43 -0500133
Chet Ramey74091dd2022-09-26 11:49:46 -0400134#define VA_NOEXPAND 0
Chet Rameyd233b482019-01-07 09:27:52 -0500135#define VA_ONEWORD 0
Chet Ramey74091dd2022-09-26 11:49:46 -0400136#define VA_ALLOWALL 0
Chet Rameyd233b482019-01-07 09:27:52 -0500137
Jari Aaltof73dda02001-11-13 17:56:06 +0000138#endif
139
140#endif /* !_ARRAYFUNC_H_ */