1 /* arrayfunc.h -- declarations for miscellaneous array functions in arrayfunc.c */
3 /* Copyright (C) 2001-2021 Free Software Foundation, Inc.
5 This file is part of GNU Bash, the Bourne Again SHell.
7 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.
12 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.
17 You should have received a copy of the GNU General Public License
18 along with Bash. If not, see <http://www.gnu.org/licenses/>.
21 #if !defined (_ARRAYFUNC_H_)
24 /* Must include variables.h before including this file. */
26 /* 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. */
32 /* values for `type' field */
33 #define ARRAY_INVALID -1
34 #define ARRAY_SCALAR 0
35 #define ARRAY_INDEXED 1
38 /* KEY will contain allocated memory if called through the assign_array_element
39 code path because of how assoc_insert works. */
40 typedef struct element_state
42 short type
; /* assoc or indexed, says which fields are valid */
43 short subtype
; /* `*', `@', or something else */
45 char *key
; /* can be allocated memory */
49 #if defined (ARRAY_VARS)
51 /* This variable means to not expand associative array subscripts more than
52 once, when performing variable expansion. */
53 extern int assoc_expand_once
;
55 /* The analog for indexed array subscripts */
56 extern int array_expand_once
;
58 /* 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 $* */
61 #define AV_QUOTED 0x002
62 #define AV_USEIND 0x004
63 #define AV_USEVAL 0x008 /* XXX - should move this */
64 #define AV_ASSIGNRHS 0x010 /* no splitting, special case ${a[@]} */
65 #define AV_NOEXPAND 0x020 /* don't run assoc subscripts through word expansion */
66 #define AV_ONEWORD 0x040 /* not used yet */
67 #define AV_ATSTARKEYS 0x080 /* accept a[@] and a[*] but use them as keys, not special values */
69 /* 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. */
72 #define VA_NOEXPAND 0x001
73 #define VA_ONEWORD 0x002
74 #define VA_ALLOWALL 0x004 /* allow @ to mean all elements of the array */
76 extern SHELL_VAR
*convert_var_to_array
PARAMS((SHELL_VAR
*));
77 extern SHELL_VAR
*convert_var_to_assoc
PARAMS((SHELL_VAR
*));
79 extern char *make_array_variable_value
PARAMS((SHELL_VAR
*, arrayind_t
, char *, char *, int));
81 extern SHELL_VAR
*bind_array_variable
PARAMS((char *, arrayind_t
, char *, int));
82 extern SHELL_VAR
*bind_array_element
PARAMS((SHELL_VAR
*, arrayind_t
, char *, int));
83 extern SHELL_VAR
*assign_array_element
PARAMS((char *, char *, int, array_eltstate_t
*));
85 extern SHELL_VAR
*bind_assoc_variable
PARAMS((SHELL_VAR
*, char *, char *, char *, int));
87 extern SHELL_VAR
*find_or_make_array_variable
PARAMS((char *, int));
89 extern SHELL_VAR
*assign_array_from_string
PARAMS((char *, char *, int));
90 extern SHELL_VAR
*assign_array_var_from_word_list
PARAMS((SHELL_VAR
*, WORD_LIST
*, int));
92 extern WORD_LIST
*expand_compound_array_assignment
PARAMS((SHELL_VAR
*, char *, int));
93 extern void assign_compound_array_list
PARAMS((SHELL_VAR
*, WORD_LIST
*, int));
94 extern SHELL_VAR
*assign_array_var_from_string
PARAMS((SHELL_VAR
*, char *, int));
96 extern char *expand_and_quote_assoc_word
PARAMS((char *, int));
97 extern void quote_compound_array_list
PARAMS((WORD_LIST
*, int));
99 extern int kvpair_assignment_p
PARAMS((WORD_LIST
*));
100 extern char *expand_and_quote_kvpair_word
PARAMS((char *));
102 extern int unbind_array_element
PARAMS((SHELL_VAR
*, char *, int));
103 extern int skipsubscript
PARAMS((const char *, int, int));
105 extern void print_array_assignment
PARAMS((SHELL_VAR
*, int));
106 extern void print_assoc_assignment
PARAMS((SHELL_VAR
*, int));
108 extern arrayind_t array_expand_index
PARAMS((SHELL_VAR
*, char *, int, int));
109 extern int valid_array_reference
PARAMS((const char *, int));
110 extern int tokenize_array_reference
PARAMS((char *, int, char **));
112 extern char *array_value
PARAMS((const char *, int, int, array_eltstate_t
*));
113 extern char *get_array_value
PARAMS((const char *, int, array_eltstate_t
*));
115 extern char *array_keys
PARAMS((char *, int, int));
117 extern char *array_variable_name
PARAMS((const char *, int, char **, int *));
118 extern SHELL_VAR
*array_variable_part
PARAMS((const char *, int, char **, int *));
120 extern void init_eltstate (array_eltstate_t
*);
121 extern void flush_eltstate (array_eltstate_t
*);
125 #define AV_ALLOWALL 0
129 #define AV_ASSIGNRHS 0
130 #define AV_NOEXPAND 0
132 #define AV_ATSTARKEYS 0
134 #define VA_NOEXPAND 0
136 #define VA_ALLOWALL 0
140 #endif /* !_ARRAYFUNC_H_ */