mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-18 15:30:21 +00:00
Reduce the number of explicit parameters passed to VarParse()
by passing them through struct VarParser. Patch: 7.127 Submitted by: Max Okumoto <okumoto@ucsd.edu>
This commit is contained in:
parent
586cfbb265
commit
73c5a04dfa
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=143904
@ -105,10 +105,11 @@ __FBSDID("$FreeBSD$");
|
||||
*/
|
||||
typedef struct VarParser {
|
||||
const char *const input; /* pointer to input string */
|
||||
const char *ptr; /* current parser pos in input str */
|
||||
GNode *ctxt;
|
||||
Boolean err;
|
||||
} VarParser;
|
||||
static char *VarParse(const char [], VarParser *, size_t *, Boolean *);
|
||||
static char *VarParse(VarParser *, size_t *, Boolean *);
|
||||
|
||||
/*
|
||||
* This is a harmless return value for Var_Parse that can be used by Var_Subst
|
||||
@ -1919,26 +1920,31 @@ VarParseShort(const char input[], VarParser *vp,
|
||||
}
|
||||
|
||||
static char *
|
||||
VarParse(const char input[], VarParser *vp, size_t *consumed, Boolean *freeResult)
|
||||
VarParse(VarParser *vp, size_t *consumed, Boolean *freeResult)
|
||||
{
|
||||
/* assert(input[0] == '$'); */
|
||||
char *value;
|
||||
|
||||
*consumed += 1; /* consume '$' */
|
||||
input += 1;
|
||||
/* assert(vp->ptr[0] == '$'); */
|
||||
|
||||
if (input[0] == '\0') {
|
||||
vp->ptr += 1; /* consume '$' */
|
||||
|
||||
if (vp->ptr[0] == '\0') {
|
||||
*consumed += 1; /* consume '$' */
|
||||
/* Error, there is only a dollar sign in the input string. */
|
||||
*freeResult = FALSE;
|
||||
return (vp->err ? var_Error : varNoError);
|
||||
value = vp->err ? var_Error : varNoError;
|
||||
|
||||
} else if (input[0] == OPEN_PAREN || input[0] == OPEN_BRACE) {
|
||||
} else if (vp->ptr[0] == OPEN_PAREN || vp->ptr[0] == OPEN_BRACE) {
|
||||
*consumed += 1; /* consume '$' */
|
||||
/* multi letter variable name */
|
||||
return (VarParseLong(input, vp, consumed, freeResult));
|
||||
value = VarParseLong(vp->ptr, vp, consumed, freeResult);
|
||||
|
||||
} else {
|
||||
*consumed += 1; /* consume '$' */
|
||||
/* single letter variable name */
|
||||
return (VarParseShort(input, vp, consumed, freeResult));
|
||||
value = VarParseShort(vp->ptr, vp, consumed, freeResult);
|
||||
}
|
||||
return (value);
|
||||
}
|
||||
|
||||
/*-
|
||||
@ -1970,12 +1976,13 @@ Var_Parse(const char input[], GNode *ctxt, Boolean err,
|
||||
size_t *consumed, Boolean *freeResult)
|
||||
{
|
||||
VarParser vp = {
|
||||
input,
|
||||
input,
|
||||
ctxt,
|
||||
err
|
||||
};
|
||||
|
||||
return VarParse(input, &vp, consumed, freeResult);
|
||||
return VarParse(&vp, consumed, freeResult);
|
||||
}
|
||||
|
||||
/*-
|
||||
|
Loading…
Reference in New Issue
Block a user