[git commit] ash: revert accidental change (should have been separate)

Denys Vlasenko vda.linux at googlemail.com
Fri Jun 25 00:08:38 UTC 2021


commit: https://git.busybox.net/busybox/commit/?id=ad57e4e4b23926002ce72979729b017520bef1d0
branch: https://git.busybox.net/busybox/commit/?id=refs/heads/master

Signed-off-by: Denys Vlasenko <vda.linux at googlemail.com>
---
 shell/ash.c | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)

diff --git a/shell/ash.c b/shell/ash.c
index 2eac6e113..bee81920a 100644
--- a/shell/ash.c
+++ b/shell/ash.c
@@ -12751,7 +12751,7 @@ parsesub: {
 			do {
 				STPUTC(c, out);
 				c = pgetc_eatbnl();
-			} while ((subtype == 0 || subtype == VSLENGTH) && isdigit(c));
+			} while (!subtype && isdigit(c));
 		} else if (c != '}') {
 			/* $[{[#]]<specialchar>[}] */
 			int cc = c;
@@ -12781,6 +12781,11 @@ parsesub: {
 		} else
 			goto badsub;
 
+		if (c != '}' && subtype == VSLENGTH) {
+			/* ${#VAR didn't end with } */
+			goto badsub;
+		}
+
 		if (subtype == 0) {
 			static const char types[] ALIGN1 = "}-+?=";
 			/* ${VAR...} but not $VAR or ${#VAR} */
@@ -12837,8 +12842,6 @@ parsesub: {
 #endif
 			}
 		} else {
-			if (subtype == VSLENGTH && c != '}')
-				subtype = 0;
  badsub:
 			pungetc();
 		}


More information about the busybox-cvs mailing list