mirror of
https://github.com/mirror/make.git
synced 2025-01-04 01:10:26 +08:00
Formerly variable.c.~21~
This commit is contained in:
parent
5136f317d2
commit
2cc84f7c97
84
variable.c
84
variable.c
@ -558,8 +558,8 @@ try_variable_definition (filename, lineno, line, origin)
|
|||||||
register char *p = line;
|
register char *p = line;
|
||||||
register char *beg;
|
register char *beg;
|
||||||
register char *end;
|
register char *end;
|
||||||
register int recursive;
|
enum { bogus, simple, recursive, append } flavor = bogus;
|
||||||
char *name, *expanded_name;
|
char *name, *expanded_name, *value;
|
||||||
struct variable *v;
|
struct variable *v;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
@ -569,32 +569,38 @@ try_variable_definition (filename, lineno, line, origin)
|
|||||||
return 0;
|
return 0;
|
||||||
if (c == '=')
|
if (c == '=')
|
||||||
{
|
{
|
||||||
recursive = 1;
|
end = p - 1;
|
||||||
|
flavor = recursive;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else if (c == ':')
|
else if (c == ':')
|
||||||
if (*p == '=')
|
if (*p == '=')
|
||||||
{
|
{
|
||||||
++p;
|
end = p++ - 1;
|
||||||
recursive = 0;
|
flavor = simple;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
/* A colon other than := is a rule line, not a variable defn. */
|
||||||
return 0;
|
return 0;
|
||||||
|
else if (c == '+' && *p == '=')
|
||||||
|
{
|
||||||
|
end = p++ - 1;
|
||||||
|
flavor = append;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
beg = next_token (line);
|
|
||||||
end = p - 1;
|
|
||||||
if (!recursive)
|
|
||||||
--end;
|
|
||||||
while (isblank (end[-1]))
|
while (isblank (end[-1]))
|
||||||
--end;
|
--end;
|
||||||
|
beg = next_token (line);
|
||||||
p = next_token (p);
|
p = next_token (p);
|
||||||
|
|
||||||
/* Expand the name, so "$(foo)bar = baz" works. */
|
/* Expand the name, so "$(foo)bar = baz" works. */
|
||||||
name = savestring (beg, end - beg);
|
name = (char *) alloca (end - beg + 1);
|
||||||
|
bcopy (beg, name, end - beg);
|
||||||
|
name[end - beg] = '\0';
|
||||||
expanded_name = allocated_variable_expand (name);
|
expanded_name = allocated_variable_expand (name);
|
||||||
free (name);
|
|
||||||
|
|
||||||
if (expanded_name[0] == '\0')
|
if (expanded_name[0] == '\0')
|
||||||
{
|
{
|
||||||
@ -604,9 +610,61 @@ try_variable_definition (filename, lineno, line, origin)
|
|||||||
makefile_fatal (filename, lineno, "empty variable name");
|
makefile_fatal (filename, lineno, "empty variable name");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Calculate the variable's new value in VALUE. */
|
||||||
|
|
||||||
|
switch (flavor)
|
||||||
|
{
|
||||||
|
case bogus:
|
||||||
|
/* Should not be possible. */
|
||||||
|
abort ();
|
||||||
|
break;
|
||||||
|
case simple:
|
||||||
|
/* A simple variable definition "var := value". Expand the value. */
|
||||||
|
value = variable_expand (p);
|
||||||
|
break;
|
||||||
|
case recursive:
|
||||||
|
/* A recursive variable definition "var = value".
|
||||||
|
The value is used verbatim. */
|
||||||
|
value = p;
|
||||||
|
break;
|
||||||
|
case append:
|
||||||
|
/* An appending variable definition "var += value".
|
||||||
|
Extract the old value and append the new one. */
|
||||||
|
v = lookup_variable (expanded_name, strlen (expanded_name));
|
||||||
|
if (v == 0)
|
||||||
|
{
|
||||||
|
/* There was no old value.
|
||||||
|
This becomes a normal recursive definition. */
|
||||||
|
value = p;
|
||||||
|
flavor = recursive;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Paste the old and new values together in VALUE. */
|
||||||
|
|
||||||
|
unsigned int oldlen, newlen;
|
||||||
|
|
||||||
|
if (v->recursive)
|
||||||
|
/* The previous definition of the variable was recursive.
|
||||||
|
The new value comes from the unexpanded old and new values. */
|
||||||
|
flavor = recursive;
|
||||||
|
else
|
||||||
|
/* The previous definition of the variable was simple.
|
||||||
|
The new value comes from the old value, which was expanded
|
||||||
|
when it was set; and from the expanded new value. */
|
||||||
|
p = variable_expand (p);
|
||||||
|
|
||||||
|
oldlen = strlen (v->value);
|
||||||
|
newlen = strlen (p);
|
||||||
|
value = (char *) alloca (oldlen + 1 + newlen + 1);
|
||||||
|
bcopy (v->value, value, oldlen);
|
||||||
|
value[oldlen] = ' ';
|
||||||
|
bcopy (p, &value[oldlen + 1], newlen + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
v = define_variable (expanded_name, strlen (expanded_name),
|
v = define_variable (expanded_name, strlen (expanded_name),
|
||||||
recursive ? p : variable_expand (p),
|
value, origin, flavor == recursive);
|
||||||
origin, recursive);
|
|
||||||
|
|
||||||
free (expanded_name);
|
free (expanded_name);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user