I'm not familiar with with the precise definition of an identifier, so
somebody might want to double-check that this change (which assumes that
valid identifiers cannot start with a '[') is correct. This fixes the
following crash:
printf %n '[0]'
---
Src/params.c | 2 ++
1 files changed, 2 insertions(+), 0 deletions(-)
diff --git a/Src/params.c b/Src/params.c
index 8510b92..ba6cd63 100644
--- a/Src/params.c
+++ b/Src/params.c
@@ -1009,6 +1009,8 @@ isident(char *s)
* definitely not a valid identifier. */
if (!*ss)
return 1;
+ if (s == ss)
+ return 0;
if (*ss != '[')
return 0;
--
1.7.3.4
Attachment:
pgpWQ7gvX6aNM.pgp
Description: PGP signature