From 29fae81fb76c854f41b493ab6c8a67e2ae834a58 Mon Sep 17 00:00:00 2001 From: Igor Burago Date: Fri, 29 Jul 2022 21:43:53 +0800 Subject: [PATCH] plumber: allow underscores in variable names in plumbing rules Fixes #561. --- src/cmd/plumb/rules.c | 29 +++++++++++++++++++---------- 1 file changed, 19 insertions(+), 10 deletions(-) diff --git a/src/cmd/plumb/rules.c b/src/cmd/plumb/rules.c index 2cb4afe9..e1687d43 100644 --- a/src/cmd/plumb/rules.c +++ b/src/cmd/plumb/rules.c @@ -215,6 +215,16 @@ setvariable(char *s, int n, char *val, char *qval) var->qvalue = estrdup(qval); } +static char* +scanvarname(char *s) +{ + if(isalpha((uchar)*s) || *s=='_') + do + s++; + while(isalnum((uchar)*s) || *s=='_'); + return s; +} + static char* nonnil(char *s) { @@ -249,16 +259,15 @@ dollar(Exec *e, char *s, int *namelen) { int n; static char *abuf; - char *t; *namelen = 1; if(e!=nil && '0'<=s[0] && s[0]<='9') return nonnil(e->match[s[0]-'0']); - for(t=s; isalnum((uchar)*t); t++) - ; - n = t-s; + n = scanvarname(s)-s; *namelen = n; + if(n == 0) + return nil; if(e != nil){ if(n == 3){ @@ -391,17 +400,17 @@ assignment(char *p) char *var, *qval; int n; - if(!isalpha((uchar)p[0])) - return 0; - for(var=p; isalnum((uchar)*p); p++) - ; + var = p; + p = scanvarname(p); n = p-var; + if(n == 0) + return 0; while(*p==' ' || *p=='\t') - p++; + p++; if(*p++ != '=') return 0; while(*p==' ' || *p=='\t') - p++; + p++; qval = expand(nil, p, nil); setvariable(var, n, p, qval); return 1;