1 /* Internals of variables for GNU Make.
2 Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
3 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free
4 Software Foundation, Inc.
5 This file is part of GNU Make.
7 GNU Make is free software; you can redistribute it and/or modify it under the
8 terms of the GNU General Public License as published by the Free Software
9 Foundation; either version 3 of the License, or (at your option) any later
12 GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License along with
17 this program. If not, see <http://www.gnu.org/licenses/>. */
30 #include "pathstuff.h"
34 /* Chain of all pattern-specific variables. */
36 static struct pattern_var
*pattern_vars
;
38 /* Pointer to the last struct in the pack of a specific size, from 1 to 255.*/
40 static struct pattern_var
*last_pattern_vars
[256];
42 /* Create a new pattern-specific variable struct. The new variable is
43 inserted into the PATTERN_VARS list in the shortest patterns first
44 order to support the shortest stem matching (the variables are
45 matched in the reverse order so the ones with the longest pattern
46 will be considered first). Variables with the same pattern length
47 are inserted in the definition order. */
50 create_pattern_var (const char *target
, const char *suffix
)
52 register unsigned int len
= strlen (target
);
53 register struct pattern_var
*p
= xmalloc (sizeof (struct pattern_var
));
55 if (pattern_vars
!= 0)
57 if (len
< 256 && last_pattern_vars
[len
] != 0)
59 p
->next
= last_pattern_vars
[len
]->next
;
60 last_pattern_vars
[len
]->next
= p
;
64 /* Find the position where we can insert this variable. */
65 register struct pattern_var
**v
;
67 for (v
= &pattern_vars
; ; v
= &(*v
)->next
)
69 /* Insert at the end of the pack so that patterns with the
70 same length appear in the order they were defined .*/
72 if (*v
== 0 || (*v
)->len
> len
)
89 p
->suffix
= suffix
+ 1;
92 last_pattern_vars
[len
] = p
;
97 /* Look up a target in the pattern-specific variable list. */
99 static struct pattern_var
*
100 lookup_pattern_var (struct pattern_var
*start
, const char *target
)
102 struct pattern_var
*p
;
103 unsigned int targlen
= strlen(target
);
105 for (p
= start
? start
->next
: pattern_vars
; p
!= 0; p
= p
->next
)
108 unsigned int stemlen
;
110 if (p
->len
> targlen
)
111 /* It can't possibly match. */
114 /* From the lengths of the filename and the pattern parts,
115 find the stem: the part of the filename that matches the %. */
116 stem
= target
+ (p
->suffix
- p
->target
- 1);
117 stemlen
= targlen
- p
->len
+ 1;
119 /* Compare the text in the pattern before the stem, if any. */
120 if (stem
> target
&& !strneq (p
->target
, target
, stem
- target
))
123 /* Compare the text in the pattern after the stem, if any.
124 We could test simply using streq, but this way we compare the
125 first two characters immediately. This saves time in the very
126 common case where the first character matches because it is a
128 if (*p
->suffix
== stem
[stemlen
]
129 && (*p
->suffix
== '\0' || streq (&p
->suffix
[1], &stem
[stemlen
+1])))
136 /* Hash table of all global variable definitions. */
139 variable_hash_1 (const void *keyv
)
141 struct variable
const *key
= (struct variable
const *) keyv
;
142 return_STRING_N_HASH_1 (key
->name
, key
->length
);
146 variable_hash_2 (const void *keyv
)
148 struct variable
const *key
= (struct variable
const *) keyv
;
149 return_STRING_N_HASH_2 (key
->name
, key
->length
);
153 variable_hash_cmp (const void *xv
, const void *yv
)
155 struct variable
const *x
= (struct variable
const *) xv
;
156 struct variable
const *y
= (struct variable
const *) yv
;
157 int result
= x
->length
- y
->length
;
160 return_STRING_N_COMPARE (x
->name
, y
->name
, x
->length
);
163 #ifndef VARIABLE_BUCKETS
164 #define VARIABLE_BUCKETS 523
166 #ifndef PERFILE_VARIABLE_BUCKETS
167 #define PERFILE_VARIABLE_BUCKETS 23
169 #ifndef SMALL_SCOPE_VARIABLE_BUCKETS
170 #define SMALL_SCOPE_VARIABLE_BUCKETS 13
173 static struct variable_set global_variable_set
;
174 static struct variable_set_list global_setlist
175 = { 0, &global_variable_set
, 0 };
176 struct variable_set_list
*current_variable_set_list
= &global_setlist
;
178 /* Implement variables. */
181 init_hash_global_variable_set (void)
183 hash_init (&global_variable_set
.table
, VARIABLE_BUCKETS
,
184 variable_hash_1
, variable_hash_2
, variable_hash_cmp
);
187 /* Define variable named NAME with value VALUE in SET. VALUE is copied.
188 LENGTH is the length of NAME, which does not need to be null-terminated.
189 ORIGIN specifies the origin of the variable (makefile, command line
191 If RECURSIVE is nonzero a flag is set in the variable saying
192 that it should be recursively re-expanded. */
195 define_variable_in_set (const char *name
, unsigned int length
,
196 const char *value
, enum variable_origin origin
,
197 int recursive
, struct variable_set
*set
,
198 const struct floc
*flocp
)
201 struct variable
**var_slot
;
202 struct variable var_key
;
205 set
= &global_variable_set
;
207 var_key
.name
= (char *) name
;
208 var_key
.length
= length
;
209 var_slot
= (struct variable
**) hash_find_slot (&set
->table
, &var_key
);
211 if (env_overrides
&& origin
== o_env
)
212 origin
= o_env_override
;
215 if (! HASH_VACANT (v
))
217 if (env_overrides
&& v
->origin
== o_env
)
218 /* V came from in the environment. Since it was defined
219 before the switches were parsed, it wasn't affected by -e. */
220 v
->origin
= o_env_override
;
222 /* A variable of this name is already defined.
223 If the old definition is from a stronger source
224 than this one, don't redefine it. */
225 if ((int) origin
>= (int) v
->origin
)
229 v
->value
= xstrdup (value
);
231 v
->fileinfo
= *flocp
;
233 v
->fileinfo
.filenm
= 0;
235 v
->recursive
= recursive
;
240 /* Create a new variable definition and add it to the hash table. */
242 v
= xmalloc (sizeof (struct variable
));
243 v
->name
= xstrndup (name
, length
);
245 hash_insert_at (&set
->table
, v
, var_slot
);
246 v
->value
= xstrdup (value
);
248 v
->fileinfo
= *flocp
;
250 v
->fileinfo
.filenm
= 0;
252 v
->recursive
= recursive
;
259 v
->export
= v_default
;
262 if (*name
!= '_' && (*name
< 'A' || *name
> 'Z')
263 && (*name
< 'a' || *name
> 'z'))
267 for (++name
; *name
!= '\0'; ++name
)
268 if (*name
!= '_' && (*name
< 'a' || *name
> 'z')
269 && (*name
< 'A' || *name
> 'Z') && !ISDIGIT(*name
))
280 /* Undefine variable named NAME in SET. LENGTH is the length of NAME, which
281 does not need to be null-terminated. ORIGIN specifies the origin of the
282 variable (makefile, command line or environment). */
285 free_variable_name_and_value (const void *item
);
288 undefine_variable_in_set (const char *name
, unsigned int length
,
289 enum variable_origin origin
,
290 struct variable_set
*set
)
293 struct variable
**var_slot
;
294 struct variable var_key
;
297 set
= &global_variable_set
;
299 var_key
.name
= (char *) name
;
300 var_key
.length
= length
;
301 var_slot
= (struct variable
**) hash_find_slot (&set
->table
, &var_key
);
303 if (env_overrides
&& origin
== o_env
)
304 origin
= o_env_override
;
307 if (! HASH_VACANT (v
))
309 if (env_overrides
&& v
->origin
== o_env
)
310 /* V came from in the environment. Since it was defined
311 before the switches were parsed, it wasn't affected by -e. */
312 v
->origin
= o_env_override
;
314 /* If the definition is from a stronger source than this one, don't
316 if ((int) origin
>= (int) v
->origin
)
318 hash_delete_at (&set
->table
, var_slot
);
319 free_variable_name_and_value (v
);
324 /* If the variable passed in is "special", handle its special nature.
325 Currently there are two such variables, both used for introspection:
326 .VARIABLES expands to a list of all the variables defined in this instance
328 .TARGETS expands to a list of all the targets defined in this
330 Returns the variable reference passed in. */
332 #define EXPANSION_INCREMENT(_l) ((((_l) / 500) + 1) * 500)
334 static struct variable
*
335 lookup_special_var (struct variable
*var
)
337 static unsigned long last_var_count
= 0;
340 /* This one actually turns out to be very hard, due to the way the parser
341 records targets. The way it works is that target information is collected
342 internally until make knows the target is completely specified. It unitl
343 it sees that some new construct (a new target or variable) is defined that
344 it knows the previous one is done. In short, this means that if you do
351 then $(TARGS) won't contain "all", because it's not until after the
352 variable is created that the previous target is completed.
354 Changing this would be a major pain. I think a less complex way to do it
355 would be to pre-define the target files as soon as the first line is
356 parsed, then come back and do the rest of the definition as now. That
357 would allow $(.TARGETS) to be correct without a major change to the way
360 if (streq (var->name, ".TARGETS"))
361 var->value = build_target_list (var->value);
365 if (streq (var
->name
, ".VARIABLES")
366 && global_variable_set
.table
.ht_fill
!= last_var_count
)
368 unsigned long max
= EXPANSION_INCREMENT (strlen (var
->value
));
371 struct variable
**vp
= (struct variable
**) global_variable_set
.table
.ht_vec
;
372 struct variable
**end
= &vp
[global_variable_set
.table
.ht_size
];
374 /* Make sure we have at least MAX bytes in the allocated buffer. */
375 var
->value
= xrealloc (var
->value
, max
);
377 /* Walk through the hash of variables, constructing a list of names. */
380 for (; vp
< end
; ++vp
)
381 if (!HASH_VACANT (*vp
))
383 struct variable
*v
= *vp
;
389 unsigned long off
= p
- var
->value
;
391 max
+= EXPANSION_INCREMENT (l
+ 1);
392 var
->value
= xrealloc (var
->value
, max
);
393 p
= &var
->value
[off
];
396 memcpy (p
, v
->name
, l
);
402 /* Remember how many variables are in our current count. Since we never
403 remove variables from the list, this is a reliable way to know whether
404 the list is up to date or needs to be recomputed. */
406 last_var_count
= global_variable_set
.table
.ht_fill
;
413 /* Lookup a variable whose name is a string starting at NAME
414 and with LENGTH chars. NAME need not be null-terminated.
415 Returns address of the `struct variable' containing all info
416 on the variable, or nil if no such variable is defined. */
419 lookup_variable (const char *name
, unsigned int length
)
421 const struct variable_set_list
*setlist
;
422 struct variable var_key
;
425 var_key
.name
= (char *) name
;
426 var_key
.length
= length
;
428 for (setlist
= current_variable_set_list
;
429 setlist
!= 0; setlist
= setlist
->next
)
431 const struct variable_set
*set
= setlist
->set
;
434 v
= (struct variable
*) hash_find_item ((struct hash_table
*) &set
->table
, &var_key
);
435 if (v
&& (!is_parent
|| !v
->private_var
))
436 return v
->special
? lookup_special_var (v
) : v
;
438 is_parent
|= setlist
->next_is_parent
;
442 /* since we don't read envp[] on startup, try to get the
443 variable via getenv() here. */
445 char *vname
= alloca (length
+ 1);
447 strncpy (vname
, name
, length
);
449 value
= getenv (vname
);
458 while ((sptr
= strchr (sptr
, '$')))
469 nvalue
= alloca (strlen (value
) + scnt
+ 1);
488 return define_variable (vname
, length
, nvalue
, o_env
, 1);
492 return define_variable (vname
, length
, value
, o_env
, 1);
500 /* Lookup a variable whose name is a string starting at NAME
501 and with LENGTH chars in set SET. NAME need not be null-terminated.
502 Returns address of the `struct variable' containing all info
503 on the variable, or nil if no such variable is defined. */
506 lookup_variable_in_set (const char *name
, unsigned int length
,
507 const struct variable_set
*set
)
509 struct variable var_key
;
511 var_key
.name
= (char *) name
;
512 var_key
.length
= length
;
514 return (struct variable
*) hash_find_item ((struct hash_table
*) &set
->table
, &var_key
);
517 /* Initialize FILE's variable set list. If FILE already has a variable set
518 list, the topmost variable set is left intact, but the the rest of the
519 chain is replaced with FILE->parent's setlist. If FILE is a double-colon
520 rule, then we will use the "root" double-colon target's variable set as the
521 parent of FILE's variable set.
523 If we're READING a makefile, don't do the pattern variable search now,
524 since the pattern variable might not have been defined yet. */
527 initialize_file_variables (struct file
*file
, int reading
)
529 struct variable_set_list
*l
= file
->variables
;
533 l
= (struct variable_set_list
*)
534 xmalloc (sizeof (struct variable_set_list
));
535 l
->set
= xmalloc (sizeof (struct variable_set
));
536 hash_init (&l
->set
->table
, PERFILE_VARIABLE_BUCKETS
,
537 variable_hash_1
, variable_hash_2
, variable_hash_cmp
);
541 /* If this is a double-colon, then our "parent" is the "root" target for
542 this double-colon rule. Since that rule has the same name, parent,
543 etc. we can just use its variables as the "next" for ours. */
545 if (file
->double_colon
&& file
->double_colon
!= file
)
547 initialize_file_variables (file
->double_colon
, reading
);
548 l
->next
= file
->double_colon
->variables
;
549 l
->next_is_parent
= 0;
553 if (file
->parent
== 0)
554 l
->next
= &global_setlist
;
557 initialize_file_variables (file
->parent
, reading
);
558 l
->next
= file
->parent
->variables
;
560 l
->next_is_parent
= 1;
562 /* If we're not reading makefiles and we haven't looked yet, see if
563 we can find pattern variables for this target. */
565 if (!reading
&& !file
->pat_searched
)
567 struct pattern_var
*p
;
569 p
= lookup_pattern_var (0, file
->name
);
572 struct variable_set_list
*global
= current_variable_set_list
;
574 /* We found at least one. Set up a new variable set to accumulate
575 all the pattern variables that match this target. */
577 file
->pat_variables
= create_new_variable_set ();
578 current_variable_set_list
= file
->pat_variables
;
582 /* We found one, so insert it into the set. */
586 if (p
->variable
.flavor
== f_simple
)
588 v
= define_variable_loc (
589 p
->variable
.name
, strlen (p
->variable
.name
),
590 p
->variable
.value
, p
->variable
.origin
,
591 0, &p
->variable
.fileinfo
);
593 v
->flavor
= f_simple
;
597 v
= do_variable_definition (
598 &p
->variable
.fileinfo
, p
->variable
.name
,
599 p
->variable
.value
, p
->variable
.origin
,
600 p
->variable
.flavor
, 1);
603 /* Also mark it as a per-target and copy export status. */
604 v
->per_target
= p
->variable
.per_target
;
605 v
->export
= p
->variable
.export
;
606 v
->private_var
= p
->variable
.private_var
;
608 while ((p
= lookup_pattern_var (p
, file
->name
)) != 0);
610 current_variable_set_list
= global
;
612 file
->pat_searched
= 1;
615 /* If we have a pattern variable match, set it up. */
617 if (file
->pat_variables
!= 0)
619 file
->pat_variables
->next
= l
->next
;
620 file
->pat_variables
->next_is_parent
= l
->next_is_parent
;
621 l
->next
= file
->pat_variables
;
622 l
->next_is_parent
= 0;
626 /* Pop the top set off the current variable set list,
627 and free all its storage. */
629 struct variable_set_list
*
630 create_new_variable_set (void)
632 register struct variable_set_list
*setlist
;
633 register struct variable_set
*set
;
635 set
= xmalloc (sizeof (struct variable_set
));
636 hash_init (&set
->table
, SMALL_SCOPE_VARIABLE_BUCKETS
,
637 variable_hash_1
, variable_hash_2
, variable_hash_cmp
);
639 setlist
= (struct variable_set_list
*)
640 xmalloc (sizeof (struct variable_set_list
));
642 setlist
->next
= current_variable_set_list
;
643 setlist
->next_is_parent
= 0;
649 free_variable_name_and_value (const void *item
)
651 struct variable
*v
= (struct variable
*) item
;
657 free_variable_set (struct variable_set_list
*list
)
659 hash_map (&list
->set
->table
, free_variable_name_and_value
);
660 hash_free (&list
->set
->table
, 1);
665 /* Create a new variable set and push it on the current setlist.
666 If we're pushing a global scope (that is, the current scope is the global
667 scope) then we need to "push" it the other way: file variable sets point
668 directly to the global_setlist so we need to replace that with the new one.
671 struct variable_set_list
*
672 push_new_variable_scope (void)
674 current_variable_set_list
= create_new_variable_set();
675 if (current_variable_set_list
->next
== &global_setlist
)
677 /* It was the global, so instead of new -> &global we want to replace
678 &global with the new one and have &global -> new, with current still
679 pointing to &global */
680 struct variable_set
*set
= current_variable_set_list
->set
;
681 current_variable_set_list
->set
= global_setlist
.set
;
682 global_setlist
.set
= set
;
683 current_variable_set_list
->next
= global_setlist
.next
;
684 global_setlist
.next
= current_variable_set_list
;
685 current_variable_set_list
= &global_setlist
;
687 return (current_variable_set_list
);
691 pop_variable_scope (void)
693 struct variable_set_list
*setlist
;
694 struct variable_set
*set
;
696 /* Can't call this if there's no scope to pop! */
697 assert(current_variable_set_list
->next
!= NULL
);
699 if (current_variable_set_list
!= &global_setlist
)
701 /* We're not pointing to the global setlist, so pop this one. */
702 setlist
= current_variable_set_list
;
704 current_variable_set_list
= setlist
->next
;
708 /* This set is the one in the global_setlist, but there is another global
709 set beyond that. We want to copy that set to global_setlist, then
710 delete what used to be in global_setlist. */
711 setlist
= global_setlist
.next
;
712 set
= global_setlist
.set
;
713 global_setlist
.set
= setlist
->set
;
714 global_setlist
.next
= setlist
->next
;
715 global_setlist
.next_is_parent
= setlist
->next_is_parent
;
718 /* Free the one we no longer need. */
720 hash_map (&set
->table
, free_variable_name_and_value
);
721 hash_free (&set
->table
, 1);
725 /* Merge FROM_SET into TO_SET, freeing unused storage in FROM_SET. */
728 merge_variable_sets (struct variable_set
*to_set
,
729 struct variable_set
*from_set
)
731 struct variable
**from_var_slot
= (struct variable
**) from_set
->table
.ht_vec
;
732 struct variable
**from_var_end
= from_var_slot
+ from_set
->table
.ht_size
;
734 for ( ; from_var_slot
< from_var_end
; from_var_slot
++)
735 if (! HASH_VACANT (*from_var_slot
))
737 struct variable
*from_var
= *from_var_slot
;
738 struct variable
**to_var_slot
739 = (struct variable
**) hash_find_slot (&to_set
->table
, *from_var_slot
);
740 if (HASH_VACANT (*to_var_slot
))
741 hash_insert_at (&to_set
->table
, from_var
, to_var_slot
);
744 /* GKM FIXME: delete in from_set->table */
745 free (from_var
->value
);
751 /* Merge SETLIST1 into SETLIST0, freeing unused storage in SETLIST1. */
754 merge_variable_set_lists (struct variable_set_list
**setlist0
,
755 struct variable_set_list
*setlist1
)
757 struct variable_set_list
*to
= *setlist0
;
758 struct variable_set_list
*last0
= 0;
760 /* If there's nothing to merge, stop now. */
764 /* This loop relies on the fact that all setlists terminate with the global
765 setlist (before NULL). If that's not true, arguably we SHOULD die. */
767 while (setlist1
!= &global_setlist
&& to
!= &global_setlist
)
769 struct variable_set_list
*from
= setlist1
;
770 setlist1
= setlist1
->next
;
772 merge_variable_sets (to
->set
, from
->set
);
778 if (setlist1
!= &global_setlist
)
781 *setlist0
= setlist1
;
783 last0
->next
= setlist1
;
787 /* Define the automatic variables, and record the addresses
788 of their structures so we can change their values quickly. */
791 define_automatic_variables (void)
793 #if defined(WINDOWS32) || defined(__EMX__)
794 extern char* default_shell
;
796 extern char default_shell
[];
798 register struct variable
*v
;
801 sprintf (buf
, "%u", makelevel
);
802 define_variable_cname (MAKELEVEL_NAME
, buf
, o_env
, 0);
804 sprintf (buf
, "%s%s%s",
806 (remote_description
== 0 || remote_description
[0] == '\0')
808 (remote_description
== 0 || remote_description
[0] == '\0')
809 ? "" : remote_description
);
810 define_variable_cname ("MAKE_VERSION", buf
, o_default
, 0);
813 /* Allow to specify a special shell just for Make,
814 and use $COMSPEC as the default $SHELL when appropriate. */
816 static char shell_str
[] = "SHELL";
817 const int shlen
= sizeof (shell_str
) - 1;
818 struct variable
*mshp
= lookup_variable ("MAKESHELL", 9);
819 struct variable
*comp
= lookup_variable ("COMSPEC", 7);
821 /* $(MAKESHELL) overrides $(SHELL) even if -e is in effect. */
823 (void) define_variable (shell_str
, shlen
,
824 mshp
->value
, o_env_override
, 0);
827 /* $(COMSPEC) shouldn't override $(SHELL). */
828 struct variable
*shp
= lookup_variable (shell_str
, shlen
);
831 (void) define_variable (shell_str
, shlen
, comp
->value
, o_env
, 0);
834 #elif defined(__EMX__)
836 static char shell_str
[] = "SHELL";
837 const int shlen
= sizeof (shell_str
) - 1;
838 struct variable
*shell
= lookup_variable (shell_str
, shlen
);
839 struct variable
*replace
= lookup_variable ("MAKESHELL", 9);
841 /* if $MAKESHELL is defined in the environment assume o_env_override */
842 if (replace
&& *replace
->value
&& replace
->origin
== o_env
)
843 replace
->origin
= o_env_override
;
845 /* if $MAKESHELL is not defined use $SHELL but only if the variable
846 did not come from the environment */
847 if (!replace
|| !*replace
->value
)
848 if (shell
&& *shell
->value
&& (shell
->origin
== o_env
849 || shell
->origin
== o_env_override
))
851 /* overwrite whatever we got from the environment */
853 shell
->value
= xstrdup (default_shell
);
854 shell
->origin
= o_default
;
857 /* Some people do not like cmd to be used as the default
858 if $SHELL is not defined in the Makefile.
859 With -DNO_CMD_DEFAULT you can turn off this behaviour */
860 # ifndef NO_CMD_DEFAULT
861 /* otherwise use $COMSPEC */
862 if (!replace
|| !*replace
->value
)
863 replace
= lookup_variable ("COMSPEC", 7);
865 /* otherwise use $OS2_SHELL */
866 if (!replace
|| !*replace
->value
)
867 replace
= lookup_variable ("OS2_SHELL", 9);
869 # warning NO_CMD_DEFAULT: GNU make will not use CMD.EXE as default shell
872 if (replace
&& *replace
->value
)
873 /* overwrite $SHELL */
874 (void) define_variable (shell_str
, shlen
, replace
->value
,
877 /* provide a definition if there is none */
878 (void) define_variable (shell_str
, shlen
, default_shell
,
884 /* This won't override any definition, but it will provide one if there
886 v
= define_variable_cname ("SHELL", default_shell
, o_default
, 0);
888 v
->export
= v_export
; /* Export always SHELL. */
891 /* On MSDOS we do use SHELL from environment, since it isn't a standard
892 environment variable on MSDOS, so whoever sets it, does that on purpose.
893 On OS/2 we do not use SHELL from environment but we have already handled
894 that problem above. */
895 #if !defined(__MSDOS__) && !defined(__EMX__)
896 /* Don't let SHELL come from the environment. */
897 if (*v
->value
== '\0' || v
->origin
== o_env
|| v
->origin
== o_env_override
)
901 v
->value
= xstrdup (default_shell
);
905 /* Make sure MAKEFILES gets exported if it is set. */
906 v
= define_variable_cname ("MAKEFILES", "", o_default
, 0);
909 /* Define the magic D and F variables in terms of
910 the automatic variables they are variations of. */
913 define_variable_cname ("@D", "$(dir $@)", o_automatic
, 1);
914 define_variable_cname ("%D", "$(dir $%)", o_automatic
, 1);
915 define_variable_cname ("*D", "$(dir $*)", o_automatic
, 1);
916 define_variable_cname ("<D", "$(dir $<)", o_automatic
, 1);
917 define_variable_cname ("?D", "$(dir $?)", o_automatic
, 1);
918 define_variable_cname ("^D", "$(dir $^)", o_automatic
, 1);
919 define_variable_cname ("+D", "$(dir $+)", o_automatic
, 1);
921 define_variable_cname ("@D", "$(patsubst %/,%,$(dir $@))", o_automatic
, 1);
922 define_variable_cname ("%D", "$(patsubst %/,%,$(dir $%))", o_automatic
, 1);
923 define_variable_cname ("*D", "$(patsubst %/,%,$(dir $*))", o_automatic
, 1);
924 define_variable_cname ("<D", "$(patsubst %/,%,$(dir $<))", o_automatic
, 1);
925 define_variable_cname ("?D", "$(patsubst %/,%,$(dir $?))", o_automatic
, 1);
926 define_variable_cname ("^D", "$(patsubst %/,%,$(dir $^))", o_automatic
, 1);
927 define_variable_cname ("+D", "$(patsubst %/,%,$(dir $+))", o_automatic
, 1);
929 define_variable_cname ("@F", "$(notdir $@)", o_automatic
, 1);
930 define_variable_cname ("%F", "$(notdir $%)", o_automatic
, 1);
931 define_variable_cname ("*F", "$(notdir $*)", o_automatic
, 1);
932 define_variable_cname ("<F", "$(notdir $<)", o_automatic
, 1);
933 define_variable_cname ("?F", "$(notdir $?)", o_automatic
, 1);
934 define_variable_cname ("^F", "$(notdir $^)", o_automatic
, 1);
935 define_variable_cname ("+F", "$(notdir $+)", o_automatic
, 1);
938 int export_all_variables
;
940 /* Create a new environment for FILE's commands.
941 If FILE is nil, this is for the `shell' function.
942 The child's MAKELEVEL variable is incremented. */
945 target_environment (struct file
*file
)
947 struct variable_set_list
*set_list
;
948 register struct variable_set_list
*s
;
949 struct hash_table table
;
950 struct variable
**v_slot
;
951 struct variable
**v_end
;
952 struct variable makelevel_key
;
957 set_list
= current_variable_set_list
;
959 set_list
= file
->variables
;
961 hash_init (&table
, VARIABLE_BUCKETS
,
962 variable_hash_1
, variable_hash_2
, variable_hash_cmp
);
964 /* Run through all the variable sets in the list,
965 accumulating variables in TABLE. */
966 for (s
= set_list
; s
!= 0; s
= s
->next
)
968 struct variable_set
*set
= s
->set
;
969 v_slot
= (struct variable
**) set
->table
.ht_vec
;
970 v_end
= v_slot
+ set
->table
.ht_size
;
971 for ( ; v_slot
< v_end
; v_slot
++)
972 if (! HASH_VACANT (*v_slot
))
974 struct variable
**new_slot
;
975 struct variable
*v
= *v_slot
;
977 /* If this is a per-target variable and it hasn't been touched
978 already then look up the global version and take its export
980 if (v
->per_target
&& v
->export
== v_default
)
984 gv
= lookup_variable_in_set (v
->name
, strlen(v
->name
),
985 &global_variable_set
);
987 v
->export
= gv
->export
;
993 if (v
->origin
== o_default
|| v
->origin
== o_automatic
)
994 /* Only export default variables by explicit request. */
997 /* The variable doesn't have a name that can be exported. */
1001 if (! export_all_variables
1002 && v
->origin
!= o_command
1003 && v
->origin
!= o_env
&& v
->origin
!= o_env_override
)
1012 /* If this is the SHELL variable and it's not exported,
1013 then add the value from our original environment, if
1014 the original environment defined a value for SHELL. */
1015 extern struct variable shell_var
;
1016 if (streq (v
->name
, "SHELL") && shell_var
.value
)
1025 if (v
->origin
== o_default
)
1030 new_slot
= (struct variable
**) hash_find_slot (&table
, v
);
1031 if (HASH_VACANT (*new_slot
))
1032 hash_insert_at (&table
, v
, new_slot
);
1036 makelevel_key
.name
= MAKELEVEL_NAME
;
1037 makelevel_key
.length
= MAKELEVEL_LENGTH
;
1038 hash_delete (&table
, &makelevel_key
);
1040 result
= result_0
= xmalloc ((table
.ht_fill
+ 2) * sizeof (char *));
1042 v_slot
= (struct variable
**) table
.ht_vec
;
1043 v_end
= v_slot
+ table
.ht_size
;
1044 for ( ; v_slot
< v_end
; v_slot
++)
1045 if (! HASH_VACANT (*v_slot
))
1047 struct variable
*v
= *v_slot
;
1049 /* If V is recursively expanded and didn't come from the environment,
1050 expand its value. If it came from the environment, it should
1051 go back into the environment unchanged. */
1053 && v
->origin
!= o_env
&& v
->origin
!= o_env_override
)
1055 char *value
= recursively_expand_for_file (v
, file
);
1057 if (strcmp(v
->name
, "Path") == 0 ||
1058 strcmp(v
->name
, "PATH") == 0)
1059 convert_Path_to_windows32(value
, ';');
1061 *result
++ = xstrdup (concat (3, v
->name
, "=", value
));
1067 if (strcmp(v
->name
, "Path") == 0 ||
1068 strcmp(v
->name
, "PATH") == 0)
1069 convert_Path_to_windows32(v
->value
, ';');
1071 *result
++ = xstrdup (concat (3, v
->name
, "=", v
->value
));
1075 *result
= xmalloc (100);
1076 sprintf (*result
, "%s=%u", MAKELEVEL_NAME
, makelevel
+ 1);
1079 hash_free (&table
, 0);
1084 static struct variable
*
1085 set_special_var (struct variable
*var
)
1087 if (streq (var
->name
, RECIPEPREFIX_NAME
))
1089 /* The user is resetting the command introduction prefix. This has to
1090 happen immediately, so that subsequent rules are interpreted
1092 cmd_prefix
= var
->value
[0]=='\0' ? RECIPEPREFIX_DEFAULT
: var
->value
[0];
1098 /* Given a variable, a value, and a flavor, define the variable.
1099 See the try_variable_definition() function for details on the parameters. */
1102 do_variable_definition (const struct floc
*flocp
, const char *varname
,
1103 const char *value
, enum variable_origin origin
,
1104 enum variable_flavor flavor
, int target_var
)
1107 char *alloc_value
= NULL
;
1110 int conditional
= 0;
1112 /* Calculate the variable's new value in VALUE. */
1118 /* Should not be possible. */
1121 /* A simple variable definition "var := value". Expand the value.
1122 We have to allocate memory since otherwise it'll clobber the
1123 variable buffer, and we may still need that if we're looking at a
1124 target-specific variable. */
1125 p
= alloc_value
= allocated_variable_expand (value
);
1128 /* A conditional variable definition "var ?= value".
1129 The value is set IFF the variable is not defined yet. */
1130 v
= lookup_variable (varname
, strlen (varname
));
1132 return v
->special
? set_special_var (v
) : v
;
1135 flavor
= f_recursive
;
1138 /* A recursive variable definition "var = value".
1139 The value is used verbatim. */
1144 /* If we have += but we're in a target variable context, we want to
1145 append only with other variables in the context of this target. */
1149 v
= lookup_variable_in_set (varname
, strlen (varname
),
1150 current_variable_set_list
->set
);
1152 /* Don't append from the global set if a previous non-appending
1153 target-specific variable definition exists. */
1154 if (v
&& !v
->append
)
1158 v
= lookup_variable (varname
, strlen (varname
));
1162 /* There was no old value.
1163 This becomes a normal recursive definition. */
1165 flavor
= f_recursive
;
1169 /* Paste the old and new values together in VALUE. */
1171 unsigned int oldlen
, vallen
;
1177 /* The previous definition of the variable was recursive.
1178 The new value is the unexpanded old and new values. */
1179 flavor
= f_recursive
;
1181 /* The previous definition of the variable was simple.
1182 The new value comes from the old value, which was expanded
1183 when it was set; and from the expanded new value. Allocate
1184 memory for the expansion as we may still need the rest of the
1185 buffer if we're looking at a target-specific variable. */
1186 val
= tp
= allocated_variable_expand (val
);
1188 oldlen
= strlen (v
->value
);
1189 vallen
= strlen (val
);
1190 p
= alloc_value
= xmalloc (oldlen
+ 1 + vallen
+ 1);
1191 memcpy (alloc_value
, v
->value
, oldlen
);
1192 alloc_value
[oldlen
] = ' ';
1193 memcpy (&alloc_value
[oldlen
+ 1], val
, vallen
+ 1);
1202 /* Many Unix Makefiles include a line saying "SHELL=/bin/sh", but
1203 non-Unix systems don't conform to this default configuration (in
1204 fact, most of them don't even have `/bin'). On the other hand,
1205 $SHELL in the environment, if set, points to the real pathname of
1207 Therefore, we generally won't let lines like "SHELL=/bin/sh" from
1208 the Makefile override $SHELL from the environment. But first, we
1209 look for the basename of the shell in the directory where SHELL=
1210 points, and along the $PATH; if it is found in any of these places,
1211 we define $SHELL to be the actual pathname of the shell. Thus, if
1212 you have bash.exe installed as d:/unix/bash.exe, and d:/unix is on
1213 your $PATH, then SHELL=/usr/local/bin/bash will have the effect of
1214 defining SHELL to be "d:/unix/bash.exe". */
1215 if ((origin
== o_file
|| origin
== o_override
)
1216 && strcmp (varname
, "SHELL") == 0)
1218 PATH_VAR (shellpath
);
1219 extern char * __dosexec_find_on_path (const char *, char *[], char *);
1221 /* See if we can find "/bin/sh.exe", "/bin/sh.com", etc. */
1222 if (__dosexec_find_on_path (p
, NULL
, shellpath
))
1226 for (tp
= shellpath
; *tp
; tp
++)
1230 v
= define_variable_loc (varname
, strlen (varname
),
1231 shellpath
, origin
, flavor
== f_recursive
,
1236 const char *shellbase
, *bslash
;
1237 struct variable
*pathv
= lookup_variable ("PATH", 4);
1242 shellbase
= strrchr (p
, '/');
1243 bslash
= strrchr (p
, '\\');
1244 if (!shellbase
|| bslash
> shellbase
)
1246 if (!shellbase
&& p
[1] == ':')
1253 /* Search for the basename of the shell (with standard
1254 executable extensions) along the $PATH. */
1256 pathlen
= strlen (pathv
->value
);
1257 path_string
= xmalloc (5 + pathlen
+ 2 + 1);
1258 /* On MSDOS, current directory is considered as part of $PATH. */
1259 sprintf (path_string
, "PATH=.;%s", pathv
? pathv
->value
: "");
1260 fake_env
[0] = path_string
;
1262 if (__dosexec_find_on_path (shellbase
, fake_env
, shellpath
))
1266 for (tp
= shellpath
; *tp
; tp
++)
1270 v
= define_variable_loc (varname
, strlen (varname
),
1272 flavor
== f_recursive
, flocp
);
1275 v
= lookup_variable (varname
, strlen (varname
));
1281 #endif /* __MSDOS__ */
1283 if ((origin
== o_file
|| origin
== o_override
|| origin
== o_command
)
1284 && streq (varname
, "SHELL"))
1286 extern char *default_shell
;
1288 /* Call shell locator function. If it returns TRUE, then
1289 set no_default_sh_exe to indicate sh was found and
1290 set new value for SHELL variable. */
1292 if (find_and_set_default_shell (p
))
1294 v
= define_variable_in_set (varname
, strlen (varname
), default_shell
,
1295 origin
, flavor
== f_recursive
,
1297 ? current_variable_set_list
->set
1300 no_default_sh_exe
= 0;
1304 char *tp
= alloc_value
;
1306 alloc_value
= allocated_variable_expand (p
);
1308 if (find_and_set_default_shell (alloc_value
))
1310 v
= define_variable_in_set (varname
, strlen (varname
), p
,
1311 origin
, flavor
== f_recursive
,
1313 ? current_variable_set_list
->set
1316 no_default_sh_exe
= 0;
1319 v
= lookup_variable (varname
, strlen (varname
));
1328 /* If we are defining variables inside an $(eval ...), we might have a
1329 different variable context pushed, not the global context (maybe we're
1330 inside a $(call ...) or something. Since this function is only ever
1331 invoked in places where we want to define globally visible variables,
1332 make sure we define this variable in the global set. */
1334 v
= define_variable_in_set (varname
, strlen (varname
), p
,
1335 origin
, flavor
== f_recursive
,
1337 ? current_variable_set_list
->set
: NULL
),
1340 v
->conditional
= conditional
;
1345 return v
->special
? set_special_var (v
) : v
;
1348 /* Parse P (a null-terminated string) as a variable definition.
1350 If it is not a variable definition, return NULL.
1352 If it is a variable definition, return a pointer to the char after the
1353 assignment token and set *FLAVOR to the type of variable assignment. */
1356 parse_variable_definition (const char *p
, enum variable_flavor
*flavor
)
1366 /* If we find a comment or EOS, it's not a variable definition. */
1367 if (c
== '\0' || c
== '#')
1372 /* This begins a variable expansion reference. Make sure we don't
1373 treat chars inside the reference as assignment tokens. */
1382 /* '$$' or '$X'. Either way, nothing special to do here. */
1385 /* P now points past the opening paren or brace.
1386 Count parens or braces until it is matched. */
1388 for (; *p
!= '\0'; ++p
)
1392 else if (*p
== closeparen
&& --count
< 0)
1401 /* If we find whitespace skip it, and remember we found it. */
1402 if (isblank ((unsigned char)c
))
1415 *flavor
= f_recursive
;
1419 /* Match assignment variants (:=, +=, ?=) */
1431 *flavor
= f_conditional
;
1434 /* If we skipped whitespace, non-assignments means no var. */
1438 /* Might be assignment, or might be $= or #=. Check. */
1444 /* A colon other than := is a rule line, not a variable defn. */
1447 /* If we skipped whitespace, non-assignments means no var. */
1455 /* Try to interpret LINE (a null-terminated string) as a variable definition.
1457 If LINE was recognized as a variable definition, a pointer to its `struct
1458 variable' is returned. If LINE is not a variable definition, NULL is
1462 assign_variable_definition (struct variable
*v
, char *line
)
1466 enum variable_flavor flavor
;
1469 beg
= next_token (line
);
1470 line
= parse_variable_definition (beg
, &flavor
);
1474 end
= line
- (flavor
== f_recursive
? 1 : 2);
1475 while (end
> beg
&& isblank ((unsigned char)end
[-1]))
1477 line
= next_token (line
);
1481 /* Expand the name, so "$(foo)bar = baz" works. */
1482 name
= alloca (end
- beg
+ 1);
1483 memcpy (name
, beg
, end
- beg
);
1484 name
[end
- beg
] = '\0';
1485 v
->name
= allocated_variable_expand (name
);
1487 if (v
->name
[0] == '\0')
1488 fatal (&v
->fileinfo
, _("empty variable name"));
1493 /* Try to interpret LINE (a null-terminated string) as a variable definition.
1495 ORIGIN may be o_file, o_override, o_env, o_env_override,
1496 or o_command specifying that the variable definition comes
1497 from a makefile, an override directive, the environment with
1498 or without the -e switch, or the command line.
1500 See the comments for assign_variable_definition().
1502 If LINE was recognized as a variable definition, a pointer to its `struct
1503 variable' is returned. If LINE is not a variable definition, NULL is
1507 try_variable_definition (const struct floc
*flocp
, char *line
,
1508 enum variable_origin origin
, int target_var
)
1511 struct variable
*vp
;
1514 v
.fileinfo
= *flocp
;
1516 v
.fileinfo
.filenm
= 0;
1518 if (!assign_variable_definition (&v
, line
))
1521 vp
= do_variable_definition (flocp
, v
.name
, v
.value
,
1522 origin
, v
.flavor
, target_var
);
1529 /* Print information for variable V, prefixing it with PREFIX. */
1532 print_variable (const void *item
, void *arg
)
1534 const struct variable
*v
= item
;
1535 const char *prefix
= arg
;
1541 origin
= _("default");
1544 origin
= _("environment");
1547 origin
= _("makefile");
1549 case o_env_override
:
1550 origin
= _("environment under -e");
1553 origin
= _("command line");
1556 origin
= _("`override' directive");
1559 origin
= _("automatic");
1565 fputs ("# ", stdout
);
1566 fputs (origin
, stdout
);
1568 fputs (" private", stdout
);
1569 if (v
->fileinfo
.filenm
)
1570 printf (_(" (from `%s', line %lu)"),
1571 v
->fileinfo
.filenm
, v
->fileinfo
.lineno
);
1573 fputs (prefix
, stdout
);
1575 /* Is this a `define'? */
1576 if (v
->recursive
&& strchr (v
->value
, '\n') != 0)
1577 printf ("define %s\n%s\nendef\n", v
->name
, v
->value
);
1582 printf ("%s %s= ", v
->name
, v
->recursive
? v
->append
? "+" : "" : ":");
1584 /* Check if the value is just whitespace. */
1585 p
= next_token (v
->value
);
1586 if (p
!= v
->value
&& *p
== '\0')
1587 /* All whitespace. */
1588 printf ("$(subst ,,%s)", v
->value
);
1589 else if (v
->recursive
)
1590 fputs (v
->value
, stdout
);
1592 /* Double up dollar signs. */
1593 for (p
= v
->value
; *p
!= '\0'; ++p
)
1604 /* Print all the variables in SET. PREFIX is printed before
1605 the actual variable definitions (everything else is comments). */
1608 print_variable_set (struct variable_set
*set
, char *prefix
)
1610 hash_map_arg (&set
->table
, print_variable
, prefix
);
1612 fputs (_("# variable set hash-table stats:\n"), stdout
);
1613 fputs ("# ", stdout
);
1614 hash_print_stats (&set
->table
, stdout
);
1615 putc ('\n', stdout
);
1618 /* Print the data base of variables. */
1621 print_variable_data_base (void)
1623 puts (_("\n# Variables\n"));
1625 print_variable_set (&global_variable_set
, "");
1627 puts (_("\n# Pattern-specific Variable Values"));
1630 struct pattern_var
*p
;
1633 for (p
= pattern_vars
; p
!= 0; p
= p
->next
)
1636 printf ("\n%s :\n", p
->target
);
1637 print_variable (&p
->variable
, "# ");
1641 puts (_("\n# No pattern-specific variable values."));
1643 printf (_("\n# %u pattern-specific variable values"), rules
);
1648 /* Print all the local variables of FILE. */
1651 print_file_variables (const struct file
*file
)
1653 if (file
->variables
!= 0)
1654 print_variable_set (file
->variables
->set
, "# ");
1659 sync_Path_environment (void)
1661 char *path
= allocated_variable_expand ("$(PATH)");
1662 static char *environ_path
= NULL
;
1668 * If done this before, don't leak memory unnecessarily.
1669 * Free the previous entry before allocating new one.
1672 free (environ_path
);
1675 * Create something WINDOWS32 world can grok
1677 convert_Path_to_windows32 (path
, ';');
1678 environ_path
= xstrdup (concat (3, "PATH", "=", path
));
1679 putenv (environ_path
);