summaryrefslogtreecommitdiffstats
path: root/testing/source/bash/bash-4.0-patches/bash40-005
blob: ccfde66da0de784d0c4ed5c2507109ecec80d333 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
			     BASH PATCH REPORT
			     =================

Bash-Release: 4.0
Patch-ID: bash40-005

Bug-Reported-by:	Pierre Gaston <pierre.gaston@gmail.com>
Bug-Reference-ID:	<c440c9800902242338n69f594a4nd66b8748def9cf18@mail.gmail.com>
Bug-Reference-URL:	http://lists.gnu.org/archive/html/bug-bash/2009-02/msg00206.html

Bug-Description:

The `declare' builtin dumped core when attempting to assign associative
array indices containing some special characters, even when they were
quoted before being expanded.

Patch:

*** ../bash-4.0/builtins/declare.def	2009-01-04 14:32:22.000000000 -0500
--- builtins/declare.def	2009-02-26 11:40:16.000000000 -0500
***************
*** 296,299 ****
--- 296,306 ----
        if (t = strchr (name, '['))	/* ] */
  	{
+ 	  /* If offset != 0 we have already validated any array reference */
+ 	  if (offset == 0 && valid_array_reference (name) == 0)
+ 	    {
+ 	      sh_invalidid (name);
+ 	      assign_error++;
+ 	      NEXT_VARIABLE ();
+ 	    }
  	  subscript_start = t;
  	  *t = '\0';
***************
*** 485,489 ****
  	  /* declare -a name[[n]] or declare name[n] makes name an indexed
  	     array variable. */
! 	  else if ((making_array_special || (flags_on & att_array)) && array_p (var) == 0)
  	    var = convert_var_to_array (var);
  #endif /* ARRAY_VARS */
--- 492,496 ----
  	  /* declare -a name[[n]] or declare name[n] makes name an indexed
  	     array variable. */
! 	  else if ((making_array_special || (flags_on & att_array)) && array_p (var) == 0 && assoc_p (var) == 0)
  	    var = convert_var_to_array (var);
  #endif /* ARRAY_VARS */
*** ../bash-4.0/patchlevel.h	2009-01-04 14:32:40.000000000 -0500
--- patchlevel.h	2009-02-22 16:11:31.000000000 -0500
***************
*** 26,30 ****
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 4
  
  #endif /* _PATCHLEVEL_H_ */
--- 26,30 ----
     looks for to find the patch level (for the sccs version string). */
  
! #define PATCHLEVEL 5
  
  #endif /* _PATCHLEVEL_H_ */