Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/make make(1): remove unnecessary fflush for empty sh...



details:   https://anonhg.NetBSD.org/src/rev/5c92a3da07ba
branches:  trunk
changeset: 950734:5c92a3da07ba
user:      rillig <rillig%NetBSD.org@localhost>
date:      Fri Jan 29 23:33:24 2021 +0000

description:
make(1): remove unnecessary fflush for empty shell files

If nothing is done to any file, there is no need to flush stdout.  Move
the call to each of the remaining branches, except for -t mode, where
Job_Touch already takes care of everything.

diffstat:

 usr.bin/make/job.c |  14 ++++++++------
 1 files changed, 8 insertions(+), 6 deletions(-)

diffs (54 lines):

diff -r 75f02582a70b -r 5c92a3da07ba usr.bin/make/job.c
--- a/usr.bin/make/job.c        Fri Jan 29 23:06:41 2021 +0000
+++ b/usr.bin/make/job.c        Fri Jan 29 23:33:24 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: job.c,v 1.400 2021/01/29 23:06:41 rillig Exp $ */
+/*     $NetBSD: job.c,v 1.401 2021/01/29 23:33:24 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -143,7 +143,7 @@
 #include "trace.h"
 
 /*     "@(#)job.c      8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: job.c,v 1.400 2021/01/29 23:06:41 rillig Exp $");
+MAKE_RCSID("$NetBSD: job.c,v 1.401 2021/01/29 23:33:24 rillig Exp $");
 
 /*
  * A shell defines how the commands are run.  All commands for a target are
@@ -1667,13 +1667,16 @@
         * flag *was* given, we just set the file to be stdout. Cute, huh?
         */
        if (Lst_IsEmpty(&gn->commands)) {
-               /* XXX: No need to flush stdout here */
                job->cmdFILE = stdout;
                run = FALSE;
        } else if (((gn->type & OP_MAKE) && !opts.noRecursiveExecute) ||
            (!opts.noExecute && !opts.touchFlag)) {
-               /* XXX: The above conditions are needlessly repeated */
+               /*
+                * XXX: The above conditions seem needlessly repeated but
+                * are subtly different.
+                */
                JobWriteShellCommands(job, gn, cmdsOK, &run);
+               (void)fflush(job->cmdFILE);
        } else if (!GNode_ShouldExecute(gn)) {
                /*
                 * Not executing anything -- just print all the commands to
@@ -1692,6 +1695,7 @@
                        JobPrintCommands(job);
                /* Don't execute the shell, thank you. */
                run = FALSE;
+               (void)fflush(job->cmdFILE);
        } else {
                /*
                 * Just touch the target and note that no shell should be
@@ -1701,8 +1705,6 @@
                Job_Touch(gn, job->echo);
                run = FALSE;
        }
-       /* Just in case it isn't already... */
-       (void)fflush(job->cmdFILE);
 
        /* If we're not supposed to execute a shell, don't. */
        if (!run) {



Home | Main Index | Thread Index | Old Index