mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
plumber: fail on buffer exhaustion or runaway quotes in string expansion
This commit is contained in:
parent
a4af25bc0d
commit
e4b913866b
1 changed files with 25 additions and 11 deletions
|
@ -289,17 +289,30 @@ dollar(Exec *e, char *s, int *namelen)
|
||||||
return variable(s, n);
|
return variable(s, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ruleerror(char *msg)
|
||||||
|
{
|
||||||
|
if(parsing){
|
||||||
|
parsing = 0;
|
||||||
|
parseerror("%s", msg);
|
||||||
|
}
|
||||||
|
error("%s", msg);
|
||||||
|
}
|
||||||
|
|
||||||
/* expand one blank-terminated string, processing quotes and $ signs */
|
/* expand one blank-terminated string, processing quotes and $ signs */
|
||||||
char*
|
char*
|
||||||
expand(Exec *e, char *s, char **ends)
|
expand(Exec *e, char *s, char **ends)
|
||||||
{
|
{
|
||||||
char *p, *ep, *val;
|
char *p, *ep, *val;
|
||||||
int namelen, quoting;
|
int namelen, vallen, quoting, inputleft;
|
||||||
|
|
||||||
p = ebuf;
|
p = ebuf;
|
||||||
ep = ebuf+sizeof ebuf-1;
|
ep = ebuf+sizeof ebuf-1;
|
||||||
quoting = 0;
|
quoting = 0;
|
||||||
while(p<ep && *s!='\0' && (quoting || (*s!=' ' && *s!='\t'))){
|
for(;;){
|
||||||
|
inputleft = (*s!='\0' && (quoting || (*s!=' ' && *s!='\t')));
|
||||||
|
if(!inputleft || p==ep)
|
||||||
|
break;
|
||||||
if(*s == '\''){
|
if(*s == '\''){
|
||||||
s++;
|
s++;
|
||||||
if(!quoting)
|
if(!quoting)
|
||||||
|
@ -321,12 +334,17 @@ expand(Exec *e, char *s, char **ends)
|
||||||
*p++ = '$';
|
*p++ = '$';
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if(ep-p < strlen(val))
|
vallen = strlen(val);
|
||||||
return "string-too-long";
|
if(ep-p < vallen)
|
||||||
|
break;
|
||||||
strcpy(p, val);
|
strcpy(p, val);
|
||||||
p += strlen(val);
|
p += vallen;
|
||||||
s += namelen;
|
s += namelen;
|
||||||
}
|
}
|
||||||
|
if(inputleft)
|
||||||
|
ruleerror("expanded string too long");
|
||||||
|
else if(quoting)
|
||||||
|
ruleerror("runaway quoted string literal");
|
||||||
if(ends)
|
if(ends)
|
||||||
*ends = s;
|
*ends = s;
|
||||||
*p = '\0';
|
*p = '\0';
|
||||||
|
@ -336,11 +354,7 @@ expand(Exec *e, char *s, char **ends)
|
||||||
void
|
void
|
||||||
regerror(char *msg)
|
regerror(char *msg)
|
||||||
{
|
{
|
||||||
if(parsing){
|
ruleerror(msg);
|
||||||
parsing = 0;
|
|
||||||
parseerror("%s", msg);
|
|
||||||
}
|
|
||||||
error("%s", msg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Reference in a new issue