- Work around a bug in glibc glob(3), by avoiding GLOB_NOCHECK.
[make.git] / ChangeLog
blob1c2d0c4acd2c4a41a663fe021f36c5bf6632ade5
1 2009-06-06  Paul Smith  <psmith@gnu.org>
3         * remake.c (check_dep): Only set the target's state to not-started
4         if it's not already running.  Found this while testing -j10 builds
5         of glibc: various targets were being rebuilt multiple times.
7         * read.c (multi_glob): Don't pass GLOB_NOCHECK to glob(3); instead
8         handle the GLOB_NOMATCH error.  This is to work around Sourceware.org
9         Bugzilla bug 10246.
11 2009-06-04  Paul Smith  <psmith@gnu.org>
13         * read.c (eval): Skip initial whitespace (ffeed, vtab, etc.)
15         * maintMakefile: Modify access of config and gnulib Savannah
16         modules to use GIT instead of CVS.
18         * main.c (main): Initialize the LENGTH field in SHELL_VAR.
19         Fixes Savannah bug #24655.
21         * read.c (eval_buffer): Don't dereference reading_file if it's NULL;
22         this can happen during some invocations of $(eval ...) for example.
23         Fixes Savannah bug #24588.  Patch by Lars Jessen <ljessen@ljessen.dk>
25 2009-06-02  Paul Smith  <psmith@gnu.org>
27         * configure.in: Check for fileno()
28         * read.c (eval_makefile): If fileno() is available, set CLOSE_ON_EXEC
29         for the makefile file so invocations of $(shell ...) don't inherit it.
30         Fixes Savannah bug #24277.
32 2009-06-01  Paul Smith  <psmith@gnu.org>
34         * main.c (main): The previous fix for .DEFAULT_GOAL had issues;
35         expansion was handled incorrectly.  Rework the default goal
36         handling to save the variable only.  Remove default_goal_file and
37         default_goal_name.
38         * read.c (eval): Check default_goal_var, not default_goal_name.
39         * read.c (record_target_var): Don't check default_goal_file here.
41 2009-05-31  Paul Smith  <psmith@gnu.org>
43         * main.c (main): Expand the .DEFAULT_GOAL variable before using
44         it, and if the multi_glob() returns nothing (say it expanded to
45         nothing but spaces) then don't crash.  Fixes Savannah bug #25697.
47         * doc/make.texi (Quick Reference): Add $(if ..), $(or ..), and
48         $(and ..) to the reference.  Fixes Savannah bug #25694.
50         * make.1: Be clear that some recipes will be executed even with -n.
51         * doc/make.texi: Ditto.  Fixes Savannah bug #25460.
53         * doc/make.texi (Override Directive): Make more clear how
54         overrides and appends interact.
55         Elucidates part of Savannah bug #26207.
57         * read.c (record_target_var): Don't reset the origin on
58         target-specific variables; try_variable_definition() will handle
59         this correctly.  Fixes Savannah bug #26207.
61         * maintMakefile (do-po-update): Copy PO files into $(top_srcdir).
62         Fixes Savannah bug #25712.
64         * implicit.c (pattern_search): Keep a pointer to the beginning of
65         the filename and save that instead of the constructed pointer.
66         Fixes Savannah bug #26593.
67         Patch by Mark Seaborn <mrs@mythic-beasts.com>
69 2009-05-30  Paul Smith  <psmith@gnu.org>
71         * doc/make.texi (Multi-Line): Add a description of the new abilities
72         of define/endef.  Rename "Sequences" to "Multi-Line" and fix some
73         "command sequence" vs. "recipe" syntax.
74         * read.c (do_define): Modify to allow assignment tokens (=, :=, etc.)
75         after a define, to create variables with those flavors.
77 2009-05-25  Paul Smith  <psmith@gnu.org>
79         Reworked the parser for variable assignments to allow multiple
80         modifiers, and in any order.  Also allows variable and
81         prerequisites to be modifier names ('export', 'private', etc.)
83         * NEWS: Add notes about user-visible changes.
85         * read.c (struct vmodifiers): Remember what modifiers were seen.
86         (parse_var_assignment): New function to parse variable assignments.
87         (eval): Call the new function.  Handle variable assignments earlier.
89         * variable.c (parse_variable_definition): Only parse; don't create var.
90         (assign_variable_definition): Call parse, then create the var.
92 2009-05-24  Paul Smith  <psmith@gnu.org>
94         * doc/make.texi: Fix the ISBN for the GNU make manual.  Incorrect
95         value noticed by Hans Stol <hans.stol@nc3a.nato.int>.
97 2009-03-14  Eli Zaretskii  <eliz@gnu.org>
99         * w32/pathstuff.c (convert_Path_to_windows32): Fix last change.
100         Fixes Savannah bug #25412.
102         * w32/subproc/sub_proc.c <top level>: Update Copyright years.  Add
103         prototype for xmalloc.
104         (find_file): Accept 3 arguments PATH_VAR, FULL_FNAME, and FULL_LEN
105         instead of an LPOFSTRUCT pointer.  Use xmalloc instead of malloc.
106         Loop over an array of extensions, instead of duplicating the same
107         code inline.  Use SearchPath followed by CreateFile, instead of
108         the obsolete OpenFile.  Fixes Savannah bug #17277.
109         (process_begin): Find $(PATH) in `envp', and pass a pointer to it
110         to `find_file'.  Fixes Savannah bug #25662.
112 2009-03-07  Eli Zaretskii  <eliz@gnu.org>
114         * function.c (func_shell): Don't close pipedes[1] if it is -1.
115         Fixes Savannah bug #20495.
117 2009-02-23  Ramon Garcia  <ramon.garcia.f@gmail.com>
119         Introduce a new keyword "private" which applies to target-specific
120         variables and prevents their values from being inherited.
122         * variable.h (struct variable): Add private_var flag to each variable.
123         Add a flag to specify which list entry switches to the parent target.
124         * variable.c (define_variable_in_set): Initialize private_var flag.
125         (lookup_variable): Skip private variables in parent contexts.
126         (initialize_file_variables): Set next_is_parent appropriately.
127         (print_variable): Show the private_var flag.
128         * read.c (eval): Recognize the private keyword.
129         (record_target_var): Set private_var.
130         * doc/make.texi (Suppressing Inheritance): Add documentation.
132 2008-10-26  Paul Smith  <psmith@gnu.org>
134         * configure.in: Check for strndup().
135         * misc.c (xstrndup): Rename savestring to xstrndup.  Use strndup
136         if it's available.
137         * make.h: Rename savestring to xstrndup.
138         * commands.c (chop_commands): Ditto.
139         * function.c (func_foreach): Ditto.
140         * read.c (eval, record_files): Ditto.
141         * variable.c (define_variable_in_set): Ditto.
143 2008-09-30  Eli Zaretskii  <eliz@gnu.org>
145         * build_w32.bat (GCCBuild): Use "-gdwarf-2 -g3" instead of
146         "-gstabs+ -ggdb3".
148         * w32/subproc/build.bat (GCCBuild): Likewise.
150 2008-09-30  David Russo  <d-russo@ti.com>  (tiny change)
152         * job.c (construct_command_argv_internal): Avoid extra backslash
153         in batch-mode Unixy shells.  Under DB_JOBS, display the contents
154         of the batch file.
156 2008-05-31  Eli Zaretskii  <eliz@gnu.org>
158         * README.W32.template: Remove obsolete text about non-support for
159         -jN without Unixy shell.  Remove obsolete text about not supplying
160         Visual Studio project files (we do supply them).  Modify text to
161         prefer GCC builds to MSC builds.
163 2008-04-02  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
165         * doc/make.texi (Empty Targets): Fix typo.
167 2008-03-27  Paul Smith  <psmith@gnu.org>
169         Fix Savannah bug #22379:
170         * ar.c (ar_glob_match): Zero the allocated structure.
171         * read.c (parse_file_seq): Ditto.
173 2008-03-08  Brian Dessent  <brian@dessent.net>
175         * maintMakefile: Update Translation Project location.
177 2008-01-26  Eli Zaretskii  <eliz@gnu.org>
179         * variable.c (target_environment): Don't use shell_var if its
180         `value' field is NULL.
182 2007-12-22  Eli Zaretskii  <eliz@gnu.org>
184         Suggested by Juan Manuel Guerrero <juan.guerrero@gmx.de>:
186         * Makefile.DOS.template (info_TEXINFOS): Remove unused variable.
187         (TEXINFOS): Value changed to `doc/make.texi'.
188         (.SUFFIXES): Use .texi instead of .texinfo.
189         (make.info, make.dvi): Depend on doc/make.texi.
190         (.texi.info): New target, instead of ".texinfo.info".  Change -I
191         switch to $(MAKEINFO) to look in doc/.  Use --no-split.
192         (.texi): New target, instead of ".texinfo".  Change -I switch to
193         $(MAKEINFO) to look in doc/.  Use --no-split.
194         (.texi.dvi): New target, instead of ".texinfo.dvi".  Change -I
195         switch to $(MAKEINFO) to look in doc/.
196         (install-info-am, uninstall-info): Don't look for "*.i[0-9]" and
197         "*.i[0-9][0-9]" (due to --no-split above).
198         (noinst_TEXINFOS, TEXI2HTML, TEXI2HTML_FLAGS): New variables.
199         (html, make_1.html): New targets.
200         (.PHONY): Add "html".
201         (.SUFFIXES): Add .html.
203 2007-12-22  Juan Manuel Guerrero  <juan.guerrero@gmx.de>  (tiny change)
205         * configh.dos.template [__DJGPP__]: Replace HAVE_SYS_SIGLIST with
206         HAVE_DECL_SYS_SIGLIST.
208         * job.c (child_execute_job): Remove __MSDOS__ because MSDOS/DJGPP
209         build does not use child_execute_job.
211         * variable.c (define_automatic_variables) [__MSDOS__]: Always
212         export the SHELL environment variable to the child.
214 2007-12-22  Eli Zaretskii  <eliz@gnu.org>
216         * config.h.W32: Include sys/types.h.
217         [!_PID_T_] (pid_t): Define only if not already defined by sys/types.h.
219         * vpath.c (construct_vpath_list) [HAVE_DOS_PATHS]: Support VPATH
220         values that use `:' in drive letters, when PATH_SEPARATOR_CHAR is
221         also `:'.
223 2007-11-04  Paul Smith  <psmith@gnu.org>
225         * doc/make.texi: Convert references to "commands", "command
226         lines", and "command script" to "recipe".
227         * NEWS: Ditto.
228         * commands.c, file.c, job.c, remake.c, read.c, variable.c, main.c:
229         Ditto.
231 2007-10-27  Bruno Haible  <bruno@clisp.org>
233         * remake.c (f_mtime): Print time difference values between 100 and
234         ULONG_MAX in fixed-point notation rather than in exponention notation.
236 2007-10-12  Eli Zaretskii  <eliz@gnu.org>
238         * variable.c (do_variable_definition): Allow $(SHELL) to expand to
239         a more complex value than a simple shell: if it's not a default
240         shell now then expand it and see if is a default shell then.
242 2007-10-10  Eli Zaretskii  <eliz@gnu.org>
244         * dir.c (find_directory) [WINDOWS32]: Remove trailing slashes from
245         pathnames, with const strings.
246         * build_w32.bat [WINDOWS32]: If no config.h.W32 exists, create one
247         from the template (used for building from CVS, not a dist).
249 2007-10-10  Paul Smith  <psmith@gnu.org>
251         * make.h: Add a prototype for w32_kill() (change suggested by
252         Yongwei Wu <wuyongwei@gmail.com>).
254 2007-09-21  Eli Zaretskii  <eliz@gnu.org>
256         * w32/pathstuff.c (convert_Path_to_windows32): Handle quoted
257         directories in Path.
259 2007-09-12  Paul Smith  <psmith@gnu.org>
261         * doc/make.texi: Applied wording cleanups from Savannah patch #6195.
262         Provided by Diego Biurrun <diego@biurrun.de>
263         (Complex Makefile): Remove .PHONY setting for tar: patch #6196.
264         Provided by Diego Biurrun <diego@biurrun.de>
266 2007-09-11  Paul Smith  <psmith@gnu.org>
268         * doc/make.texi (Special Variables): Moved this into the "How to
269         Use Variables" chapter.  Added a table entry for .RECIPEPREFIX.
270         (MAKEFILE_LIST) No longer a section; this was added into the
271         "Special Variables" section.
272         (Rule Introduction): Reference .RECIPEPREFIX.
273         (Simple Makefile): Ditto.
274         (Rule Syntax): Ditto.
275         (Command Syntax): Ditto.
276         (Error Messages): Ditto.
278 2007-09-10  Paul Smith  <psmith@gnu.org>
280         * commands.c (print_commands): Don't print an extra line in the
281         command scripts.  Prefix the command scripts with cmd_prefix, not \t.
283         * read.c (construct_include_path): Add the full string to the cache; we
284         were chopping the last char.
286         * NEWS: Announce the .RECIPEPREFIX special variable.
287         * variable.c (lookup_special_var): Rename from handle_special_var().
288         (lookup_variable): Call the new name.
289         (set_special_var): New function: handle setting of special variables.
290         When setting .RECIPEPREFIX, reset the cmd_prefix global variable.
291         (do_variable_definition): Call it.
292         * make.h (RECIPEPREFIX_DEFAULT): Define the default command prefix char.
293         (RECIPEPREFIX_NAME): Define the command prefix special variable name.
294         * main.c (main): Create the .RECIPEPREFIX special variable.
295         * read.c (eval): Remove the cmd_prefix characters from the command
296         scripts here, so they're not stored in the commands array at all,
297         rather than waiting and stripping them out during command construction.
298         * job.c (construct_command_argv_internal): Don't skip cmd_prefix here.
300 2007-08-15  Paul Smith  <psmith@gnu.org>
302         * doc/make.texi (GNU Free Documentation License): The fdl.texi
303         file has had the section info removed, so add some to make.texi
304         before we include it.
306 2007-08-15  Icarus Sparry  <savannah@icarus.freeuk.com>
308         * remake.c (check_dep): Reset the target state for intermediate
309         files.  They might have been considered before but not updated
310         then (order-only for example) but they will be this time.
311         Fixes Savannah bug #'s 3330 and 15919.
313 2007-07-21  Eli Zaretskii  <eliz@gnu.org>
315         Fix Savannah bug #20549:
316         * function.c (func_shell): Call construct_command_argv with zero
317         value of FLAGS.
318         * job.c (construct_command_argv_internal): New argument FLAGS; all
319         callers changed.
320         [WINDOWS32]: If FLAGS has the COMMANDS_RECURSE bit set, ignore
321         just_print_flag.
322         * job.h (construct_command_argv_internal): Update prototype.
324 2007-07-13  Paul Smith  <psmith@gnu.org>
326         * file.c (expand_deps): Use variable_buffer as the start of the
327         buffer, not the original pointer (in case it was reallocated).
328         Fix suggested by Rafi Einstein <rafi.einstein@formalism-labs.com>.
329         Fixes Savannah bug #20452.
331 2007-07-04  Paul Smith  <psmith@gnu.org>
333         * (ALL FILES): Update to GPLv3.
334         * (ALL FILES): Update copyright for 2007.
336         * main.c (print_version): Move the host type info to the second line.
338 2007-06-29  Thiemo Seufer  <ths@mips.com>
340         * maintMakefile: Update Translation Project location.
342 2007-06-13  Paul Smith  <psmith@gnu.org>
344         * doc/make.texi (Reading Makefiles): "Expansion of deferred" ->
345         "Expansion of a deferred"
346         Fixes Savannah bug #20018.
348         * expand.c (variable_expand_for_file): Preserve the value of
349         reading_file rather than setting it to 0 at the end.
350         Fixes Savannah bug #20033.
352 2007-05-11  Paul Smith  <psmith@gnu.org>
354         * job.c (new_job): Add debug info to specify where make found the
355         command script it is running to build a target.
356         Fixes Savannah bug #18617.
358         * default.c (default_suffixes,default_suffix_rules,default_variables):
359         Add support for Objective C.  Fixes Savannah bug #16389.
360         Based on a patch provided by Peter O'Gorman <peter@pogma.com>.
362         * function.c (func_lastword): Initialize p.
364         * doc/make.texi (Eval Function, Implicit Variables, Special Targets):
365         Doc fixes noticed by Bob <twobanjobob@sbcglobal.net>.  Patch from
366         Dave Korn <dave.korn@artimi.com>
368 2007-05-08  Paul Smith  <psmith@gnu.org>
370         Fix Savannah bug #19656:
372         * configure.in: Check for strcasecmp(), strcmpi(), and stricmp().
374         * make.h: Change all case-insensitive string compares to use
375         strcasecmp() (from POSIX).  If we don't have that but do have one
376         of the others, define strcasecmp to be one of those instead.  If
377         we don't have any, declare a prototype for our own version.
379         * misc.c (strcasecmp): Use this if we can't find any native
380         case-insensitive string comparison function.
381         * vmsfunctions.c: Remove strcmpi(); we'll use misc.c:strcasecmp().
382         * main.c (find_and_set_default_shell): Use strcasecmp() instead of
383         strcmpi().
384         * job.c (_is_unixy_shell, construct_command_argv_internal): Use
385         strcasecmp() instead of stricmp().
386         * hash.h (ISTRING_COMPARE, return_ISTRING_COMPARE): Use strcasecmp()
387         instead of strcmpi().
388         * acinclude.m4: Remove the strcasecmp() check from here.
390 2007-03-21  Paul Smith  <psmith@gnu.org>
392         * configure.in: Don't turn on case-insensitive file system support
393         if --disable-... is given.  Fixes Savannah bug #19348.
395 2007-03-19  Paul Smith  <psmith@gnu.org>
397         * ALL: Use the strcache for all file name strings, or other
398         strings which we will never free.  The goal is to save memory by
399         avoiding duplicate copies of strings.  However, at the moment this
400         doesn't save much memory in most situations: due to secondary
401         expansion we actually save prerequisite lists twice (once before
402         the secondary expansion, and then again after it's been parsed
403         into individual file names in the dep list).  We will resolve this
404         in a future change, by doing the parsing up-front for targets
405         where secondary expansion is not set.
407         Moving things into the strcache also allows us to use const
408         pointers in many more places.
410 2007-01-03  Paul Smith  <psmith@gnu.org>
412         * make.h (ENULLLOOP): Reset errno after each failed invocation of
413         the function, not just the first.  Fixes Savannah bug #18680.
415 2006-11-18  Paul Smith  <psmith@gnu.org>
417         * strcache.c (strcache_add_len): Don't allocate a new buffer
418         unless the string is not already nil-terminated.  Technically this
419         is a violation of the standard, since we may be passed an array
420         that is not long enough to test one past.  However, in make this
421         is never true since we only use nil-terminated strings or
422         sub-strings thereof.
424         * read.c (eval, do_define): Use cmd_prefix instead of '\t'.
426         * main.c: New global cmd_prefix, defaults to '\t'.
427         * job.c (construct_command_argv_internal): Use cmd_prefix instead
428         of '\t'.
430         * dir.c: Constified.
431         (dir_contents_file_exists_p): Check for an error return from
432         readdir(), just in case.
434         * commands.c: Constified.
435         * default.c: Constified.
436         * expand.c: Constified.
437         * function.c: Partial constification.
438         * variable.c: Partial constification.
439         * vmsify.c: Constification.  Hard to test this but I hope I didn't
440         screw it up!
441         * vpath.c: Partial constification.
442         * w32/pathstuff.c: Partial constification.
444 2006-11-16  Eli Zaretskii  <eliz@gnu.org>
446         * main.c (main) [HAVE_DOS_PATHS]: Treat DOS style argv[0] with
447         backslashes and drive letters as absolute.
449 2006-10-22  Paul Smith  <psmith@gnu.org>
451         * main.c (struct command_switch): Use const and void*.
453 2006-10-21  Paul Smith  <psmith@gnu.org>
455         * ar.c: Constified.
456         * arscan.c: Constified.
458 2006-09-30  Paul Smith  <psmith@gnu.org>
460         * doc/make.texi (MAKEFILE_LIST Variable): Modify reference to
461         point to lastword since the example was updated.
462         Fixes Savannah bug #16304.
463         (Secondary Expansion): Correct example description.
464         Fixes Savannah bug #16468.
465         (Makefile Contents): Clarify that comments cannot appear within
466         variable references or function calls.
467         Fixes Savannah bug #16577.
468         (Special Targets): Clarify how .NOTPARALLEL works in recursion.
469         Fixes Savannah bug #17701.
470         Reported by Ralf Wildenhues <Ralf.Wildenhues@gmx.de>:
471         (Prerequisite Types): Added an example of using order-only
472         prerequisites.  Fixes Savannah bug #17880.
473         (Rule Syntax): "lise" -> "list"
474         (Multiple Rules): ... -> @dots{}
475         (Splitting Lines): ditto.
477         * remake.c (update_file_1): Prereqs that don't exist should be
478         considered changed, for the purposes of $?.
479         Fixes Savannah bug #16051.
481         * make.1: Remove extraneous "+".
482         Fixes Savannah bug #16652.
484 2006-09-06  Paul D. Smith  <psmith@gnu.org>
486         * configure.in: Include sys/types.h when checking for sys/wait.h.
488 2006-08-18  Eli Zaretskii  <eliz@gnu.org>
490         * configure.in (PATH_SEPARATOR_CHAR): Define to the value of
491         $PATH_SEPARATOR.
493         * make.h (PATH_SEPARATOR_CHAR): Define only if still undefined.
494         Normally, it is defined in config.h.
496         * config/dospaths.m4 <ac_cv_dos_paths>: Define to yes on Cygwin as
497         well.
499         * job.c (construct_command_argv_internal) [HAVE_DOS_PATHS]: Define
500         sh_chars_sh for Windows platforms that emulate Unix.
502 2006-05-07  Paul D. Smith  <psmith@gnu.org>
504         * README.OS2.template: Updates provided by Andreas Buening
505         <andreas.buening@nexgo.de>.
507 2006-04-30  Paul D. Smith  <psmith@gnu.org>
509         * make.h: Include <direct.h> if HAVE_DIRECT_H.
510         * config.h.W32.template (HAVE_DIRECT_H): Set it if it's available.
512 2006-04-26  Paul D. Smith  <psmith@gnu.org>
514         * README.cvs: Add a reminder to notify the GNU translation robot.
516         * doc/make.texi: Change @direcategory (requested by Karl Berry).
518 2006-04-20  Paul D. Smith  <psmith@gnu.org>
520         * maintMakefile (po-check): Use Perl instead of grep -E, for systems
521         that don't have extended grep.
522         (cvsclean): Use $(PERL) instead of perl.
524 2006-04-09  Paul D. Smith  <psmith@gnu.org>
526         * maintMakefile: Add some extra warning options (GCC 4.1 only?)
528         * expand.c, implicit.c, main.c, read.c: Rename variables so that
529         inner-scope variables don't mask outer-scope variables.
531         * ar.c, arscan.c, commands.c, default.c, dir.c, expand.c, file.c:
532         * function.c, getloadavg.c, implicit.c, job.c, main.c, misc.c, read.c:
533         * remake.c, remote-cstms.c, rule.c, strcache.c, variable.c:
534         * vmsfunctions.c, vmsify.c, vpath.c: Remove all casts of returned
535         values from memory allocation functions: they return void* and so
536         don't need to be cast.  Also remove (char *) casts of arguments to
537         xrealloc().
539         * configure.in: Remove checks for memcpy/memmove/strchr.
541         * make.h: Remove bcmp/bcopy/bzero/strchr/strrchr macros.
543         * ar.c, arscan.c, commands.c, dir.c: Convert all bzero/bcopy/bcmp
544         calls to memset/memcpy/memmove/memcmp calls.
545         * expand.c, file.c, function.c, getloadavg.c, implicit.c: Ditto.
546         * job.c, main.c, misc.c, read.c, remake.c, rule.c: Ditto.
547         * variable.c, vpath.c: Ditto.
549         * make.h (EXIT_FAILURE): Should be 1, not 0.
551 2006-04-06  Paul D. Smith  <psmith@gnu.org>
553         * configure.in: Removed AM_C_PROTOTYPES.  Starting now on we
554         require an ISO C 1989 standard compiler and runtime library.
556         * Makefile.am: Remove the ansi2knr feature.
558         * make.h: Remove the PARAMS() macro definition and all uses of it.
560         * amiga.h, ar.c, arscan.c: Remove all uses of the PARAMS() macro.
561         * commands.c, commands.h, config.h-vms.template: Ditto.
562         * dep.h, dir.c, expand.c, filedef.h, function.c: Ditto.
563         * implicit.c, job.c, job.h, main.c, read.c, remake.c: Ditto.
564         * rule.c, rule.h, variable.h, vmsdir.h, vmsjobs.c, vpath.c: Ditto.
566         * NEWS: Update.
568 2006-04-01  Paul D. Smith  <psmith@gnu.org>
570         Version 3.81 released.
572         * NEWS: Updated for 3.81.
574         * README.cvs: Mention that vpath builds are not supported out of
575         CVS.  Fixes Savannah bug #16236.
576         Remove update of make.texi from the list of things to do; we use
577         version.texi now.
579 2006-03-26  Paul D. Smith  <psmith@gnu.org>
581         * doc/make.texi: Clean up licensing.  Use @copying and version.texi
582         support from automake, as described in the Texinfo manual.
584 2006-03-25  Eli Zaretskii  <eliz@gnu.org>
586         * implicit.c (pattern_search) [HAVE_DOS_PATHS]: Don't compare b
587         with lastslash, since the latter points to filename, not to
588         target.
589         * job.c (construct_command_argv_internal) [HAVE_DOS_PATHS]:
590         Declare and define sh_chars_sh[].
592 2006-03-23  Paul D. Smith  <psmith@gnu.org>
594         * configure.in: Look for build.sh.in in $srcdir so it will be
595         built for remote configurations as well.
597         * Makefile.am: Make sure to clean up build.sh during distclean.
598         Fixes Savannah bug #16166.
600         * misc.c (log_access): Takes a const char *.
601         * function.c (fold_newlines): Takes an unsigned int *.
602         Both fixes for Savannah bug #16170.
604 2006-03-22  Boris Kolpackov  <boris@kolpackov.net>
606         * implicit.c (pattern_search): Call set_file_variables only
607         if we have prerequisites that need second expansion. Fixes
608         Savannah bug #16140.
610 2006-03-19  Paul D. Smith  <psmith@gnu.org>
612         * remake.c (update_file): Add alloca(0) to clean up alloca'd
613         memory on hosts that don't support it directly.
615         * README.cvs: Add information on steps for making a release (to
616         make sure I don't forget any).
618         * main.c (clean_jobserver): Move jobserver cleanup code into a new
619         function.
620         (die): Cleanup code was removed from here; call the new function.
621         (main): If we are re-execing, clean up the jobserver first so we
622         don't leak file descriptors.
623         Reported by Craig Fithian <craig.fithian@citigroup.com>
625 2006-03-17  Paul D. Smith  <psmith@gnu.org>
627         * maintMakefile (do-po-update): Rewrite this rule to clean up and
628         allow multiple concurrent runs.
629         Patch from Joseph Myers <joseph@codesourcery.com>
631 2006-03-17  Boris Kolpackov  <boris@kolpackov.net>
633         * dep.h (struct dep): Add the stem field.
634         * misc.c (alloc_dep, free_dep): New functions.
635         (copy_dep_chain): Copy stem.
636         (free_dep_chain): Use free_dep.
637         * read.c (record_files): Store stem in the dependency line.
638         * file.c (expand_deps): Use stem stored in the dependency line. Use
639         free_dep_chain instead of free_ns_chain.
640         * implicit.c (pattern_search): Use alloc_dep and free_dep.
641         * read.c (read_all_makefiles, eval_makefile, eval): Ditto.
642         * main.c (main, handle_non_switch_argument): Ditto.
643         * remake.c (check_dep): Ditto.
644         * rule.c (convert_suffix_rule, freerule): Ditto.
646 2006-03-14  Paul D. Smith  <psmith@gnu.org>
648         * expand.c (variable_append): Instead of appending everything then
649         expanding the result, we expand (or not, if it's simple) each part
650         as we add it.
651         (allocated_variable_append): Don't expand the final result.
652         Fixes Savannah bug #15913.
654 2006-03-09  Paul Smith  <psmith@gnu.org>
656         * remake.c (update_file_1): Revert the change of 3 Jan 2006 which
657         listed non-existent files as changed.  Turns out there's a bug in
658         the Linux kernel builds which means that this change causes
659         everything to rebuild every time.  We will re-introduce this fix
660         in the next release, to give them time to fix their build system.
661         Fixes Savannah bug #16002.
662         Introduces Savannah bug #16051.
664         * implicit.c (pattern_search) [DOS_PATHS]: Look for DOS paths if
665         we *don't* find UNIX "/".
666         Reported by David Ergo <david.ergo@alterface.com>
668 2006-03-04  Eli Zaretskii  <eliz@gnu.org>
670         * variable.c (do_variable_definition) [WINDOWS32]: Call the shell
671         locator function find_and_set_default_shell if SHELL came from the
672         command line.
674 2006-02-20  Paul D. Smith  <psmith@gnu.org>
676         * variable.c (merge_variable_set_lists): It's legal for *setlist0
677         to be null; don't core in that case.
679 2006-02-19  Paul D. Smith  <psmith@gnu.org>
681         * commands.c (set_file_variables): Realloc, not malloc, the static
682         string values to avoid memory leaks.
684         * expand.c (recursively_expand_for_file): Only set reading_file to
685         an initialized value.
687         * implicit.c (pattern_search): We need to make a copy of the stem
688         if we get it from an intermediate dep, since those get freed.
690         * file.c (lookup_file) [VMS]: Don't lowercase special targets that
691         begin with ".".
692         (enter_file) [VMS]: Ditto.
693         Patch provided by Hartmut Becker <Hartmut.Becker@hp.com>.
695 2006-02-24  Eli Zaretskii  <eliz@gnu.org>
697         * job.c (construct_command_argv_internal): Fix last change.
699         * w32/subproc/sub_proc.c (process_pipe_io): Make dwStdin,
700         dwStdout, and dwStderr unsigned int: avoids compiler warnings in
701         the calls to _beginthreadex.
703         * expand.c (recursively_expand_for_file): Initialize `save' to
704         prevent compiler warnings.
706 2006-02-18  Eli Zaretskii  <eliz@gnu.org>
708         * job.c (construct_command_argv_internal): Don't create a temporary
709         script/batch file if we are under -n.  Call _setmode to switch the
710         script file stream to text mode.
712 2006-02-17  Paul D. Smith  <psmith@gnu.org>
714         * variable.c (merge_variable_set_lists): Don't try to merge the
715         global_setlist.  Not only is this useless, but it can lead to
716         circularities in the linked list, if global_setlist->next in one
717         list gets set to point to another list which also ends in
718         global_setlist.
719         Fixes Savannah bug #15757.
721 2006-02-15  Paul D. Smith  <psmith@gnu.org>
723         Fix for Savannah bug #106.
725         * expand.c (expanding_var): Keep track of which variable we're
726         expanding.  If no variable is being expanded, it's the same as
727         reading_file.
728         * make.h (expanding_var): Declare it.
729         * expand.c (recursively_expand_for_file): Set expanding_var to the
730         current variable we're expanding, unless there's no file info in
731         it (could happen if it comes from the command line or a default
732         variable).  Restore it before we exit.
733         * expand.c (variable_expand_string): Use the expanding_var file
734         info instead of the reading_file info.
735         * function.c (check_numeric): Ditto.
736         (func_word): Ditto.
737         (func_wordlist): Ditto.
738         (func_error): Ditto.
739         (expand_builtin_function): Ditto.
740         (handle_function): Ditto.
742 2006-02-14  Paul D. Smith  <psmith@gnu.org>
744         * read.c (eval): Even if the included filenames expands to the
745         empty string we still need to free the allocated buffer.
747         * implicit.c (pattern_search): If we allocated a variable set for
748         an impossible file, free it.
749         * variable.c (free_variable_set): New function.
750         * variable.h: Declare it.
752         * read.c (read_all_makefiles): Makefile names are kept in the
753         strcache, so there's never any need to alloc/free them.
754         (eval): Ditto.
756         * main.c (main): Add "archives" to the .FEATURES variable if
757         archive support is enabled.
758         * doc/make.texi (Special Variables): Document it.
760 2006-02-13  Paul D. Smith  <psmith@gnu.org>
762         * implicit.c (pattern_search): Add checking for DOS pathnames to
763         the pattern rule target LASTSLASH manipulation.
764         Fixes Savannah bug #11183.
766 2006-02-11  Paul D. Smith  <psmith@gnu.org>
768         * (ALL FILES): Updated copyright and license notices.
770 2006-02-10  Paul D. Smith  <psmith@gnu.org>
772         A new internal capability: the string cache is a read-only cache
773         of strings, with a hash table interface for fast lookup.  Nothing
774         in the cache will ever be freed, so there's no need for reference
775         counting, etc.  This is the beginning of a full solution for
776         Savannah bug #15182, but for now we only store makefile names here.
778         * strcache.c: New file.  Implement a read-only string cache.
779         * make.h: Add prototypes for new functions.
780         * main.c (initialize_global_hash_tables): Initialize the string cache.
781         (print_data_base): Print string cache stats.
782         * read.c (eval_makefile): Use the string cache to store makefile
783         names.  Rewrite the string allocation to be sure we free everything.
785 2006-02-10  Eli Zaretskii  <eliz@gnu.org>
787         * dir.c (dir_contents_file_exists_p): Don't opendir if the
788         directory time stamp didn't change, except on FAT filesystems.
789         Suggested by J. David Bryan <jdbryan@acm.org>.
791 2006-02-09  Paul D. Smith  <psmith@gnu.org>
793         * function.c (func_or): Implement a short-circuiting OR function.
794         (func_and): Implement a short-circuiting AND function.
795         (function_table_init): Update the table with the new functions.
796         * doc/make.texi (Conditional Functions): Changed the "if" section
797         to one on general conditional functions.  Added documentation for
798         $(and ...) and $(or ...) functions.
799         * NEWS: Note new $(and ...) and $(or ...) functions.
801 2006-02-08  Boris Kolpackov  <boris@kolpackov.net>
803         * job.h (struct child): Add the dontcare bitfield.
804         * job.c (new_job): Cache dontcare flag.
805         * job.c (reap_children): Use cached dontcare flag instead of the
806         one in struct file. Fixes Savannah bug #15641.
808 2006-02-06  Paul D. Smith  <psmith@gnu.org>
810         * vpath.c (selective_vpath_search): If the file we find has a
811         timestamp from -o or -W, use that instead of the real time.
812         * remake.c (f_mtime): If the mtime is a special token from -o or
813         -W, don't overwrite it with the real mtime.
814         Fixes Savannah bug #15341.
816         Updates from Markus Mauhart <qwe123@chello.at>:
818         * w32/subproc/sub_proc.c (process_begin): Remove no-op tests.
819         (process_signal, process_last_err, process_exit_code): Manage
820         invalid handle values.
821         (process_{outbuf,errbuf,outcnt,errcnt,pipes}): Unused and don't
822         manage invalid handles; remove them.
823         * job.c (start_job_command) [WINDOWS32]: Jump out on error.
824         * config.h.W32.template [WINDOWS32]: Set flags for Windows builds.
825         * README.cvs: Updates for building from CVS.
827 2006-02-05  Paul D. Smith  <psmith@gnu.org>
829         * file.c (enter_file): Keep track of the last double_colon entry,
830         to avoid walking the list every time we want to add a new one.
831         Fixes Savannah bug #15533.
832         * filedef.h (struct file): Add a new LAST pointer.
834         * dir.c (directory_contents_hash_cmp): Don't use subtraction to do
835         the comparison.  For 64-bits systems the result of the subtraction
836         might not fit into an int.  Use comparison instead.
837         Fixes Savannah bug #15534.
839         * doc/make.texi: Update the chapter on writing commands to reflect
840         the changes made in 3.81 for backslash/newline and SHELL handling.
842 2006-02-01  Paul D. Smith  <psmith@gnu.org>
844         * dir.c (dir_contents_file_exists_p) [WINDOWS32]: Make sure
845         variable st is not used when it's not initialized.
846         Patch from Eli Zaretskii <eliz@gnu.org>.
848 2006-01-31  Paul D. Smith  <psmith@gnu.org>
850         * README.W32.template: Applied patch #4785 from
851         Markus Mauhart <qwe123@chello.at>.
852         * README.cvs: Applied patch #4786 from
853         Markus Mauhart <qwe123@chello.at>.
854         * make_msvc_net2003.vcproj [WINDOWS32]: New version from
855         J. Grant <jg@jguk.org>.
857         * main.c: Update the copyright year in the version output.
858         * prepare_w32.bat: Remove this file from the distribution.
860 2006-01-21  Eli Zaretskii  <eliz@gnu.org>
862         * remake.c (update_goal_chain): Set g->changed instead of
863         incrementing it, as it is only 8-bit wide, and could overflow if
864         many commands got started in update_file.
866         * w32/include/sub_proc.h: Add a prototype for process_used_slots.
868         * w32/subproc/sub_proc.c: Change dimension of proc_array[] to
869         MAXIMUM_WAIT_OBJECTS.
870         (process_wait_for_any_private): Change dimension of handles[]
871         array to MAXIMUM_WAIT_OBJECTS.
872         (process_used_slots): New function.
873         (process_register): Don't register more processes than the
874         available number of slots.
875         (process_easy): Don't start new processes if all slots are used up.
877         * job.c (load_too_high, start_waiting_jobs) [WINDOWS32]: If there
878         are already more children than sub_proc.c can handle, behave as if
879         the load were too high.
880         (start_job_command): Fix a typo in error message when process_easy
881         fails.
883 2006-01-14  Eli Zaretskii  <eliz@gnu.org>
885         * main.c (main) [WINDOWS32]: Don't refuse to run with -jN, even if
886         the shell is not sh.exe.
888         * job.c (create_batch_file): Renamed from create_batch_filename;
889         all callers changed.  Don't close the temporary file; return its
890         file descriptor instead.  New arg FD allows to return the file
891         descriptor.
892         (construct_command_argv_internal): Use _fdopen instead of fopen to
893         open the batch file.
895 2006-01-04  Paul D. Smith  <psmith@gnu.org>
897         * readme.vms: Updates for case-insensitive VMS file systems from
898         Hartmut Becker <Hartmut.Becker@hp.com>.
899         * dir.c (vms_hash): Ditto.
900         * vmsify.c (copyto): Ditto.
901         * vmsfunctions.c (readdir): Ditto.
903         * make.1: Add a section on the exit codes for make.
905         * doc/make.texi: A number of minor updates to the documentation.
907 2006-01-03  Paul D. Smith  <psmith@gnu.org>
909         * remake.c (update_file_1): Mark a prerequisite changed if it
910         doesn't exist.
912         * read.c (eval): Be sure to strip off trailing whitespace from the
913         prerequisites list properly.  Also, initialize all fields in
914         struct dep when creating a new one.
916 2005-12-28  Paul D. Smith  <psmith@gnu.org>
918         * config.h.W32.template [WINDOWS32]: Add in some pragmas to
919         disable warnings for MSC.
920         Patch by Rob Tulloh <rtulloh@yahoo.com>.
922 2005-12-17  Eli Zaretskii  <eliz@gnu.org>
924         * doc/make.texi (Execution): Add a footnote about changes in
925         handling of backslash-newline sequences.  Mention the differences
926         on MS-DOS and MS-Windows.
928         * NEWS: More details about building the MinGW port and a pointer
929         to README.W32.  Fix the section name that describes the new
930         backward-incompatible processing of backslash-newline sequences.
931         The special processing of SHELL set to "cmd" is only relevant to
932         MS-Windows, not MS-DOS.
934 2005-12-17  Eli Zaretskii  <eliz@gnu.org>
936         * main.c (handle_runtime_exceptions): Cast exrec->ExceptionAddress
937         to DWORD, to avoid compiler warnings.
938         * job.c (exec_command): Cast hWaitPID and hPID to DWORD, and
939         use %ld in format, to avoid compiler warnings.
941         * doc/make.texi (Special Targets): Fix a typo.
942         (Appending): Fix cross-reference to Setting.
943         (Special Variables, Secondary Expansion, File Name Functions)
944         (Flavor Function, Pattern Match, Quick Reference): Ensure two
945         periods after a sentence.
946         (Execution): Add @: after "e.g.".
947         (Environment): Fix punctuation.
948         (Target-specific, Call Function, Quick Reference): Add @: after "etc."
949         (Shell Function, Target-specific): Add @: after "vs."
951 2005-12-14  Boris Kolpackov  <boris@kolpackov.net>
953         * read.c (record_target_var): Initialize variable's export field
954         with v_default instead of leaving it "initialized" by whatever
955         garbage happened to be on the heap.
957 2005-12-12  Paul D. Smith  <psmith@gnu.org>
959         * make.1: Fix some display errors and document all existing options.
960         Patch provided by Mike Frysinger <vapier@gentoo.org>.
962 2005-12-11  Paul D. Smith  <psmith@gnu.org>
964         * implicit.c (pattern_search): If 2nd expansion is not set for
965         this implicit rule, replace the pattern with the stem directly,
966         and don't re-expand the variable list.  Along with the other
967         .SECONDEXPANSION changes below, fixes bug #13781.
969 2005-12-09  Boris Kolpackov  <boris@kolpackov.net>
971         * implicit.c (pattern_search): Mark other files that this rule
972         builds as targets so that they are not treated as intermediates
973         by the pattern rule search algorithm. Fixes bug #13022.
975 2005-12-07  Boris Kolpackov  <boris@kolpackov.net>
977         * remake.c (notice_finished_file): Propagate the change of
978         modification time to all the double-colon entries only if
979         it is the last one to be updated. Fixes bug #14334.
981 2005-11-17  Boris Kolpackov  <boris@kolpackov.net>
983         * function.c (func_flavor): Implement the flavor function which
984         returns the flavor of a variable.
985         * doc/make.texi (Functions for Transforming Text): Document it.
986         * NEWS: Add it to the list of new functions.
988 2005-11-14  Boris Kolpackov  <boris@kolpackov.net>
990         * read.c (construct_include_path): Set the .INCLUDE_DIRS special
991         variable.
992         * doc/make.texi (Special Variables): Document .INCLUDE_DIRS.
993         * NEWS: Add .INCLUDE_DIRS to the list of new special variables.
995 2005-10-26  Paul Smith  <psmith@gnu.org>
997         * read.c (record_files): Don't set deps flags if there are no deps.
998         * maintMakefile: We only need to build the templates when we are
999         creating a distribution, so don't do it for "all".
1001 2005-10-24  Paul D. Smith  <psmith@gnu.org>
1003         Make secondary expansion optional: its enabled by declaring the
1004         special target .SECONDEXPANSION.
1006         * NEWS: Update information on second expansion capabilities.
1007         * doc/make.texi (Secondary Expansion): Document the
1008         .SECONDEXPANSION special target and its behavior.
1009         * dep.h (struct dep): Add a flag STATICPATTERN, set to true if the
1010         prerequisite list was found in a static pattern rule.
1011         (free_dep_chain): Declare a prototype.
1012         * file.c (parse_prereqs): New function: break out some complexity
1013         from expand_deps().
1014         (expand_deps): If we aren't doing second expansion, replace % with
1015         the stem for static pattern rules.  Call the new function.
1016         * filedef.h (parse_prereqs): Declare a prototype.
1017         * implicit.c (pattern_search): Initialize the new staticpattern
1018         field.
1019         * main.c (second_expansion): Declare a global variable to remember
1020         if the special target has been seen.  Initialize the new
1021         staticpattern field for prerequisites.
1022         * make.h: Extern for second_expansion.
1023         * misc.c (free_dep_chain): New function: frees a struct dep list.
1024         * read.c (read_all_makefiles): Initialize the staticpattern field.
1025         (eval_makefile): Ditto.
1026         (record_files): Check for the .SECONDEXPANSION target and set
1027         second_expansion global if it's found.
1028         Use the new free_dep_chain() instead of doing it by hand.
1029         Set the staticpattern field for prereqs of static pattern targets.
1031 2005-10-16  Paul D. Smith  <psmith@gnu.org>
1033         * main.c (main): Set CURDIR to be a file variable instead of a
1034         default, so that values of CURDIR inherited from the environment
1035         won't override the make value.
1037 2005-09-26  Paul D. Smith  <psmith@gnu.org>
1039         * job.c (construct_command_argv_internal): If the line is empty
1040         remember to free the temporary argv strings.
1041         Fixes bug # 14527.
1043 2005-09-16  Paul D. Smith  <psmith@gnu.org>
1045         * job.c (start_job_command): The noerror flag is a boolean (single
1046         bit); set it appropriately.
1047         Reported by Mark Eichin <eichin@metacarta.com>
1049 2005-08-29  Paul D. Smith  <psmith@gnu.org>
1051         * function.c (func_error): On Windows, output from $(info ...)
1052         seems to come in the wrong order.  Try to force it with fflush().
1054 2005-08-10  Boris Kolpackov  <boris@kolpackov.net>
1056         * read.c (record_files): Move code that sets stem for static
1057         pattern rules out of the if (!two_colon) condition so it is
1058         also executed for two-colon rules. Fixes Savannah bug #13881.
1060 2005-08-08  Paul D. Smith  <psmith@gnu.org>
1062         * make.h: Don't test that __STDC__ is non-0.  Some compilers
1063         (Windows for example) set it to 0 to denote "ISO C + extensions".
1064         Fixes bug # 13594.
1066 2005-08-07  Paul D. Smith  <psmith@gnu.org>
1068         * w32/pathstuff.c (getcwd_fs): Fix warning about assignment in a
1069         conditional (slightly different version of a fix from Eli).
1071         Fix a bug reported by Michael Matz <matz@suse.de>: patch included.
1072         If make is running in parallel without -k and two jobs die in a
1073         row, but not too close to each other, then make will quit without
1074         waiting for the rest of the jobs to die.
1076         * main.c (die): Don't reset err before calling reap_children() the
1077         second time: we still want it to be in the error condition.
1078         * job.c (reap_children): Use a static variable, rather than err,
1079         to control whether or not the error message should be printed.
1081 2005-08-06  Eli Zaretskii  <eliz@gnu.org>
1083         * w32/subproc/sub_proc.c: Include signal.h.
1084         (process_pipe_io, process_file_io): Pass a pointer to a local
1085         DWORD variable to GetExitCodeProcess.  If the exit code is
1086         CONTROL_C_EXIT, put SIGINT into pproc->signal.
1088         * job.c [WINDOWS32]: Include windows.h.
1089         (main_thread) [WINDOWS32]: New global variable.
1090         (reap_children) [WINDOWS32]: Get the handle for the main thread
1091         and store it in main_thread.
1093         * commands.c [WINDOWS32]: Include windows.h and w32err.h.
1094         (fatal_error_signal) [WINDOWS32]: Suspend the main thread before
1095         doing anything else.  When we are done, close the main thread
1096         handle and exit with status 130.
1098 2005-07-30  Eli Zaretskii  <eliz@gnu.org>
1100         * w32/subproc/sub_proc.c (process_begin): Don't pass a NULL
1101         pointer to fprintf.
1103         * main.c (find_and_set_default_shell): If found a DOSish shell,
1104         set sh_found and the value of default_shell, and report the
1105         findings in debug mode.
1107         * job.c (construct_command_argv_internal): Check unixy_shell, not
1108         no_default_sh_exe, to decide whether to use Unixy or DOSish
1109         builtin commands.
1111         * README.W32: Update with info about the MinGW build.
1113         * build_w32.bat: Support MinGW.
1115         * w32/subproc/build.bat: Likewise.
1117         * w32/subproc/sub_proc.c (process_easy): Fix format strings for
1118         printing DWORD args.
1120         * function.c (windows32_openpipe): Fix format strings for printing
1121         DWORD args.
1123         * job.c (reap_children) [WINDOWS32]: Don't declare 'status' and
1124         'reap_mode'.
1125         (start_job_command): Fix format string for printing the result of
1126         process_easy.
1127         (start_job_command) [WINDOWS32]: Do not define.
1128         (exec_command): Fix format string for printing HANDLE args.
1130         * main.c (handle_runtime_exceptions): Fix sprintf format strings
1131         to avoid compiler warnings.
1132         (open_tmpfile): Declare fd only if HAVE_FDOPEN is defined.
1133         (Note: some of these fixes were submitted independently by J. Grant)
1135 2005-07-30  J. Grant <jg@jguk.org>
1137         * prepare_w32.bat: Copy config.h.w32 to config.h if not exist.
1138         * make_msvc_net2003.vcproj, make_msvc_net2003.sln: MSVC Project files.
1139         * Makefile.am (EXTRA_DIST): Add MSVC Project files.
1141 2005-07-15  Paul Smith  <psmith@gnu.org>
1143         * job.c (construct_command_argv_internal) [DOS,WINDOWS32,OS/2]: If
1144         we don't have a POSIX shell, then revert to the old
1145         backslash-newline behavior (where they are stripped).
1146         Fixes bug #13665.
1148 2005-07-08  Paul D. Smith  <psmith@gnu.org>
1150         * config.h.W32.template: Reorder to match the standard config.h,
1151         for easier comparisons.
1152         From J. Grant <jg@jguk.org>
1154         * maintMakefile: Remove .dep_segment before overwriting it, in
1155         case it's not writable or noclobber is set.
1156         * expand.c (variable_expand_string): Cast result of pointer
1157         arithmetic to avoid a warning.
1158         * main.c (switches): Add full-fledged final initializer.
1160 2005-07-06  Paul D. Smith  <psmith@gnu.org>
1162         * configure.in: IRIX has _sys_siglist.  Tru64 UNIX has __sys_siglist.
1163         * signame.c (strsignal): If we found _sys_siglist[] or
1164         __sys_siglist[] use those instead of sys_siglist[].
1165         From Albert Chin <china@thewrittenword.com>
1167 2005-07-04  Paul D. Smith  <psmith@gnu.org>
1169         * config.h-vms.template [VMS]: Latest VMS has its own glob() and
1170         globfree(); set up to use the GNU versions.
1171         From Martin Zinser <zinser@zinser.no-ip.info>
1173 2005-07-03  Paul D. Smith  <psmith@gnu.org>
1175         From J. Grant <jg@jguk.org>:
1177         * README.W32.template: Update the Windows and tested MSVC versions.
1178         * NMakefile.template (CFLAGS_any): Change warning level from W3 to W4.
1179         * w32/subproc/NMakefile (CFLAGS_any): Ditto.
1180         * build_w32.bat: Ditto.
1181         * w32/subproc/build.bat: Ditto.
1183 2005-06-28  Paul D. Smith  <psmith@gnu.org>
1185         * signame.c: HAVE_DECL_* macros are set to 0, not undef, if the
1186         declaration was checked but not present.
1188 2005-06-27  Paul D. Smith  <psmith@gnu.org>
1190         * dir.c (find_directory): Change type of fs_serno/fs_flags/fs_len
1191         to unsigned long.  Fixes Savannah bug #13550.
1193         * w32/subproc/sub_proc.c: Remove (HANDLE) casts on lvalues.
1194         (process_pipe_io): Initialize tStdin/tStdout/tStderr variables.
1195         Fixes Savannah bug #13551.
1197 2005-06-26  Paul D. Smith  <psmith@gnu.org>
1199         * make.h: Fix bug in ANSI_STRING/strerror() handling; only define
1200         it if ANSI_STRING is not set.
1202 2005-06-25  Paul D. Smith  <psmith@gnu.org>
1204         * read.c (eval): If no filenames are passed to any of the
1205         "include" variants, don't print an error.
1206         * doc/make.texi (Include): Document this.
1207         Fixes Savannah bug #1761.
1209         * job.c (construct_command_argv_internal): Sanitize handling of
1210         backslash/newline pairs according to POSIX: that is, keep the
1211         backslash-newline in the command script, but remove a following
1212         TAB character, if present.  In the fast path, make sure that the
1213         behavior matches what the shell would do both inside and outside
1214         of quotes.  In the slow path, quote the backslash and put a
1215         literal newline in the string.
1216         Fixes Savannah bug #1332.
1217         * doc/make.texi (Execution): Document the new behavior and give
1218         some examples.
1219         * NEWS: Make a note of the new behavior.
1221         * make.h [WINDOWS32]: #include <direct.h>.
1222         Fixes Savannah bug #13478.
1224         * remake.c (name_mtime): If the stat() of a file fails and the -L
1225         option was given and the file is a symlink, take the best mtime of
1226         the symlink we can get as the mtime of the file and don't fail.
1227         Fixes Savannah bug #13280.
1229         * read.c (find_char_unquote): Accept a new argument IGNOREVARS.
1230         If it's set, then don't stop on STOPCHARs or BLANKs if they're
1231         inside a variable reference.  Make this function static as it's
1232         only used here.
1233         (eval): Call find_char_unquote() with IGNOREVARS set when we're
1234         parsing an unexpanded line looking for semicolons.
1235         Fixes Savannah bug #1454.
1236         * misc.c (remove_comments): Move this to read.c and make it static
1237         as it's only used there.  Call find_char_unquote() with new arg.
1238         * make.h: Remove prototypes for find_char_unquote() and
1239         remove_comments() since they're static now.
1241         * main.c (main): If we see MAKE_RESTARTS in the environment, unset
1242         its export flag and obtain its value.  When we need to re-exec,
1243         increment the value and add it into the environment.
1244         * doc/make.texi (Special Variables): Document MAKE_RESTARTS.
1245         * NEWS: Mention MAKE_RESTARTS.
1246         * main.c (always_make_set): New variable.  Change the -B option to
1247         set this one instead.
1248         (main): When checking makefiles, only set always_make_flag if
1249         always_make_set is set AND the restarts flag is 0.  When building
1250         normal targets, set it IFF always_make_set is set.
1251         (main): Avoid infinite recursion with -W, too: only set what-if
1252         files to NEW before we check makefiles if we've never restarted
1253         before.  If we have restarted, set what-if files to NEW _after_ we
1254         check makefiles.
1255         Fixes Savannah bug #7566:
1257 2005-06-17  Paul D. Smith  <psmith@gnu.org>
1259         * default.c: Change VMS implicit rules to use $$$$ instead of $$
1260         in the prerequisites list.
1262 2005-06-12  Paul D. Smith  <psmith@gnu.org>
1264         Fix Savannah bug # 1328.
1266         * configure.in: Check for atexit().
1267         * misc.c (close_stdout): Test stdout to see if writes to it have
1268         failed.  If so, be sure to exit with a non-0 error code.  Based on
1269         code found in gnulib.
1270         * make.h: Prototype.
1271         * main.c (main): Install close_stdout() with atexit().
1273 2005-06-10  Paul D. Smith  <psmith@gnu.org>
1275         VMS build updates from Hartmut Becker <Hartmut.Becker@hp.com>:
1277         * vmsjobs.c [VMS]: Updates to compile on VMS: add some missing
1278         headers; make vmsWaitForChildren() static; extern vmsify().
1279         * job.c [VMS]: Move vmsWaitForChildren() prototype to be global.
1280         Don't create child_execute_job() here (it's in vmsjobs.c).
1281         * makefile.vms (job.obj) [VMS]: Add vmsjobs.c as a prerequisite.
1283 2005-06-09  Paul D. Smith  <psmith@gnu.org>
1285         * variable.c (push_new_variable_scope): File variables point
1286         directly to the global_setlist variable.  So, inserting a new
1287         scope in front of that has no effect on those variables: they
1288         don't go through current_variable_set_list.  If we're pushing a
1289         scope and the current scope is global, push it "the other way" so
1290         that the new setlist is in the global_setlist variable, and
1291         next points to a new setlist with the global variable set.
1292         (pop_variable_scope): Properly undo a push with the new
1293         semantics.
1294         Fixes Savannah bug #11913.
1296 2005-05-31  Boris Kolpackov  <boris@kolpackov.net>
1298         * job.c (reap_children): Don't die of the command failed but
1299         the dontcare flag is set. Fixes Savannah bug #13216.
1301         * implicit.c (pattern_search): When creating a target from
1302         an implicit rule match, lookup pattern target and set precious
1303         flag in a newly created target. Fixes Savannah bug #13218.
1305 2005-05-13  Paul D. Smith  <psmith@gnu.org>
1307         Implement "if... else if... endif" syntax.
1309         * read.c (eval): Push all checks for conditional words ("ifeq",
1310         "else", etc.) down into the conditional_line() function.
1311         (conditional_line): Rework to allow "else if..." clause.  New
1312         return value -2 for lines which are not conditionals.  The
1313         ignoring flag can now also be 2, which means "already parsed a
1314         true branch".  If that value is seen no other branch of this
1315         conditional can be considered true.  In the else parsing if there
1316         is extra text after the else, invoke conditional_line()
1317         recursively to see if it's another conditional.  If not, it's an
1318         error.  If so, raise the conditional value to this level instead
1319         of creating a new conditional nesting level.  Special check for
1320         "else" and "endif", which aren't allowed on the "else" line.
1321         * doc/make.texi (Conditional Syntax): Document the new syntax.
1323 2005-05-09  Paul D. Smith  <psmith@gnu.org>
1325         * Makefile.am (EXTRA_make_SOURCES): Add vmsjobs.c
1326         (MAYBE_W32): Rework how SUBDIRS are handled so that "make dist"
1327         recurses to the w32 directory, even on non-Windows systems.  Use
1328         the method suggested in the automake manual.
1329         * configure.in: Add w32/Makefile to AC_CONFIG_FILES.
1330         * maintMakefile (gnulib-url): They moved the texinfo.tex files.
1332 2005-05-07  Paul D. Smith  <psmith@gnu.org>
1334         * main.c (die): If we're dying with a fatal error (not that a
1335         command has failed), write back any leftover tokens before we go.
1337         * job.c (set_child_handler_action_flags): If there are jobs
1338         waiting for the load to go down, set an alarm to go off in 1
1339         second.  This allows us to wake up from a potentially long-lasting
1340         read() and start a new job if the load has gone down.  Turn it off
1341         after the read.
1342         (job_noop): Dummy signal handler function.
1343         (new_job): Invoke it with the new semantics.
1345         * docs/make.texi: Document secondary expansion.  Various cleanups
1346         and random work.
1348 2005-05-03  Paul D. Smith  <psmith@gnu.org>
1350         Rename .DEFAULT_TARGET to .DEFAULT_GOAL: in GNU make terminology
1351         the targets which are to ultimately be made are called "goals";
1352         see the GNU make manual.  Also, MAKECMDGOALS, etc.
1354         * filedef.h, read.c, main.c: Change .DEFAULT_TARGET to
1355         .DEFAULT_GOAL, and default_target_name to default_goal_name.
1356         * doc/make.texi (Special Variables): Document .DEFAULT_GOAL.
1358 2005-05-02  Paul D. Smith  <psmith@gnu.org>
1360         * job.c, vmsjobs.c (vmsWaitForChildren, vms_redirect,
1361         vms_handle_apos, vmsHandleChildTerm, reEnableAst, astHandler,
1362         tryToSetupYAst, child_execute_job) [VMS]: Move VMS-specific
1363         functions to vmsjobs.c.  #include it into jobs.c.
1365         Grant Taylor <gtaylor@picante.com> reports that -j# can lose
1366         jobserver tokens.  I found that this happens when an exported
1367         recursive variable contains a $(shell ...) function reference: in
1368         this situation we could "forget" to write back a token.
1370         * job.c, job.h: Add variable jobserver_tokens: counts the tokens
1371         we have.  It's not reliable to depend on the number of children in
1372         our linked list so keep a separate count.
1373         (new_job): Check jobserver_tokens rather than children &&
1374         waiting_jobs.  Increment jobserver_tokens when we get one.
1375         (free_child): If jobserver_tokens is 0, internal error.  If it's
1376         >1, write a token back to the jobserver pipe (we don't write a
1377         token for the "free" job).  Decrement jobserver_tokens.
1379         * main.c: Add variable master_job_slots.
1380         (main): Set it to hold the number of jobs requested if we're the
1381         master process, when using the jobserver.
1382         (die): Sanity checks: first test jobserver_tokens to make sure
1383         this process isn't holding any tokens we didn't write back.
1384         Second, if master_job_slots is set count the tokens left in the
1385         jobserver pipe and ensure it's the same as master_job_slots (- 1).
1387 2005-04-24  Paul D. Smith  <psmith@gnu.org>
1389         Grant Taylor <gtaylor@picante.com> reports that -j# in conjunction
1390         with -l# can lose jobserver tokens, because waiting jobs are not
1391         consulted properly when checking for the "free" token.
1393         * job.c (free_child): Count waiting_jobs as having tokens.
1394         * job.c (new_job): Ditto.  Plus, call start_waiting_jobs() here to
1395         handle jobs waiting for the load to drop.
1397 2005-04-23  Paul D. Smith  <psmith@gnu.org>
1399         * main.c (main): Be careful to not core if a variable setting in
1400         the environment doesn't contain an '='.  This is illegal but can
1401         happen in broken setups.
1402         Reported by Joerg Schilling <schilling@fokus.fraunhofer.de>.
1404 2005-04-12  Paul D. Smith  <psmith@gnu.org>
1406         The second expansion feature causes significant slowdown.  Timing
1407         a complex makefile (GCC 4.1) shows a slowdown from .25s to just
1408         read the makefile before the feature, to 11+s to do the same
1409         operations after the feature.  Additionally, memory usage
1410         increased drastically.  To fix this I added some intelligence that
1411         avoids the overhead of the second expansion unless it's required.
1413         * dep.h: Add a new boolean field, need_2nd_expansion.
1415         * read.c (eval): When creating the struct dep for the target,
1416         check if the name contains a "$"; if so set need_2nd_expansion to 1.
1417         (record_files): If there's a "%" in a static pattern rule, it gets
1418         converted to "$*" so set need_2nd_expansion to 1.
1420         * file.c (expand_deps): Rework to be more efficient.  Only perform
1421         initialize_file_variables(), set_file_variables(), and
1422         variable_expand_for_file() if the need_2nd_expansion is set.
1424         * implicit.c (pattern_search): Default need_2nd_expansion to 0.
1425         (pattern_search): Ditto.
1426         * main.c (handle_non_switch_argument): Ditto.
1427         (main): Ditto.
1428         * read.c (read_all_makefiles): Ditto.
1429         (eval_makefile): Ditto.
1431 2005-04-07  Paul D. Smith  <psmith@gnu.org>
1433         * main.c (main) [WINDOWS32]: Export PATH to sub-shells, not Path.
1434         * variable.c (sync_Path_environment): Ditto.
1435         Patch by Alessandro Vesely.  Fixes Savannah bug #12209.
1437         * main.c (main): Define the .FEATURES variable.
1438         * NEWS: Announce .FEATURES.
1439         * doc/make.texi (Special Variables): Document .FEATURES.
1441         * remake.c (check_dep): If a file is .PHONY, update it even if
1442         it's marked intermediate.  Fixes Savannah bug #12331.
1444 2005-03-15  Boris Kolpackov  <boris@kolpackov.net>
1446         * file.c (expand_deps): Factor out the second expansion and
1447         prerequisite line parsing logic from snap_deps().
1449         * file.c (snap_deps): Use expand_deps(). Expand and parse
1450         prerequisites of the .SUFFIXES special target first. Fixes
1451         Savannah bug #12320.
1453 2005-03-13  Paul D. Smith  <psmith@gnu.org>
1455         * main.c (main) [MSDOS]: Export SHELL in MSDOS.  Requested by Eli
1456         Zaretskii.
1458 2005-03-11  Paul D. Smith  <psmith@gnu.org>
1460         * signame.c (strsignal): HAVE_DECL_SYS_SIGLIST is 0 when not
1461         available, not undefined (from Earnie Boyd).
1463 2005-03-10  Boris Kolpackov  <boris@kolpackov.net>
1465         * implicit.c (pattern_search): Mark an intermediate target as
1466         precious if it happened to be a prerequisite of some (other)
1467         target. Fixes Savannah bug #12267.
1469 2005-03-09  Paul D. Smith  <psmith@gnu.org>
1471         * read.c (eval_makefile): Add alloca(0).
1472         (eval_buffer): Ditto.
1474 2005-03-09  Boris Kolpackov  <boris@kolpackov.net>
1476         * main.c (main): Use o_file instead of o_default when defining
1477         the .DEFAULT_TARGET special variable.
1478         * read.c (eval): Use define_variable_global() instead of
1479         define_variable() when setting new value for the .DEFAULT_TARGET
1480         special variable.  Fixes Savannah bug #12266.
1482 2005-03-04  Boris Kolpackov  <boris@kolpackov.net>
1484         * imlicit.c (pattern_search): Mark files for which an implicit
1485         rule has been found as targets. Fixes Savannah bug #12202.
1487 2005-03-04  Paul D. Smith  <psmith@gnu.org>
1489         * AUTHORS: Update.
1490         * doc/make.texi (Automatic Variables): Document $|.
1492 2005-03-03  Boris Kolpackov  <boris@kolpackov.net>
1494         * read.c (record_files): Instead of substituting % with
1495         actual stem value in dependency list replace it with $*.
1496         This fixes stem triple expansion bug.
1498         * implicit.c (pattern_search): Copy stem to a separate
1499         buffer and make it a properly terminated string. Assign
1500         this buffer instead of STEM (which is not terminated) to
1501         f->stem. Instead of substituting % with actual stem value
1502         in dependency list replace it with $*. This fixes stem
1503         triple expansion bug.
1505 2005-03-01  Paul D. Smith  <psmith@gnu.org>
1507         * commands.c (fatal_error_signal) [WINDOWS32]: Don't call kill()
1508         on Windows, as it takes a handle not a pid.  Just exit.
1509         Fix from patch #3679, provided by Alessandro Vesely.
1511         * configure.in: Update check for sys_siglist[] from autoconf manual.
1512         * signame.c (strsignal): Update to use the new autoconf macro.
1514 2005-03-01  Boris Kolpackov  <boris@kolpackov.net>
1516         * read.c (record_files): Add a check for the list of prerequisites
1517         of a static pattern rule being empty. Fixes Savannah bug #12180.
1519 2005-02-28  Paul D. Smith  <psmith@gnu.org>
1521         * doc/make.texi (Text Functions): Update docs to allow the end
1522         ordinal for $(wordlist ...) to be 0.
1523         * function.c (func_wordlist): Fail if the start ordinal for
1524         $(wordlist ...) is <1.  Matches documentation.
1525         Resolves Savannah support request #103195.
1527         * remake.c (update_goal_chain): Fix logic for stopping in -q:
1528         previously we were stopping when !-q, exactly the opposite.  This
1529         has been wrong since version 1.34, in 1994!
1530         (update_file): If we got an error don't break out to run more
1531         double-colon rules: just return immediately.
1532         Fixes Savannah bug #7144.
1534 2005-02-27  Paul D. Smith  <psmith@gnu.org>
1536         * misc.c (end_of_token): Make argument const.
1537         * make.h: Update prototype.
1539         * function.c (abspath, func_realpath, func_abspath): Use
1540         PATH_VAR() and GET_PATH_MAX instead of PATH_MAX.
1541         * dir.c (downcase): Use PATH_VAR() instead of PATH_MAX.
1542         * read.c (record_files): Ditto.
1543         * variable.c (do_variable_definition): Ditto.
1545         * function.c (func_error): Create a new function $(info ...) that
1546         simply prints the message to stdout with no extras.
1547         (function_table_init): Add new function to the table.
1548         * NEWS: Add $(info ...) reference.
1549         * doc/make.texi (Make Control Functions): Document it.
1551         New feature: if the system supports symbolic links, and the user
1552         provides the -L/--check-symlink-time flag, then use the latest
1553         mtime between the symlink(s) and the target file.
1555         * configure.in (MAKE_SYMLINKS): Check for lstat() and
1556         readlink().  If both are available, define MAKE_SYMLINKS.
1557         * main.c: New variable: check_symlink_flag.
1558         (usage): Add a line for -L/--check-symlink-times to the help string.
1559         (switches): Add -L/--check-symlink-times command line argument.
1560         (main): If MAKE_SYMLINKS is not defined but the user specified -L,
1561         print a warning and disable it again.
1562         * make.h: Declare check_symlink_flag.
1563         * remake.c (name_mtime): If MAKE_SYMLINKS and check_symlink_flag,
1564         if the file is a symlink then check each link in the chain and
1565         choose the NEWEST mtime we find as the mtime for the file.  The
1566         newest mtime might be the file itself!
1567         * NEWS: Add information about this new feature.
1568         * doc/make.texi (Options Summary): Add -L/--check-symlink-times docs.
1570         Avoid core dumps described in Savannah bug # 12124:
1572         * file.c: New variable snapped_deps remember whether we've run
1573         snap_deps().
1574         (snap_deps): Set it.
1575         * filedef.h: Extern it.
1576         * read.c (record_files): Check snapped_deps; if it's set then
1577         we're trying to eval a new target/prerequisite relationship from
1578         within a command script, which we don't support.  Fatal.
1580 2005-02-28  Boris Kolpackov  <boris@kolpackov.net>
1582         Implementation of the .DEFAULT_TARGET special variable.
1584         * read.c (eval): If necessary, update default_target_name when
1585         reading rules.
1586         * read.c (record_files): Update default_target_file if
1587         default_target_name has changed.
1588         * main.c (default_target_name): Define.
1589         * main.c (main): Enter .DEFAULT_TARGET as make variable. If
1590         default_target_name is set use default_target_file as a root
1591         target to make.
1592         * filedef.h (default_target_name): Declare.
1593         * dep.h (free_dep_chain):
1594         * misc.c (free_dep_chain): Change to operate on struct nameseq
1595         and change name to free_ns_chain.
1596         * file.c (snap_deps): Update to use free_ns_chain.
1598 2005-02-27  Boris Kolpackov  <boris@kolpackov.net>
1600         Implementation of the second expansion in explicit rules,
1601         static pattern rules and implicit rules.
1603         * read.c (eval): Refrain from chopping up rule's dependencies.
1604         Store them in a struct dep as a single dependency line. Remove
1605         the code that implements SySV-style automatic variables.
1607         * read.c (record_files): Adjust the code that handles static
1608         pattern rules to expand all percents instead of only the first
1609         one. Reverse the order in which dependencies are stored so that
1610         when the second expansion reverses them again they appear in
1611         the makefile order (with some exceptions, see comments in
1612         the code). Remove the code that implements SySV-style automatic
1613         variables.
1615         * file.c (snap_deps): Implement the second expansion and chopping
1616         of dependency lines for explicit rules.
1618         * implicit.c (struct idep): Define an auxiliary data type to hold
1619         implicit rule's dependencies after stem substitution and
1620         expansion.
1622         * implicit.c (free_idep_chain): Implement.
1624         * implicit.c (get_next_word): Implement helper function for
1625         parsing implicit rule's dependency lines into words taking
1626         into account variable expansion requests. Used in the stem
1627         splitting code.
1629         * implicit.c (pattern_search): Implement the second expansion
1630         for implicit rules. Also fixes bug #12091.
1632         * commands.h (set_file_variables): Declare.
1633         * commands.c (set_file_variables): Remove static specifier.
1635         * dep.h (free_dep_chain): Declare.
1636         * misc.c (free_dep_chain): Implement.
1638         * variable.h (variable_expand_for_file): Declare.
1639         * expand.c (variable_expand_for_file): Remove static specifier.
1641         * make.h (strip_whitespace): Declare.
1642         * function.c (strip_whitespace): Remove static specifier.
1644 2005-02-26  Paul D. Smith  <psmith@gnu.org>
1646         * main.c (main): Check for ferror() when reading makefiles from stdin.
1647         Apparently some shells in Windows don't close pipes properly and
1648         require this check.
1650 2005-02-24  Jonathan Grant  <jg@jguk.org>
1652         * configure.in: Add MinGW configuration options, and extra w32 code
1653         directory.
1654         * Makefile.am: Add MinGW configuration options, and extra w32 code
1655         directory.
1656         * main.c: Determine correct program string (after last \ without .exe).
1657         * subproc/sub_proc.c: `GetExitCodeProcess' from incompatible pointer
1658         type fix x2
1659         * w32/Makefile.am: Import to build win32 lib of sub_proc etc.
1660         * subproc/w32err.c: MSVC thread directive not applied to MinGW builds.
1661         * tests/run_make_tests.pl, tests/test_driver.pl: MSYS testing
1662         environment support.
1664 2004-04-16  Dmitry V. Levin  <ldv@altlinux.org>
1666         * function.c (func_shell): When initializing error_prefix, check
1667         that reading file name is not null.  This fixes long-standing
1668         segfault in cases like "make 'a1=$(shell :)' 'a2:=$(a1)'".
1670 2005-02-09  Paul D. Smith  <psmith@gnu.org>
1672         * maintMakefile: Update the CVS download URL to simplify them.
1673         Also, the ftp://ftp.gnu.org/GNUinfo site was removed so I'm
1674         downloading the .texi files from Savannah now.
1676         Fixed these issues reported by Markus Mauhart <qwe123@chello.at>:
1678         * main.c (handle_non_switch_argument): Only add variables to
1679         command_variables if they're not already there: duplicate settings
1680         waste space and can be confusing to read.
1682         * w32/include/sub_proc.h: Remove WINDOWS32.  It's not needed since
1683         this header is never included by non-WINDOWS32 code, and it
1684         requires <config.h> to define which isn't always included first.
1686         * dir.c (read_dirstream) [MINGW]: Use proper macro names when
1687         testing MINGW32 versions.
1689         * main.c (log_working_directory): flush stdout to be sure the WD
1690         change is printed before any stderr messages show up.
1692 2005-02-01  Paul D. Smith  <psmith@gnu.org>
1694         * maintMakefile (po_repo): Update the GNU translation site URL.
1696 2004-12-01  Paul D. Smith  <psmith@gnu.org>
1698         * main.c (main): Change char* env_shell to struct variable shell_var.
1699         * variable.c (target_environment): Use new shell_var.
1701 2004-11-30  Paul D. Smith  <psmith@gnu.org>
1703         * configure.in: The old way we avoided creating build.sh from
1704         build.sh.in before build.sh.in exists doesn't work anymore; we
1705         have to use raw M4 (thanks to Andreas Schwab <schwab@suse.de> for
1706         the help!).  This also keeps automake from complaining.
1707         * Makefile.am (README): Add a dummy target so automake won't
1708         complain that this file doesn't exist when we checkout from CVS.
1709         * maintMakefile (.dep_segment): Rewrite this rule since newer
1710         versions of automake don't provide DEP_FILES.
1712 2004-11-30  Boris Kolpackov  <boris@kolpackov.net>
1714         Implementation of `realpath' and `abspath' built-in functions.
1716         * configure.in: Check for realpath.
1717         * function.c (abspath): Return an absolute file name that does
1718         not contain any `.' or `..' components, nor repeated `/'.
1719         * function.c (func_abspath): For each name call abspath.
1720         * function.c (func_realpath): For each name call realpath
1721         from libc or delegate to abspath if realpath is not available.
1722         * doc/make.texi (Functions for File Names): Document new functions.
1723         * doc/make.texi (Quick Reference): Ditto.
1725 2004-11-28  Paul D. Smith  <psmith@gnu.org>
1727         * main.c (main) [WINDOWS32]: Remove any trailing slashes from -C
1728         arguments.  Fixes bug #10252.
1730         Fix for bug #1276: Handle SHELL according to POSIX requirements.
1732         * main.c (main): Set SHELL to v_noexport by default.  Remember the
1733         original environment setting of SHELL in the env_shell variable.
1734         * main.h: Export new env_shell variable.
1735         * variable.c (target_environment): If we find a v_noexport
1736         variable for SHELL, add a SHELL variable with the env_shell value.
1737         * doc/make.texi (Quick Reference): Document the POSIX behavior.
1738         * doc/make.texi (Variables/Recursion): Ditto.
1740 2004-11-28  Paul D. Smith  <psmith@gnu.org>
1742         * main.c (find_and_set_default_shell) [WINDOWS32]: check for
1743         equality of "cmd"/"cmd.exe", not inequality.  Fixes bug #11155.
1744         Patch by Alessandro Vesely.
1746 2004-11-12  Paul D. Smith  <psmith@gnu.org>
1748         * job.c (child_execute_job) [VMS]: Don't treat "#" as a comment on
1749         the command line if it's inside a string.
1750         Patch by: Hartmut Becker <Hartmut.Becker@hp.com>
1752 2004-10-21  Boris Kolpackov  <boris@kolpackov.net>
1754         * function.c (func_lastword): New function: return last word
1755         from the list of words.
1756         * doc/make.texi: Document $(lastword ). Fix broken links in
1757         Quick Reference section.
1759 2004-10-06  Paul D. Smith  <psmith@gnu.org>
1761         Apply patch from Alessandro Vesely, provided with bug # 9748.
1762         Fix use of tmpnam() to work with Borland C.
1764         * job.c (construct_command_argv_internal) [WINDOWS32]: Remove
1765         construction of a temporary filename, and call new function
1766         create_batch_filename().
1767         (create_batch_filename) [WINDOWS32]: New function to create a
1768         temporary filename.
1770 2004-10-05  Boris Kolpackov  <boris@kolpackov.net>
1772         * read.c (record_target_var): Expand simple pattern-specific
1773         variable.
1774         * variable.c (initialize_file_variables): Do not expand simple
1775         pattern-specific variable.
1777 2004-09-28  Boris Kolpackov  <boris@kolpackov.net>
1779         * remake.c (update_file_1): When rebuilding makefiles inherit
1780         dontcare flag from a target that triggered update.
1782 2004-09-27  Boris Kolpackov  <boris@kolpackov.net>
1784         * variable.c (initialize_file_variables): Mark pattern-specific
1785         variable as a per-target and copy export status.
1787 2004-09-21  Boris Kolpackov  <boris@kolpackov.net>
1789         * file.c (snap_deps): Mark .PHONY prerequisites as targets.
1791         * implicit.c (pattern_search): When considering an implicit rule's
1792         prerequisite check that it is actually a target rather then
1793         just an entry in the file hashtable.
1795 2004-09-21  Paul D. Smith  <psmith@gnu.org>
1797         * read.c (readstring): Fix some logic errors in backslash handling.
1798         (eval): Remove some unnecessary processing in buffer handling.
1799         (record_target_var): Assert that parse_variable_definition() succeeded.
1800         Reported by: Markus Mauhart <qwe123@chello.at>.
1802         * misc.c: Removed the sindex() function.  All instances of this
1803         function were trivially replaceable by the standard strstr()
1804         function, and that function will always have better (or certainly
1805         no worse) performance than the very simple-minded algorithm
1806         sindex() used.  This can matter with complex makefiles.
1807         * make.h: Remove the prototype for sindex().
1808         * function.c (subst_expand): Convert sindex() call to strstr().
1809         This means we no longer need to track the TLEN value so remove that.
1810         (func_findstring): Convert sindex() to strstr().
1811         * commands.c (chop_commands): Convert sindex() calls to strstr().
1812         Suggested by: Markus Mauhart <qwe123@chello.at>.
1814         * main.c (find_and_set_default_shell) [WINDOWS32]: Implement the
1815         idea behind Savannah Patch #3144 from david.baird@homemail.com.
1816         If SHELL is set to CMD.EXE then assume it's batch-mode and
1817         non-unixy.  I wrote the code differently from the patch, though,
1818         to make it safer.  This also resolves bug #9174.
1820 2004-09-20  Paul D. Smith  <psmith@gnu.org>
1822         * expand.c (variable_expand_string): Modify to invoke
1823         patsubst_expand() instead of subst_expand(); the latter didn't
1824         handle suffix patterns correctly.
1825         * function.c (subst_expand): Remove the SUFFIX_ONLY parameter; it
1826         was used only from variable_expand_string() and is no longer used
1827         there.
1828         (func_subst): Ditto, on call to subst_expand().
1829         (patsubst_expand): Require the percent pointers to point to the
1830         character after the %, not to the % itself.
1831         * read.c (record_files): New call criteria for patsubst_expand().
1832         * variable.h: Remove SUFFIX_ONLY from subst_expand() prototype.
1833         This is to fix a bug reported by Markus Mauhart <qwe123@chello.at>.
1835 2004-09-19  Paul D. Smith  <psmith@gnu.org>
1837         * function.c (subst_expand): Fix a check in by_word: look for a
1838         previous blank if we're beyond the beginning of the string, not
1839         the beginning of the word.
1840         Bugs reported by Markus Mauhart <qwe123@chello.at>.
1842 2004-05-16  Paul D. Smith  <psmith@gnu.org>
1844         * remake.c (update_goal_chain): Change the argument specifying
1845         whether we're rebuilding makefiles to be a global variable,
1846         REBUILDING_MAKEFILES.
1847         (complain): Extract the code that complains about no rules to make
1848         a target into a separate function.
1849         (update_file_1): If we tried to rebuild a file during the makefile
1850         rebuild phase and it was dontcare, then no message was printed.
1851         If we then try to build the same file during the normal build,
1852         print a message this time.
1853         (remake_file): Don't complain about un-remake-able files when
1854         we're rebuilding makefiles.
1856 2004-05-11  Paul D. Smith  <psmith@gnu.org>
1858         * job.c (construct_command_argv_internal): OS/2 patches from
1859         Andreas Buening <andreas.buening@nexgo.de>.
1861 2004-05-10  Paul D. Smith  <psmith@gnu.org>
1863         * remake.c (update_file): Don't walk the double-colon chain unless
1864         this is a double-colon rule.  Fix suggested by Boris Kolpackov
1865         <boris@kolpackov.net>.
1867         * makefile.vms (CFLAGS): Remove glob/globfree (see readme.vms docs)
1868         * readme.vms: New section describing OpenVMS support and issues.
1869         * default.c (default_variables): Add support for IA64.
1870         * job.c (tryToSetupYAst) [VMS]: On VMS running make in batch mode
1871         without some privilege aborts make with the error
1872         %SYSTEM-F-NOPRIV. It happens when setting up a handler for
1873         pressing Ctrl+Y and the input device is no terminal. The change
1874         catches this error and just continues.
1876         Patches by Hartmut Becker <Hartmut.Becker@hp.com>
1878 2004-04-25  Paul D. Smith  <psmith@gnu.org>
1880         * commands.c (set_file_variables): Set $< properly in the face of
1881         order-only prerequisites.
1882         Patch from Boris Kolpackov <boris@kolpackov.net>
1884 2004-04-21  Bob Byrnes  <byrnes@curl.com>
1886         * main.c (main): Notice failures to remake makefiles.
1888 2004-03-28  Paul D. Smith  <psmith@gnu.org>
1890         Patches for Acorn RISC OS by Peter Naulls <peter@chocky.org>
1892         * job.c: No default shell for RISC OS.
1893         (load_too_high): Hard-code the return to 1.
1894         (construct_command_argv_internal): No sh_chars or sh_cmds.
1895         * getloadavg.c: Don't set LOAD_AVE_TYPE on RISC OS.
1897 2004-03-20  Paul D. Smith  <psmith@gnu.org>
1899         * variable.c (do_variable_definition): Don't append from the
1900         global set if a previous non-appending target-specific variable
1901         definition exists.  Reported by Oliver Schmidt <oschmidt@gmx.net>
1902         (with fix).
1904         * expand.c (reference_variable): Don't give up on variables with
1905         no value that have the target-specific append flag set: they might
1906         have a value after all.  Reported by Oliver Schmidt
1907         <oschmidt@gmx.net> (with fix) and also by Maksim A. Nikulin
1908         <nikulin@dx1cmd.inp.nsk.su>.
1910         * rule.c (count_implicit_rule_limits): Don't delete patterns which
1911         refer to absolute pathnames in directories that don't exist: some
1912         portion of the makefile could create those directories before we
1913         match the pattern.  Fixes bugs #775 and #108.
1915         Fixes from Jonathan R. Grant  <jg-make@jguk.org>:
1917         * main.c (main): Free makefile_mtimes if we have any.
1918         * README.W32.template: Update documentation for the current status
1919         of the MS-Windows port.
1920         * NMakefile.template (MAKE): Add "MAKE = nmake".  A conflicting
1921         environment variable is sometimes already defined which causes the
1922         build to fail.
1923         * main.c (debug_signal_handler): Only define this function if
1924         SIGUSR1 is available.
1926         Fixes for OS/2 from Andreas Beuning <andreas.buening@nexgo.de>:
1928         * configure.in [OS/2]: Relocate setting of HAVE_SA_RESTART for OS/2.
1929         * README.OS2.template: Documentation updates.
1930         * build.template: Add LIBINTL into LOADLIBES.  Add $CFLAGS to the
1931         link line for safety.
1932         * maintMakefile (build.sh.in): Remove an extraneous ")".
1933         * job.c (child_execute_job): Close saved FDs.
1934         * job.c (exec_command) [OS/2]: exec_command(): If the command
1935         can't be exec'ed and if the shell is not Unix-sh, then try again
1936         with argv = { "cmd", "/c", ... }. Normally, this code is never
1937         reached for the cmd shell unless the command really doesn't exist.
1938         (construct_command_argv_internal) [OS/2]: The code for cmd
1939         handling now uses new_argv = { "cmd", "/c", "original line", NULL}.
1940         The CMD builtin commands are case insensitive so use strcasecmp().
1942 2004-03-19  Paul D. Smith  <psmith@gnu.org>
1944         * read.c (do_define): Re-order line counter increment so the count
1945         is accurate (we were losing one line per define).  Reported by
1946         Dave Yost <Dave@Yost.com>.
1948 2004-03-06  Paul D. Smith  <psmith@gnu.org>
1950         * configure.in (HAVE_ANSI_COMPILER): Define if we have an ANSI/ISO
1951         compiler.
1952         * make.h: Convert uses of __STDC__ to HAVE_ANSI_COMPILER.
1953         * misc.c (message,error,fatal): Ditto.
1954         * configh.dos.template: Define HAVE_ANSI_COMPILER.
1955         * config.h.W32.template: Ditto.
1956         * config.h-vms.template: Ditto.
1957         * config.ami.template: Ditto.
1959 2004-03-04  Paul D. Smith  <psmith@gnu.org>
1961         * README.template: Add a note about broken /bin/sh on SunOS
1962         4.1.3_U1 & 4.1.4.  Fix up Savannah links.
1964         * misc.c (message, error, fatal): Don't use "..." if we're using
1965         varargs.  ansi2knr should handle this but it doesn't work: it
1966         translates "..." to va_dcl etc. but _AFTER_ the preprocessor is
1967         done.  On many systems (SunOS for example) va_dcl is a #define.
1968         So, force the use of the non-"..." version on pre-ANSI compilers.
1970         * maintMakefile (sign-dist): Create some rules to help automate
1971         the new GNU ftp upload method.
1973 2004-02-24  Paul D. Smith  <psmith@gnu.org>
1975         * config.h.W32.template: Add HAVE_STDARG_H
1976         * config.h-vms.template: Ditto.
1977         * config.ami.template: Ditto.
1979 2004-02-23  Jonathan Grant  <jg-make@jguk.org>
1981         * README.W32.template: Add a notation about -j with BATCH_MODE_ONLY.
1982         * build_w32.bat: Remove extra "+".
1984 2004-02-23  Paul D. Smith  <psmith@gnu.org>
1986         * make.h: Create an UNUSED macro to mark unused parameters.
1987         * (many): Clean up warnings by applying UNUSED, fixing
1988         signed/unsigned incompatibilities, etc.
1990         * acinclude.m4 (AC_STRUCT_ST_MTIM_NSEC): Add quoting to silence
1991         autoconf warnings.
1992         * filedef.h: Name the command_state enumeration.
1993         * file.c (set_command_state): Use the enumeration in the function
1994         argument.
1996         * configure.in: Explicitly set SET_MAKE to empty, to disable
1997         MAKE=make even when no make already exists.  Fix bug #3823.
1999 2004-02-22  Paul D. Smith  <psmith@gnu.org>
2001         * maintMakefile: Perl script to clean up all non-CVS files.  Use
2002         it on all the subdirectories for the cvs-clean target.
2004         * main.c (decode_switches): Require non-empty strings for all our
2005         string command-line options.  Fixes Debian bug # 164165.
2007         * configure.in: Check for stdarg.h and varargs.h.
2008         * make.h (USE_VARIADIC): Set this if we can use variadic functions
2009         for printing messages.
2010         * misc.c: Check USE_VARIADIC instead of (obsolete) HAVE_STDVARARGS.
2011         (message): Ditto.
2012         (error): Ditto.
2013         (fatal): Ditto.
2015         A number of patches for OS/2 support from Andreas Buening
2016         <andreas.buening@nexgo.de>:
2018         * job.c (child_handler) [OS/2]: Allow this on OS/2 but we have to
2019         disable the SIGCHLD handler.
2020         (reap_children) [OS/2]: Remove special handling of job_rfd.
2021         (set_child_handler_action_flags) [OS/2]: Use this function in OS/2.
2022         (new_job) [OS/2]: Disable the SIGCHLD handler on OS/2.
2023         * main.c (main) [OS/2]: Special handling for paths in OS/2.
2024         * configure.in [OS/2]: Force SA_RESTART for OS/2.
2025         * Makefile.am (check-regression): Use $(EXEEXT) for Windows-type
2026         systems.
2028 2004-02-21  Paul D. Smith  <psmith@gnu.org>
2030         * w32/subproc/sub_proc.c (process_easy) [W32]: Christoph Schulz
2031         <mail@kristov.de> reports that if process_begin() fails we don't
2032         handle the error condition correctly in all cases.
2033         * w32/subproc/w32err.c (map_windows32_error_to_string): Make sure
2034         to have a newline on the message.
2036         * job.c (construct_command_argv_internal): Add "test" to UNIX
2037         sh_cmds[].  Fixes Savannah bug # 7606.
2039 2004-02-04  Paul D. Smith  <psmith@gnu.org>
2041         * job.c (vms_handle_apos) [VMS]: Fix various string handling
2042         situations in VMS DCL.  Fixes Savannah bug #5533.  Fix provided by
2043         Hartmut Becker <Hartmut.Becker@hp.com>.
2045 2004-01-21  Paul D. Smith  <psmith@gnu.org>
2047         * job.c (load_too_high): Implement an algorithm to control the
2048         "thundering herd" problem when using -l to control job creation
2049         via the load average.  The system only recomputes the load once a
2050         second but we can start many jobs in a second.  To solve this we
2051         keep track of the number of jobs started in the last second and
2052         apply a weight to try to guess what a correct load would be.
2053         The algorithm was provided by Thomas Riedl <thomas.riedl@siemens.com>.
2054         Also fixes bug #4693.
2055         (reap_children): Decrease the job count for this second.
2056         (start_job_command): Increase the job count for this second.
2058         * read.c (conditional_line): Expand the text after ifn?def before
2059         checking to see if it's a single word.  Fixes bug #7257.
2061 2004-01-09  Paul D. Smith  <psmith@gnu.org>
2063         * file.c (print_file): Recurse to print all targets in
2064         double-colon rules.  Fixes bug #4518, reported (with patch) by
2065         Andrew Chatham <chatham@google.com>.
2067 2004-01-07  Paul D. Smith  <psmith@gnu.org>
2069         * acinclude.m4: Remove make_FUNC_SETVBUF_REVERSED.
2070         * configure.in: Change make_FUNC_SETVBUF_REVERSED to
2071         AC_FUNC_SETVBUF_REVERSED.
2073         * doc/make.texi (Target-specific): Fix Savannah bug #1772.
2074         (MAKE Variable): Fix Savannah bug #4898.
2076         * job.c (construct_command_argv_internal): Add "!" to the list of
2077         shell escape chars.  POSIX sh allows it to appear before a
2078         command, to negate the exit code.  Fixes bug #6404.
2080         * implicit.c (pattern_search): When matching an implicit rule,
2081         remember which dependencies have the ignore_mtime flag set.
2082         Original fix provided in Savannah patch #2349, by Benoit
2083         Poulot-Cazajous <Benoit.Poulot-Cazajous@jaluna.com>.
2085 2003-11-22  Paul D. Smith  <psmith@gnu.org>
2087         * README.W32.template (Outputs): Clarification on -j with
2088         BATCH_MODE_ONLY_SEHLL suggested by Jonathan R. Grant
2089         <jg-make@jguk.org>.
2091 2003-11-02  Paul D. Smith  <psmith@gnu.org>
2093         * function.c (func_if): Strip all the trailing whitespace from the
2094         condition, then don't expand it.  Fixed bug # 5798.
2096         * expand.c (recursively_expand_for_file): If we're expanding a
2097         variable with no file context, then use the variable's context.
2098         Fixes bug # 6195.
2100 2003-10-21  Paul D. Smith  <psmith@gnu.org>
2102         * main.c (log_working_directory): Add newlines to printf()s.
2104         * README.cvs: Add a note to ignore warnings during autoreconf.
2106         * maintMakefile (po_repo): Set a new URL for PO file updates.
2107         (get-config/config.guess get-config/config.sub): Get these files
2108         from the Savannah config project instead of ftp.gnu.org.
2110 2003-10-05  Paul Eggert  <eggert@twinsun.com>
2112         * main.c (main): Avoid potential subscript error if environ has
2113         short strings.
2115 2003-08-22  Paul D. Smith  <psmith@gnu.org>
2117         * misc.c (xmalloc, xrealloc): Add one to 0 sizes, to cater to
2118         systems which don't yet implement the C89 standard :-/.
2120 2003-07-18  Paul D. Smith  <psmith@gnu.org>
2122         * dir.c (directory_contents_hash_1, directory_contents_hash_1)
2123         [WINDOWS32]: Initialize hash.
2125 2003-06-19  Earnie Boyd  <earnie@uses.sf.net>
2127         * dir.c (read_dirstream): Provide a workaround for broken versions of
2128         the MinGW dirent structure.
2130 2003-05-30  Earnie Boyd  <earnie@users.sf.net>
2132         * w32/include/dirent.h: Add __MINGW32__ filter.
2134 2003-05-30  Earnie Boyd  <earnie@users.sf.net>
2136         * make.h: Add global declaration of *make_host.
2137         * main.c (print_usage): Remove local declaration of *make_host.
2138         (print_version): Display "This program built for ..." after Copyright
2139         notice.
2141 2003-05-30  Earnie Boyd  <earnie@users.sf.net>
2143         * doc/make.texi: Change "ifinfo" to "ifnottex" as suggested by the
2144         execution of "makeinfo --html make.texi".
2146 2003-04-30  Paul D. Smith  <psmith@gnu.org>
2148         * build.template: Make some changes to maybe allow this script to
2149         work on DOS/Windows/OS2 systems.  Suggested by Andreas Buening.
2151         * README.OS2.template: New file for OS/2 support.  Original
2152         contributed by Andreas Buening.
2153         * configure.in: Invoke new pds_AC_DOS_PATHS macro to test for
2154         DOS-style paths.
2156 2003-04-19  Paul D. Smith  <psmith@gnu.org>
2158         Fix bug #1405: allow a target to match multiple pattern-specific
2159         variables.
2161         * rule.c (create_pattern_var, lookup_pattern_var): Move these to
2162         variable.c, where they've always belonged.
2163         * rule.h: Move the prototypes and struct pattern_var as well.
2164         * variable.c (initialize_file_variables): Invoke
2165         lookup_pattern_var() in a loop, until no more matches are found.
2166         If a match is found, create a new variable set for the target's
2167         pattern variables.  Then merge the contents of each matching
2168         pattern variable set into the target's pattern variable set.
2169         (lookup_pattern_var): Change this function to be usable
2170         in a loop.  It takes a starting position: if NULL, start at the
2171         beginning; if non-NULL, start with the pattern variable after that
2172         position, and return the next matching pattern.
2173         (create_pattern_var): Create a unique instance of
2174         pattern-specific variables for every definition in the makefile.
2175         Don't combine the same pattern together.  This allows us to
2176         process the variable handling properly even when the same pattern
2177         is used multiple times.
2178         (parse_variable_definition): New function: break out the parsing
2179         of a variable definition line from try_variable_definition.
2180         (try_variable_definition): Call parse_variable_definition to
2181         parse.
2182         (print_variable_data_base): Print out pattern-specific variables.
2183         * variable.h (struct variable): Remember when a variable is
2184         conditional.  Also remember its flavor.
2185         (struct pattern_var): Instead of keeping a variable set, we just
2186         keep a single variable for each pattern.
2187         * read.c (record_target_var): Each pattern variable contains only a
2188         single variable, not a set, so create it properly.
2189         * doc/make.texi (Pattern-specific): Document the new behavior.
2191 2003-04-17  Paul D. Smith  <psmith@gnu.org>
2193         * dir.c (file_exists_p) [VMS]: Patch provided with Bug #3018 by
2194         Jean-Pierre Portier <portierjp2@free.fr>.  I don't understand the
2195         file/directory naming rules for VMS so I can't tell whether this
2196         is correct or not.
2198 2003-04-09  Paul D. Smith  <psmith@gnu.org>
2200         * configure.in (HAVE_DOS_PATHS): Define this on systems that need
2201         DOS-style pathnames: backslash separators and drive specifiers.
2203 2003-03-28  Paul D. Smith  <psmith@gnu.org>
2205         * file.c (snap_deps): If .SECONDARY with no targets is given, set
2206         the intermediate flag on all targets.  Fixes bug #2515.
2208 2003-03-24  Paul D. Smith  <psmith@gnu.org>
2210         * configure.in, Makefile.am, glob/Makefile.am, doc/Makefile.am:
2211         Upgrade to autoconf 2.57 and automake 1.7.3.
2213         * job.c: More OS/2 changes from Andreas Buening.
2215         * file.c (print_file): Fix variable initialization.
2216         Fixes bug #2892.
2218         * remake.c (notice_finished_file):
2220         * make.h (ENULLLOOP): Set errno = 0 before invoking the command;
2221         some calls (like readdir()) return NULL in valid situations
2222         without resetting errno.  Fixes bug #2846.
2224 2003-02-25  Paul D. Smith  <psmith@gnu.org>
2226         Port to OS/2 (__EMX__) by Andreas Buening <andreas.buening@nexgo.de>.
2228         * job.c (_is_unixy_shell) [OS/2]: New function.
2229         Set default shell to /bin/sh.
2230         (reap_children): Close the job_rfd pipe here since we don't use a
2231         SIGCHLD handler.
2232         (set_child_handler_action_flags): define this to empty on OS/2.
2233         (start_job_command): Close the jobserver pipe and use
2234         child_execute_job() instead of fork/exec.
2235         (child_execute_job): Rewrite to handle stdin/stdout FDs and spawn
2236         rather than exec'ing, then reconfigure stdin/stdout.
2237         (exec_command): Rewrite to use spawn instead of exec.  Return the
2238         PID of the child.
2240         * main.c (main) [OS/2]: Call initialize_main().  Handle argv[0] as
2241         in DOS.  Handle the TEMP environment variable as in DOS.  Don't
2242         use a SIGCHLD handler on OS/2.  Choose a shell as in DOS.  Don't
2243         use -j in DOS mode.  Use child_execute_job() instead of
2244         exec_command().
2246         * function.c (func_shell) [OS/2]: Can't use fork/exec on OS/2: use
2247         spawn() instead.
2249         * job.h [OS/2]: Move CLOSE_ON_EXEC here from job.c.  Add
2250         prototypes that return values.
2252         * remake.c (f_mtime) [OS/2]: Handle FAT timestamp offsets for OS/2.
2254         * read.c (readline) [OS/2]: Don't handle CRLF specially on OS/2.
2255         * default.c (default_suffixes) [OS/2]: Set proper default suffixes
2256         for OS/2.
2257         * vpath.c (construct_vpath_list) [OS/2]: Handle OS/2 paths like
2258         DOS paths.
2260 2003-02-24  Paul D. Smith  <psmith@gnu.org>
2262         * default.c [VMS]: New default rules for .cxx -> .obj compiles.
2263         * job.c (child_execute_job) [VMS]: New code for handling spawn().
2264         (child_execute_job) [VMS]: Handle error status properly.
2265         Patches provided by Hartmut Becker <Hartmut.Becker@compaq.com>.
2267         * function.c (func_shell): Use EINTRLOOP() while reading from the
2268         subshell pipe (Fixes bug #2502).
2269         * job.c (free_child): Use EINTRLOOP() while writing tokens to the
2270         jobserver pipe.
2271         * main.c (main): Ditto.
2273 2003-01-30  Paul D. Smith  <psmith@gnu.org>
2275         * read.c (eval): eval() was not fully reentrant, because the
2276         collapsed buffer was static.  Change it to be an automatic
2277         variable so that eval() can be invoked recursively.
2278         Fixes bug # 2238.
2279         (eval): Apply patch # 1022: fix memory reference error on long
2280         target-specific variable lines.
2281         Patch provided by Steve Brown <Steve.Brown@macquarie.com>.
2283         * function.c (check_numeric): Combine the is_numeric() function
2284         into this function, since it's only called from one place.
2285         Constify this function.  Have it print the incorrect string in the
2286         error message.  Fixes bug #2407.
2287         (strip_whitespace): Constify.
2288         (func_if): Constify.
2289         * expand.c (expand_argument): Constify.
2291 2003-01-29  Paul D. Smith  <psmith@gnu.org>
2293         Fix bug # 2169, also reported by other people on various systems.
2295         * make.h: Some systems, such as Solaris and PTX, do not fully
2296         implement POSIX-compliant SA_RESTART functionality; important
2297         system calls like stat() and readdir() can still fail with EINTR
2298         even if SA_RESTART has been set on the signal handler.  So,
2299         introduce macros EINTRLOOP() and ENULLLOOP() which can loop on
2300         EINTR for system calls which return -1 or 0 (NULL), respectively,
2301         on error.
2302         Also, remove the old atomic_stat()/atomic_readdir() and
2303         HAVE_BROKEN_RESTART handling.
2305         * configure.in: Remove setting of HAVE_BROKEN_RESTART.
2307         * arscan.c (ar_member_touch): Use EINTRLOOP() to wrap fstat().
2308         * remake.c (touch_file): Ditto.
2310         * commands.c (delete_target): Use EINTRLOOP() to wrap stat().
2311         * read.c (construct_include_path): Ditto.
2312         * remake.c (name_mtime): Ditto.
2313         * vpath.c (selective_vpath_search): Ditto.
2314         * dir.c (find_directory): Ditto.
2315         (local_stat): Ditto.
2316         (find_directory): Use ENULLLOOP() to wrap opendir().
2317         (dir_contents_file_exists_p): Use ENULLLOOP() to wrap readdir().
2319         * misc.c: Remove HAVE_BROKEN_RESTART, atomic_stat(), and
2320         atomic_readdir() handling.
2322 2003-01-22  Paul D. Smith  <psmith@gnu.org>
2324         * function.c (func_call): Fix Bug #1744.  If we're inside a
2325         recursive invocation of $(call ...), mask any of the outer
2326         invocation's arguments that aren't used by this one, so that this
2327         invocation doesn't "inherit" them accidentally.
2329 2002-12-05  Paul D. Smith  <psmith@gnu.org>
2331         * function.c (subst_expand): Valery Khamenia reported a
2332         pathological performance hit when doing substitutions on very
2333         large values with lots of words: turns out we were invoking
2334         strlen() a ridiculous number of times.  Instead of having each
2335         call to sindex() call strlen() again, keep track of how much of
2336         the text we've seen and pass the length to sindex().
2338 2002-11-19  Paul D. Smith  <psmith@gnu.org>
2340         * README.cvs, configure.in: Upgrade to require autoconf 2.56.
2343 2002-11-16  Paul D. Smith  <psmith@gnu.org>
2345         * NMakefile.template (OBJS): Add hash.c object file.
2346         * SMakefile.template (srcs): Ditto.
2347         * Makefile.ami (objs): Ditto.
2348         * build_w32.bat: Ditto.
2350         * Makefile.DOS.template: Remove extra dependencies.
2352 2002-10-25  Paul D. Smith  <psmith@gnu.org>
2354         * expand.c (install_variable_buffer): New function.  Install a new
2355         variable_buffer context and return the previous one.
2356         (restore_variable_buffer): New function.  Free the current
2357         variable_buffer context and put a previously saved one back.
2358         * variable.h: Prototypes for {install,restore}_variable_buffer.
2359         * function.c (func_eval): Push a new variable_buffer context
2360         before we eval, then restore the old one when we're done.
2361         Fixes Bug #1517.
2363         * read.c (install_conditionals): New function.  Install a new
2364         conditional context and return the previous one.
2365         (restore_conditionals): New function.  Free the current
2366         conditional context and put a previously saved one back.
2367         (eval): Use the {install,restore}_conditionals for "include"
2368         handling.
2369         (eval_buffer): Use {install,restore}_conditionals to preserve the
2370         present conditional state before we evaluate the buffer.
2371         Fixes Bug #1516.
2373         * doc/make.texi (Quick Reference): Add references to $(eval ...)
2374         and $(value ...).
2375         (Recursion): Add a variable index entry for CURDIR.
2377         * README.cvs: Update to appropriate versions.
2378         * Makefile.am (nodist_loadavg_SOURCES): automake gurus point out I
2379         don't need to copy loadavg.c: automake is smart enough to create
2380         it for me.  Still have a bug in automake related to ansi2knr tho.
2382 2002-10-14  Paul D. Smith  <psmith@gnu.org>
2384         * remake.c (notice_finished_file): Only touch targets if they have
2385         at least one command (as per POSIX).  Resolve Bug #1418.
2387         * *.c: Convert to using ANSI C-style function definitions.
2388         * Makefile.am: Enable the ansi2knr feature of automake.
2389         * configure.in: ditto.
2391 2002-10-13  Paul D. Smith  <psmith@gnu.org>
2393         * commands.c (set_file_variables): Bug #1379: Don't use alloca()
2394         for automatic variable values like $^, etc.  In the case of very
2395         large lists of prerequisites this causes problems.  Instead reuse
2396         a static buffer (resizeable) for each variable.
2398         * read.c (eval): Fix Bug #1391: allow "export" keyword in
2399         target-specific variable definitions.  Check for it and set an
2400         "exported" flag.
2401         (record_target_var): Set the export field to v_export if the
2402         "exported" flag is set.
2403         * doc/make.texi (Target-specific): Document the ability to use
2404         "export".
2406         * doc/make.texi: Change the name of the section on automatic
2407         variables from "Automatic" to "Automatic Variables".  Added text
2408         clarifying the scope of automatic variables.
2410 2002-10-04  Paul D. Smith  <psmith@gnu.org>
2412         * read.c (eval): Allow SysV $$@ variables to use {} braces as well
2413         as () braces.
2414         (record_files): Ditto.
2416         * expand.c (variable_expand_string): In $(A:x=y) expansion limit
2417         the search for the '=' to only within the enclosing parens.
2419 2002-10-03  Paul D. Smith  <psmith@gnu.org>
2421         Version 3.80 released.
2423         * dir.c: Change hash functions to use K&R function definition style.
2424         * function.c: Ditto.
2425         * read.c: Ditto.
2426         * variable.c: Ditto.
2428         Update to automake 1.7.
2430         * Makefile.am (AUTOMAKE_OPTIONS): Update to require 1.7.
2431         (pdf): Remove this target as automake now provides one.
2433         * configure.in: Change AM_CONFIG_HEADER to AC_CONFIG_HEADERS.
2435 2002-09-30  Martin P.J. Zinser  <zinser@decus.de>
2437         * makefile.com: Updates for GNU make 3.80.
2438         * makefile.vms: Ditto.
2440 2002-09-23  Paul D. Smith  <psmith@gnu.org>
2442         * read.c (enum make_word_type): Remove w_comment.
2443         (get_next_mword): Don't treat comment characters as special; where
2444         this function is used we will never see a comment (it's stripped
2445         before we get here) and treating comments specially means that
2446         targets like "foo\#bar" aren't handled properly.
2448 2002-09-18  Paul D. Smith  <psmith@gnu.org>
2450         * doc/make.texi (Bugs): Update with some info on Savannah, etc.
2452         * read.c (eval): Expansion of arguments to export/unexport was
2453         ignoring all arguments after the first one.  Change the algorithm
2454         to expand the whole line once, then parse the results.
2456 2002-09-17  Paul D. Smith  <psmith@gnu.org>
2458         Fix Bug #940 (plus another bug I found while looking at this):
2460         * read.c (record_target_var): enter_file() will add a new entry if
2461         it's a double-colon target: we don't want to do that in this
2462         situation.  Invoke lookup_file() and only enter_file() if it does
2463         not already exist.  If the file we get back is a double-colon then
2464         add this variable to the "root" double-colon target.
2466         * variable.c (initialize_file_variables): If this file is a
2467         double-colon target but is not the "root" target, then initialize
2468         the root and make the root's variable list the parent of our
2469         variable list.
2471 2002-09-13  Paul D. Smith  <psmith@gnu.org>
2473         * doc/make.texi (MAKE Variable): Add some indexing for "+".
2475         * hash.c (round_up_2): Get rid of a warning.
2477 2002-09-12  Paul D. Smith  <psmith@gnu.org>
2479         * Makefile.am (loadavg_SOURCES, loadavg.c): Tiptoe around automake
2480         so it doesn't complain about getloadavg.c.
2482         * commands.c (set_file_variables): Make sure we always alloca() at
2483         least 1 character for the value of $? (for '\0').
2485 2002-09-11  Paul D. Smith  <psmith@gnu.org>
2487         * hash.h (STRING_COMPARE, ISTRING_COMPARE, STRING_N_COMPARE): Fix
2488         macro to use RESULT instead of the incorrect _RESULT_.
2490         * make.h (HAVE_BROKEN_RESTART): Add prototypes for atomic_stat()
2491         and atomic_readdir().  We need to #include dirent.h to get this to
2492         work.
2493         * misc.c (atomic_readdir): Fix typos.
2495 2002-09-10  Paul D. Smith  <psmith@gnu.org>
2497         * read.c (eval): Expand variable lists given to export and
2498         unexport, so that "export $(LIST_OF_VARIABLES)" (etc.) works.
2499         (conditional_line): Ditto for "ifdef".  Fixes bug #103.
2501         * doc/make.texi (Variables/Recursion): Document this.
2502         (Conditional Syntax): And here.
2504 2002-09-09  Paul D. Smith  <psmith@gnu.org>
2506         * configure.in: Check for memmove().
2508 2002-09-07  Paul D. Smith  <psmith@gnu.org>
2510         * configure.in (HAVE_BROKEN_RESTART): Define this on PTX systems;
2511         Michael Sterrett <msterret@coat.com> reports that while it has
2512         SA_RESTART, it does not work properly.
2514         * misc.c (atomic_stat): If HAVE_BROKEN_RESTART, create a function
2515         that invokes stat() and loops to do it again if it returns EINTR.
2516         (atomic_readdir): Ditto, with readdir().
2518         * make.h (stat, readdir): If HAVE_BROKEN_RESTART, alias stat()
2519         and readdir() to atomic_stat() and atomic_readdir().
2521 2002-09-04  Paul D. Smith  <psmith@gnu.org>
2523         * implicit.c (pattern_search): Daniel <barkalow@reputation.com>
2524         reports that GNU make sometimes doesn't recognize that targets can
2525         be made, when directories can be created as prerequisites.  He
2526         reports that changing the order of predicates in the DEP->changed
2527         flag test so that lookup_file() is always performed, solves this
2528         problem.
2530 2002-08-08  Paul D. Smith  <psmith@gnu.org>
2532         * configure.in: Require a newer version of gettext.
2534         * misc.c (perror_with_name): Translate the format string (for
2535         right-to-left language support).
2536         (pfatal_with_name): Ditto.
2538         * main.c: Create a static array of strings to store the usage
2539         text.  This is done to facilitate translations.
2540         (struct command_switch): Remove argdesc and description fields.
2541         (switches): Remove values for obsolete fields.
2542         (print_usage): Print each element of the usage array.
2544         * hash.c: Change function definitions to be K&R style.
2546 2002-08-02  Paul D. Smith  <psmith@gnu.org>
2548         * NEWS: Remove the mention of .TARGETS; we aren't going to publish
2549         this one because it's too hard to get right.  We'll look at it for
2550         a future release.
2551         * main.c (main): Don't create the .TARGETS variable.
2552         * variable.c (handle_special_var): Don't handle .TARGETS.
2554 2002-08-01  Paul D. Smith  <psmith@gnu.org>
2556         * main.c (switches): Add a new option, -B (--always-make).  If
2557         specified, make will rebuild all targets that it encounters even
2558         if they don't appear to be out of date.
2559         (always_make_flag): New flag.
2560         * make.h: Extern always_make_flag.
2561         * remake.c (update_file_1): Check always_make_flag; if it's set we
2562         will always rebuild any target we can, even if none of its
2563         prerequisites are newer.
2564         * NEWS: Mention it.
2566         * doc/make.texi (Shell Function): Make it clear that make
2567         variables marked as "export" are not passed to instances of the
2568         shell function.
2570         Add new introspection variable .VARIABLES and .TARGETS.
2572         * variable.c (handle_special_var): New function.  If the variable
2573         reference passed in is "special" (.VARIABLES or .TARGETS),
2574         calculate the new value if necessary.  .VARIABLES is handled here:
2575         walk through the hash of defined variables and construct a value
2576         which is a list of the names.  .TARGETS is handled by
2577         build_target_list().
2578         (lookup_variable): Invoke handle_special_var().
2579         * file.c (build_target_list): Walk through the hask of known files
2580         and construct a list of the names of all the ones marked as
2581         targets.
2582         * main.c (main): Initialize them to empty (and as simple variables).
2583         * doc/make.texi (Special Variables): Document them.
2584         * NEWS: Mention them.
2586         * variable.h (struct variable): Add a new flag "exportable" which
2587         is true if the variable name is valid for export.
2588         * variable.c (define_variable_in_set): Set "exportable" when a new
2589         variable is defined.
2590         (target_environment): Use the "exportable" flag instead of
2591         re-checking the name here... an efficiency improvement.
2593 2002-07-31  Paul D. Smith  <psmith@gnu.org>
2595         * config.h-vms.template: Updates to build on VMS.  Thanks to
2596         Brian_Benning@aksteel.com for helping verify the build.
2597         * makefile.com: Build the new hash.c file.
2598         * hash.h: Use strcpmi(), not stricmp(), in the
2599         HAVE_CASE_INSENSITIVE_FS case.
2601 2002-07-30  Paul D. Smith  <psmith@gnu.org>
2603         * hash.h (ISTRING_COMPARE, return_ISTRING_COMPARE): Add missing
2604         backslashes to the HAVE_CASE_INSENSITIVE_FS case.
2605         Reported by <Brian_Benning@aksteel.com>.
2607 2002-07-10  Paul D. Smith  <psmith@gnu.org>
2609         * variable.c (pop_variable_scope): Remove variable made unused by
2610         new hash infrastructure.
2611         * read.c (dep_hash_cmp): Rewrite this to handle ignore_mtime
2612         comparisons as well as name comparisons.
2613         * variable.h: Add a prototype for new hash_init_function_table().
2614         * file.c (lookup_file): Remove variables made unused by new hash
2615         infrastructure.
2616         * dir.c (directory_contents_hash_2): Missing return of hash value.
2617         (dir_contents_file_exists_p): Remove variables made unused by new
2618         hash infrastructure.
2621         Installed Greg McGary's integration of the hash functions from the
2622         GNU id-utils package:
2624 2002-07-10  Greg McGary  <greg@mcgary.org>
2626         * scripts/functions/filter-out: Add literals to to the
2627         pattern space in order to add complexity, and trigger
2628         use of an internal hash table.  Fix documentation strings.
2629         * scripts/targets/INTERMEDIATE: Reverse order of files
2630         passed to expected `rm' command.
2632 2002-07-10  Greg McGary  <greg@mcgary.org>
2634         * Makefile.am (SRCS): Add hash.c (noinst_HEADERS): Add hash.h
2635         * hash.c: New file, taken from id-utils.
2636         * hash.h: New file, taken from id-utils.
2638         * make.h (HASH, HASHI): Remove macros.
2639         (find_char_unquote): Change arglist in decl.
2640         (hash_init_directories): New function decl.
2641         * variable.h (hash.h): New #include.
2642         (MAKELEVEL_NAME, MAKELEVEL_LENGTH): New constants.
2643         * filedef.h (hash.h): New #include.
2644         (struct file) [next]: Remove member.
2645         (file_hash_enter): Remove function decl.
2646         (init_hash_files): New function decl.
2648         * ar.c (ar_name): Delay call to strlen until needed.
2649         * main.c (initialize_global_hash_tables): New function.
2650         (main): Call it.  Use MAKELEVEL_NAME & MAKELEVEL_LENGTH.
2651         * misc.c (remove_comments): Pass char constants to find_char_unquote.
2652         * remake.c (notice_finished_file): Update last_mtime on `prev' chain.
2654         * dir.c (hash.h): New #include.
2655         (struct directory_contents) [next, files]: Remove members.
2656         [ctime]: Add member for VMS.  [dirfiles]: Add hash-table member.
2657         (directory_contents_hash_1, directory_contents_hash_2,
2658         directory_contents_hash_cmp): New functions.
2659         (directories_contents): Change type to `struct hash_table'.
2660         (struct directory) [next]: Remove member.
2661         (directory_hash_1, directory_hash_2, directory_hash_cmp): New funcs.
2662         (directory): Change type to `struct hash_table'.
2663         (struct dirfile) [next]: Remove member.
2664         [length]: Add member.  [impossible]: widen type to fill alignment gap.
2665         (dirfile_hash_1, dirfile_hash_2, dirfile_hash_cmp): New functions.
2666         (find_directory): Use new hash table package.
2667         (dir_contents_file_exists_p): Likewise.
2668         (file_impossible): Likewise.
2669         (file_impossible_p): Likewise.
2670         (print_dir_data_base): Likewise.
2671         (open_dirstream): Likewise.
2672         (read_dirstream): Likewise.
2673         (hash_init_directories): New function.
2675         * file.c (hash.h): New #include.
2676         (file_hash_1, file_hash_2, file_hash_cmp): New functions.
2677         (files): Change type to `struct hash_table'.
2678         (lookup_file): Use new hash table package.
2679         (enter_file): Likewise.
2680         (remove_intermediates): Likewise.
2681         (snap_deps): Likewise.
2682         (print_file_data_base): Likewise.
2684         * function.c
2685         (function_table_entry_hash_1, function_table_entry_hash_2,
2686         function_table_entry_hash_cmp): New functions.
2687         (lookup_function): Remove `table' argument.
2688         Use new hash table package.
2689         (struct a_word) [chain, length]: New members.
2690         (a_word_hash_1, a_word_hash_2, a_word_hash_cmp): New functions.
2691         (struct a_pattern): New struct.
2692         (func_filter_filterout): Pass through patterns noting boundaries
2693         and '%', if present.  Note a_word length.  Use a hash table if
2694         arglists are large enough to justify cost.
2695         (function_table_init): Renamed from function_table.
2696         (function_table): Declare as `struct hash_table'.
2697         (FUNCTION_TABLE_ENTRIES): New constant.
2698         (hash_init_function_table): New function.
2700         * read.c (hash.h): New #include.
2701         (read_makefile): Pass char constants to find_char_unquote.
2702         (dep_hash_1, dep_hash_2, dep_hash_cmp): New functions.
2703         (uniquize_deps): Use hash table to efficiently identify duplicates.
2704         (find_char_unquote): Accept two char-constant stop chars, rather
2705         than a string constant, avoiding zillions of calls to strchr.
2706         Tighten inner search loops to test only for desired delimiters.
2708         * variable.c (variable_hash_1, variable_hash_2,
2709         variable_hash_cmp): New functions.
2710         (variable_table): Declare as `struct hash_table'.
2711         (global_variable_set): Remove initialization.
2712         (init_hash_global_variable_set): New function.
2713         (define_variable_in_set): Use new hash table package.
2714         (lookup_variable): Likewise.
2715         (lookup_variable_in_set): Likewise.
2716         (initialize_file_variables): Likewise.
2717         (pop_variable_scope): Likewise.
2718         (create_new_variable_set): Likewise.
2719         (merge_variable_sets): Likewise.
2720         (define_automatic_variables): Likewise.
2721         (target_environment): Likewise.
2722         (print_variable_set): Likewise.
2724 2002-07-10  Paul D. Smith  <psmith@gnu.org>
2726         Implement the SysV make syntax $$@, $$(@D), and $$(@F) in the
2727         prerequisite list.  A real SysV make will expand the entire
2728         prerequisites list _twice_: we don't do that as it's a big
2729         backward-compatibility problem.  We only replace those specific
2730         variables.
2732         * read.c (record_files): Replace any $@, $(@D), and $(@F) variable
2733         references left in the list of prerequisites.  Check for .POSIX as
2734         we record targets, so we can disable non-POSIX behavior while
2735         reading makefiles as well as running them.
2736         (eval): Check the prerequisite list to see if we have anything
2737         that looks like a SysV prerequisite variable reference.
2739 2002-07-09  Paul D. Smith  <psmith@gnu.org>
2741         * doc/make.texi (Prerequisite Types): Add a new section describing
2742         order-only prerequisites.
2744         * read.c (uniquize_deps): If we have the same file as both a
2745         normal and order-only prereq, get rid of the order-only prereq,
2746         since the normal one supersedes it.
2748 2002-07-08  Paul D. Smith  <psmith@gnu.org>
2750         * AUTHORS: Added Greg McGary to the AUTHORS file.
2751         * NEWS: Blurbed order-only prerequisites.
2752         * file.c (print_file): Show order-only deps properly when printing
2753         the database.
2755         * maintMakefile: Add "update" targets for wget'ing the latest
2756         versions of various external files.  Taken from Makefile.maint in
2757         autoconf, etc.
2759         * dosbuild.bat: Somehow we got _double_ ^M's.  Remove them.
2760         Reported by Eli Zaretskii <eliz@is.elta.co.il>.
2762 2002-07-07  Paul D. Smith  <psmith@gnu.org>
2764         * po/*.po: Remove.  We'll use wget to retrieve them at release
2765         time.
2767         * variable.c (do_variable_definition) [W32]: On W32 using cmd
2768         rather than a shell you get an exception.  Make sure we look up
2769         the variable.  Patch provided by Eli Zaretskii <eliz@is.elta.co.il>.
2771         * remake.c (notice_finished_file): Fix handling of -t flag.
2772         Patch provided by Henning Makholm <henning@makholm.net>.
2774         * implicit.c (pattern_search): Some systems apparently run short
2775         of stack space, and using alloca() in this function caused an
2776         overrun.  I modified it to use xmalloc() on the two variables
2777         which seemed like they might get large.  Fixes Bug #476.
2779         * main.c (print_version): Update copyright notice to conform with
2780         GNU standards.
2781         (print_usage): Update help output.
2783         * function.c (func_eval): Create a new make function, $(eval
2784         ...).  Expand the arguments, put them into a buffer, then invoke
2785         eval_buffer() on the resulting string.
2786         (func_quote): Create a new function, $(quote VARNAME).  Inserts
2787         the value of the variable VARNAME without expanding it any
2788         further.
2790         * read.c (struct ebuffer): Change the linebuffer structure to an
2791         "eval buffer", which can be either a file or a buffer.
2792         (eval_makefile): Move the code in the old read_makefile() which
2793         located a makefile into here: create a struct ebuffer with that
2794         information.  Have it invoke the new function eval() with that
2795         ebuffer.
2796         (eval_buffer): Create a new function that creates a struct ebuffer
2797         that holds a string buffer instead of a file.  Have it invoke
2798         eval() with that ebuffer.
2799         (eval): New function that contains the guts of the old
2800         read_makefile() function: this function parses makefiles.  Obtains
2801         data to parse from the provided ebuffer.  Some modifications to
2802         make the flow of the function cleaner and clearer.  Still could
2803         use some work here...
2804         (do_define): Takes a struct ebuffer instead of a FILE*.  Read the
2805         contents of the define/endef variable from the ebuffer.
2806         (readstring): Read the next line from a string-style ebuffer.
2807         (readline): Read the next line from an ebuffer.  If it's a string
2808         ebuffer, invoke readstring().  If it's a FILE* ebuffer, read it
2809         from the file.
2811         * dep.h (eval_buffer): Prototype eval_buffer();
2813         * variable.c (do_variable_definition): Make sure that all
2814         non-target-specific variables are registered in the global set.
2815         If we're invoked from an $(eval ...) we might be inside a $(call
2816         ...) or other function which has pushed a variable scope; we still
2817         want to define our variables from evaluated makefile code in the
2818         global scope.
2820 2002-07-03  Greg McGary  <greg@mcgary.org>
2822         * dep.h (struct dep) [ignore_mtime]: New member.
2823         [changed]: convert to a bitfield.
2824         * implicit.c (pattern_search): Zero ignore_mtime.
2825         * main.c (main, handle_non_switch_argument): Likewise.
2826         * rule.c (convert_suffix_rule): Likewise.
2827         * read.c (read_all_makefiles, read_makefile, multi_glob): Likewise.
2828         (read_makefile): Parse '|' in prerequisite list.
2829         (uniquize_deps): Consider ignore_mtime when comparing deps.
2830         * remake.c (update_file_1, check_dep): Don't force remake for
2831         dependencies that have d->ignore_mtime.
2832         * commands.c (FILE_LIST_SEPARATOR): New constant.
2833         (set_file_variables): Don't include a
2834         prerequisite in $+, $^ or $? if d->ignore_mtime.
2835         Define $|.
2837 2002-06-18  Paul D. Smith  <psmith@gnu.org>
2839         * make.texinfo: Updates for next revision.  New date/rev/etc.
2840         Recreate all Info menus.  Change license on the manual to the GNU
2841         Free Documentation License.  A number of typos.
2842         (Variables Simplify): Don't use "-" before it's defined.
2843         (Automatic Prerequisites): Rewrite the target example to work
2844         properly if the compile fails.  Remove incorrect comments about
2845         how "set -e" behaves.
2846         (Text Functions): Move the "word", "wordlist", "words", and
2847         "firstword" functions here, from "File Name Functions".
2848         * make-stds.texi: Update from latest GNU version.
2849         * fdl.texi: (created) Import the latest GNU version.
2851 2002-06-06  Paul D. Smith  <psmith@gnu.org>
2853         * variable.c (do_variable_definition): New function: extract the
2854         part of try_variable_definition() that actually sets the value
2855         into a separate function.
2856         (try_variable_definition): Call do_variable_definition() after
2857         parsing the variable definition string.
2858         (define_variable_in_set): Make the name argument const.
2860         * variable.h (enum variable_flavor): Make public.
2861         (do_variable_definition): Create prototype.
2863         * read.c (read_all_makefiles): Create a new built-in variable,
2864         MAKEFILE_LIST.
2865         (read_makefile): Add each makefile read in to this variable value.
2867 2002-05-18  Eli Zaretskii  <eliz@is.elta.co.il>
2869         * Makefile.DOS.template: Tweak according to changes in the
2870         distribution.  Add back the dependencies of *.o files.
2872         * configh.dos.template: Synchronize with config.h.in.
2874 2002-05-09  Paul D. Smith  <psmith@gnu.org>
2876         * file.c (file_timestamp_now): Use K&R function declaration.
2878         * getloadavg.c (getloadavg): Merge setlocale() fix from sh-utils
2879         getloadavg.c.  Autoconf thinks QNX is SVR4-like, but it isn't, so
2880         #undef it.  Remove predefined setup of NLIST_STRUCT.  Decide
2881         whether to include nlist.h based on HAVE_NLIST_H.  Change obsolete
2882         NLIST_NAME_UNION to new HAVE_STRUCT_NLIST_N_UN_N_NAME.
2883         * configure.in (NLIST_STRUCT): Define this if we have nlist.h and
2884         nlist.n_name is a pointer rather than an array.
2886         * acinclude.m4 (make_FUNC_SETVBUF_REVERSED): Grab the latest
2887         version of AC_FUNC_SETVBUF_REVERSED from autoconf CVS.
2888         * configure.in: Use it instead of the old version.
2890         * main.c (main): Prefer setvbuf() to setlinebuf().
2892 2002-05-08  Paul D. Smith  <psmith@gnu.org>
2894         * Makefile.am (make_LDADD): Add GETLOADAVG_LIBS.
2895         (loadavg_LDADD): Ditto.
2897 2002-04-29  Paul D. Smith  <psmith@gnu.org>
2899         * expand.c (recursively_expand_for_file): Rename
2900         recursively_expand() to recursively_expand_for_file() and provide
2901         an extra argument, struct file.  If the argument is provided, set
2902         the variable scope to that of the file before expanding.
2903         * variable.h (recursively_expand): Make this a macro that invokes
2904         recursively_expand_for_file() with a NULL file pointer.
2905         * variable.c (target_environment): Call the renamed function and
2906         provide the current file context.
2907         Fixes Debian bug #144306.
2909 2002-04-28  Paul D. Smith  <psmith@gnu.org>
2911         Allow $(call ...) user-defined variables to be self-referencing
2912         without throwing an error.  Allows implementation of transitive
2913         closures, among other possibly useful things.
2914         Requested by: Philip Guenther <guenther@sendmail.com>
2916         * variable.h (struct variable): Add a new field: exp_count, and
2917         new macros to hold its size and maximum value.
2918         (warn_undefined): Make this a macro.
2919         * variable.c (define_variable_in_set): Initialize it.
2920         * expand.c (recursively_expand): If we detect recursive expansion
2921         of a variable, check the exp_count field.  If it's greater than 0
2922         allow the recursion and decrement the count.
2923         (warn_undefined): Remove this (now a macro in variable.h).
2924         * function.c (func_call): Before we expand the user-defined
2925         function, modify its exp_count field to contain the maximum
2926         number of recursive calls we'll allow.  After the call, reset it
2927         to 0.
2929 2002-04-21  Paul D. Smith  <psmith@gnu.org>
2931         Modified to use latest autoconf (2.53), automake (1.6.1), and
2932         gettext (0.11.1).  We're using gettext's new "external" support,
2933         to avoid including libintl source with GNU make.
2935         * README.cvs: New file.  Explain how to build GNU make from CVS.
2937         * configure.in: Modify checking for the system glob library.
2938         Use AC_EGREP_CPP instead of AC_TRY_CPP.  Remove the setting of
2939         GLOBDIR (we will always put "glob" in SUBDIRS, so automake
2940         etc. will manage it correctly).  Set an automake conditional
2941         USE_LOCAL_GLOB to decide whether to compile the glob library.
2943         * getloadavg.c (main): Include make.h in the "TEST" program to
2944         avoid warnings.
2946         * Makefile.am: Remove special rules for loadavg.  Replace them
2947         with Automake capabilities for building extra programs.
2949         * signame.c: This file does nothing if the system provide
2950         strsignal().  If not, it implements strsignal().  If the system
2951         doesn't define sys_siglist, then we make our own; otherwise we use
2952         the system version.
2953         * signame.h: Removed.
2955         * main.c (main): No need to invoke signame_init().  Update copyright.
2957         * ABOUT-NLS: Removed.
2958         * gettext.c: Removed.
2959         * gettext.h: Get a simplified copy from the gettext package.
2960         * po/*: Created.
2961         * i18n/*.po: Moved to po/.
2962         * i18n/: Removed.
2964         * config/*: Created.  Contains package configuration helper files.
2965         * config.guess, config.sub: Moved to config directory.
2967         * configure.in (AC_CONFIG_FILES): Add po/Makefile.in, config/Makefile.
2968         Rework to use new-style autoconf features.  Use the "external"
2969         mode for gettext.  Make the build.sh config file conditional on
2970         whether build.sh.in exists, to avoid autoconf errors.
2971         * acinclude.m4: Removed almost all macros as being obsolete.
2972         Rewrote remaining macros to use AC_DEFINE.
2973         * acconfig.h: Removed.
2975         * Makefile.am (EXTRA_DIST): Add config/config.rpath.  Use a
2976         conditional to handle customs support.  Remove special handling
2977         for i18n features.
2979 2002-04-20  Paul D. Smith  <psmith@gnu.org>
2981         * function.c (func_call): Don't mark the argument variables $1,
2982         etc. as recursive.  They've already been fully expanded so
2983         there's no need to do it again, and doing so strips escaped $'s.
2984         Reported by Sebastian Glita <glseba@yahoo.com>.
2986         * remake.c (notice_finished_file): Walk through double-colon
2987         entries via the prev field, not the next field!
2988         Reported by Greg McGary <greg@mcgary.org>.
2990         * main.c (main): If the user specifies -q and asks for a specific
2991         target which is a makefile, we got an assert.  In that case it
2992         turns out we should continue normally instead.
2994         * i18n/de.po, i18n/fr.po: Installed an updated translation.
2996         * i18n/he.po: Installed a new translation.
2998 2002-01-07  Paul D. Smith  <psmith@gnu.org>
3000         * i18n/es.po, i18n/ru.po: Installed an updated translation.
3002 2001-12-04  Paul D. Smith  <psmith@gnu.org>
3004         * i18n/ja.po: Installed an updated translation.
3006 2001-09-06  Paul Eggert  <eggert@twinsun.com>
3008         * configure.in (AC_CHECK_HEADERS): Add sys/resource.h.
3009         (AC_CHECK_FUNCS): Add getrlimit, setrlimit.
3011         * main.c: Include <sys/resource.h> if it, getrlimit, and setrlimit
3012         are available.
3013         (main): Get rid of any avoidable limit on stack size.
3015 2001-09-04  Paul D. Smith  <psmith@gnu.org>
3017         * i18n/da.po: Installed an updated translation.
3019 2001-08-03  Paul D. Smith  <psmith@gnu.org>
3021         * i18n/fr.po: Installed an updated translation.
3022         Resolves Debian bug #106720.
3024 2001-06-13  Paul D. Smith  <psmith@gnu.org>
3026         * i18n/da.po, configure.in (ALL_LINGUAS): Installed a new
3027         translation.
3029 2001-06-11  Paul D. Smith  <psmith@gnu.org>
3031         * i18n/ko.po: Installed a new translation.
3033 2001-05-06  Paul D. Smith  <psmith@gnu.org>
3035         Modify the EINTR handling.
3037         * job.c (new_job): Reorganize the jobserver algorithm.  Reorder
3038         the way in which we manage the file descriptor/signal handler race
3039         trap to be more efficient.
3041 2001-05-06  Paul Eggert  <eggert@twinsun.com>
3043         Restart almost all system calls that are interrupted, instead
3044         of worrying about EINTR.  The lone exception is the read() for
3045         job tokens.
3047         * configure.in (HAVE_SA_RESTART): New macro.
3048         (MAKE_JOBSERVER): Define to 1 only if HAVE_SA_RESTART.
3049         * main.c (main): Use SA_RESTART instead of the old,
3050         nonstandard SA_INTERRUPT.
3052         * configure.in (AC_CHECK_FUNCS): Add bsd_signal.
3053         * main.c (bsd_signal): New function or macro,
3054         if the implementation doesn't supply it.
3055         (The bsd_signal function will be in POSIX 1003.1-200x.)
3056         (HANDLESIG): Remove.
3057         (main, FATAL_SIG): Use bsd_signal instead of signal or HANDLESIG.
3059         * make.h (EINTR_SET): Remove.
3060         (SA_RESTART): New macro.
3062         * arscan.c (ar_member_touch): Don't worry about EINTR.
3063         * function.c (func_shell): Likewise.
3064         * job.c (reap_children, free_child, new_job): Likewise.
3065         * main.c (main): Likewise.
3066         * remake.c (touch_file, name_mtime): Likewise.
3068         * arscan.c (ar_member_touch): Fix bug uncovered by EINTR removal;
3069         if fstat failed with errno!=EINTR, the error was ignored.
3071         * job.c (set_child_handler_action_flags): New function.
3072         (new_job): Use it to temporarily clear the SIGCHLD action flags
3073         while reading the token.
3075 2001-05-02  Paul D. Smith  <psmith@gnu.org>
3077         * job.c (start_job_command): Don't add define/endef per-line flags
3078         to the top-level flags setting.
3080 2001-04-03  Paul D. Smith  <psmith@gnu.org>
3082         * arscan.c (VMS_get_member_info,ar_scan) [VMS]: VMS sets the low
3083         bit on error, so check for odd return values, not non-0 return
3084         values.
3085         (VMS_get_member_info): Calculate the timezone differences correctly.
3086         Reported by John Fowler <jfowler@nyx.net>.
3089 2001-03-14  Paul D. Smith  <psmith@gnu.org>
3091         * variable.c (lookup_variable) [VMS]: Null-terminate the variable
3092         value before invoking define_variable().
3093         Reported by John Fowler <jfowler@nyx.net>.
3095 2001-02-07  Paul D. Smith  <psmith@gnu.org>
3097         * read.c (record_target_var): If we reset the variable due to a
3098         command-line variable setting overriding it, turn off the "append"
3099         flag.
3101 2001-01-17  Paul D. Smith  <psmith@gnu.org>
3103         * variable.c (lookup_variable) [VMS]: When getting values from the
3104         environment, allocate enough space for the _value_ plus escapes,
3105         not enough space for the name plus escapes :-/.
3106         Reported by John Fowler <jfowler@nyx.net>.
3108         * remake.c (f_mtime): Removed the "***" prefix from the mod time
3109         warnings that make generates, so it doesn't look like an error.
3110         Reported by Karl Berry <karl@gnu.org>.
3113         Fix for PR/2020:  Rework appended target-specific variables.  I'm
3114         fairly confident this algorithm is finally correct.
3116         * expand.c (allocated_variable_append): Rewrite.  Instead of
3117         expanding each appended variable then adding all the expanded
3118         strings together, we append all the unexpanded values going up
3119         through the variable set contexts, then expand the final result.
3120         This behaves just like non-target-specific appended variable
3121         values, while the old way didn't in various corner cases.
3122         (variable_append): New function: recursively append the unexpanded
3123         value of a variable, walking from the outermost variable scope to
3124         the innermost.
3125         * variable.c (lookup_variable): Remove the code that looked up the
3126         variable set list if the found variable was "append".  We don't
3127         need this anymore.
3128         (lookup_variable_in_set): Make this non-static so we can use it
3129         elsewhere.
3130         (try_variable_definition): Use lookup_variable_in_set() rather
3131         than faking out current_variable_set_list by hand (cleanup).
3132         * variable.h: Add a prototype for the now non-static
3133         lookup_variable_in_set().
3135 2000-11-17  Paul D. Smith  <psmith@gnu.org>
3137         * remake.c (f_mtime) [WINDOWS32]: On various advice, I changed the
3138         WINDOWS32 port to assume timestamps can be up to 3 seconds away
3139         before throwing a fit.
3141 2000-11-17  Paul D. Smith  <psmith@gnu.org>
3143         * read.c (readline): CRLF calculations had a hole, if you hit the
3144         buffer grow scenario just right.  Reworked the algorithm to avoid
3145         the need for len or lastlen at all.  Problem description with
3146         sample code chages provided by Chris Faylor <cgf@redhat.com>.
3148 2000-10-24  Paul D. Smith  <psmith@gnu.org>
3150         * gettext.c (SWAP): Declare this with the prototype, otherwise
3151         some systems don't work (non-32-bit?  Reported for Cray T3E).
3152         Reported by Thorstein Thorsteinsson <thor@signe.teokem.lu.se>.
3154 2000-10-05  Paul D. Smith  <psmith@gnu.org>
3156         * acinclude.m4 (AM_LC_MESSAGES): Remove undefined macro
3157         AM_LC_MESSAGES; it doesn't seem to do anything anyway??
3159         * i18n/gl.po, configure.in (ALL_LINGUAS): New Galician translation.
3161 2000-09-22  Paul D. Smith  <psmith@gnu.org>
3163         * gettext.c: Don't #define _GETTEXT_H here; we only include some
3164         parts of the real gettext.h here, and we expect to really include
3165         the real gettext.h later.  If we keep this #define, it's ignored.
3167 2000-09-21  Paul D. Smith  <psmith@gnu.org>
3169         * main.c (log_working_directory): Rework the text to use complete
3170         sentences, to make life simpler for the translators.
3172 2000-08-29  Paul D. Smith  <psmith@gnu.org>
3174         * file.c (remove_intermediates): Print a debug message before we
3175         remove intermediate files, so the user (if she uses -d) knows
3176         what's going on.
3178 2000-08-21  Paul D. Smith  <psmith@gnu.org>
3180         * variable.c (try_variable_definition): Change how we handle
3181         target-specific append variable defns: instead of just setting the
3182         value, expand it as an append _but_ only within the current
3183         target's context.  Otherwise we lose all but the last value if the
3184         variable is appended more than once within the current target
3185         context.  Fixes PR/1831.
3187 2000-08-16  Paul D. Smith  <psmith@gnu.org>
3189         * function.c (func_shell): Nul-terminate the buffer before
3190         printing an exec error message (just in case it's not!).
3191         Fixes PR/1860, reported by Joey Hess <joey@valinux.com>.
3193 2000-07-25  Paul D. Smith  <psmith@gnu.org>
3195         * job.c (construct_command_argv_internal): Add "~" to the list of
3196         sh_chars[] which disallow optimizing out the shell call.
3198 2000-07-23  Paul Eggert  <eggert@twinsun.com>
3200         * NEWS, make.texinfo: Document .LOW_RESOLUTION_TIME, which
3201         supersedes --disable-nsec-timestamps.
3202         * make.texinfo: Consistently use "time stamp" instead of "timestamp".
3203         * README: Remove --disable-nsec-timestamps.
3205         * filedef.h (struct file.low_resolution_time): New member.
3206         * file.c (snap_deps): Add support for .LOW_RESOLUTION_TIME.
3207         * remake.c (update_file_1):
3208         Avoid spurious rebuilds due to low resolution time stamps,
3209         generalizing the earlier code that applied only to archive members.
3210         (f_mtime): Archive members always have low resolution time stamps.
3212         * configure.in: Remove --disable-nsec-timestamps, as this has
3213         been superseded by .LOW_RESOLUTION_TIME.
3215 2000-07-23  Paul Eggert  <eggert@twinsun.com>
3217         * configure.in (enable_nsec_timestamps): Renamed from
3218         make_cv_nsec_timestamps, since enable/disable options
3219         shouldn't be cached.
3221 2000-07-23  Bruno Haible  <haible@clisp.cons.org>
3222        and  Paul Eggert  <eggert@twinsun.com>
3224         * file.c (file_timestamp_now):
3225         Use preprocessor-time check for FILE_TIMESTAMP_HI_RES
3226         so that clock_gettime is not linked unless needed.
3228         * filedef.h (FILE_TIMESTAMP_HI_RES):
3229         Remove definition; "configure" now does this.
3231         * configure.in (jm_AC_TYPE_UINTMAX_T): Move up,
3232         to before high resolution file timestamp check,
3233         since that check now uses uintmax_t.
3234         (FILE_TIMESTAMP_HI_RES): Define to nonzero if the code should use
3235         high resolution file timestamps.
3236         (HAVE_CLOCK_GETTIME): Do not define if !FILE_TIMESTAMP_HI_RES,
3237         so that we don't link in clock_gettime unnecessarily.
3239 2000-07-17  Paul D. Smith  <psmith@gnu.org>
3241         * i18n/ja.po: New version of the translation file.
3243 2000-07-07  Paul D. Smith  <psmith@gnu.org>
3245         * remake.c (f_mtime): If NO_FLOAT is defined, don't bother with
3246         the offset calculation.
3247         (name_mtime): Replace EINTR test with EINTR_SET macro.
3249 2000-07-07  Paul Eggert  <eggert@twinsun.com>
3251         Fix for PR/1811:
3253         * remake.c (update_file_1):
3254         Avoid spurious rebuilds of archive members due to their
3255         timestamp resolution being only one second.
3256         (f_mtime): Avoid spurious warnings of timestamps in the future due to
3257         the clock's resolution being lower than file timestamps'.
3258         When warning about future timestamps, report only the discrepancy,
3259         not the absolute value of the timestamp and the current time.
3261         * file.c (file_timestamp_now): New arg RESOLUTION.
3262         * filedef.h (file_timestamp_now): Likewise.
3263         (FILE_TIMESTAMP_NS): Now returns int.  All uses changed.
3265 2000-07-05  Paul D. Smith  <psmith@gnu.org>
3267         * variable.c (lookup_variable) [VMS]: Remove vestigial references
3268         to listp.  Fixes PR/1793.
3270 2000-06-26  Paul Eggert  <eggert@twinsun.com>
3272         * Makefile.am (MAINTAINERCLEANFILES): New macro, with stamp-pot in it.
3274         * dir.c (vms_hash): Ensure ctype macro args are nonnegative.
3276         * remake.c (f_mtime): Remove unused var memtime.
3278 2000-06-25  Martin Buchholz  <martin@xemacs.org>
3280         * make.texinfo, NEWS, TODO.private: Minor spelling corrections.
3281         Ran spell-check on make.texinfo.
3283 2000-06-23  Paul D. Smith  <psmith@gnu.org>
3285         * main.c (main): Replace EXIT_SUCCESS, EXIT_FAILURE, and
3286         EXIT_TROUBLE with MAKE_SUCCESS, MAKE_FAILURE, and MAKE_TROUBLE.
3287         * make.h: Define these macros.
3289         * Version 3.79.1 released.
3291         * configure.in: Add a new option, --disable-nsec-timestamps, to
3292         avoid using sub-second timestamps on systems that support it.  It
3293         can lead to problems, e.g. if your makefile relies on "cp -p".
3294         * README.template: Document the issue with "cp -p".
3296         * config.guess, config.sub: Updated.
3300 See ChangeLog.2, available in the CVS repository at:
3302         http://savannah.gnu.org/cvs/?group=make
3304 for earlier changes.
3307 Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 Free Software
3308 Foundation, Inc.
3309 This file is part of GNU Make.
3311 GNU Make is free software; you can redistribute it and/or modify it under the
3312 terms of the GNU General Public License as published by the Free Software
3313 Foundation; either version 3 of the License, or (at your option) any later
3314 version.
3316 GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
3317 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
3318 A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
3320 You should have received a copy of the GNU General Public License along with
3321 this program.  If not, see <http://www.gnu.org/licenses/>.