mirror of
https://github.com/mirror/make.git
synced 2025-03-14 11:50:35 +08:00
Logging of implicit rule search gives limited information as to why a given implicit rule was rejected, and if no implicit rule is found we get the confusing "No rule to make target" result when the real issue is that some prerequisite of some implicit rule could not be built. Enhance logging around implicit rule search as follows: 1. The messages which refer to a rule print a description (the targets and prerequisites) of the rule. 2. A new message tells when a rule is rejected, along with the reason. 3. The 'Looking for an implicit rule...' message is printed for every prerequisite, not just the top-level target. 4. "Trying harder" message is printed, when intermediate prerequisites are going to be searched. 5. The 'No rule found...' and 'Found implicit rule...' messages are printed for every prerequisite, not just the top-level target. 6. "Ought to exist...", "Found..." or "Not found..." message is printed for each prerequisite. * src/rule.h (struct rule): Remember the definition of the rule. * src/rule.c (get_rule_defn): Compute the definition of a rule. (install_pattern_rule): Initialize the definition to empty. (create_pattern_rule): Ditto. (freerule): Free the definition. (print_rule): Use the definition when printing rules. * src/remake.c (update_file_1): Push debug output down into try_implicit_rule(). * src/implicit.c (try_implicit_rule): Add debugging (pattern_search): Show the rule definition in various debug output. Add new debug messages for implicit rule search. Additional changes by Paul Smith <psmith@gnu.org>: Since we usually don't need the rule definition, defer computing it until we do. * bootstrap.conf: Include the mempcpy Gnulib module. * src/makeint.h (mempcpy): Declare mempcpy if not available. * src/misc.c (mempcpy): Define mempcpy if not available. * src/config.h-vms.template: Don't set HAVE_MEMPCPY. * src/config.h.W32.template: Ditto. * src/rule.h (get_rule_defn): Return the definition of a rule. * src/rule.c (get_rule_defn): If we don't have a definition compute it; either way return it. * src/implicit.c (pattern_search): Rework the handling of explicit prerequisites to pattern rules to be more clear. There is no change in behavior.
60 lines
2.2 KiB
C
60 lines
2.2 KiB
C
/* Definitions for using pattern rules in GNU Make.
|
|
Copyright (C) 1988-2020 Free Software Foundation, Inc.
|
|
This file is part of GNU Make.
|
|
|
|
GNU Make is free software; you can redistribute it and/or modify it under the
|
|
terms of the GNU General Public License as published by the Free Software
|
|
Foundation; either version 3 of the License, or (at your option) any later
|
|
version.
|
|
|
|
GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
/* Structure used for pattern (implicit) rules. */
|
|
|
|
struct rule
|
|
{
|
|
struct rule *next;
|
|
const char **targets; /* Targets of the rule. */
|
|
unsigned int *lens; /* Lengths of each target. */
|
|
const char **suffixes; /* Suffixes (after '%') of each target. */
|
|
struct dep *deps; /* Dependencies of the rule. */
|
|
struct commands *cmds; /* Commands to execute. */
|
|
char *_defn; /* Definition of the rule. */
|
|
unsigned short num; /* Number of targets. */
|
|
char terminal; /* If terminal (double-colon). */
|
|
char in_use; /* If in use by a parent pattern_search. */
|
|
};
|
|
|
|
/* For calling install_pattern_rule. */
|
|
struct pspec
|
|
{
|
|
const char *target, *dep, *commands;
|
|
};
|
|
|
|
|
|
extern struct rule *pattern_rules;
|
|
extern struct rule *last_pattern_rule;
|
|
extern unsigned int num_pattern_rules;
|
|
|
|
extern unsigned int max_pattern_deps;
|
|
extern unsigned int max_pattern_targets;
|
|
extern size_t max_pattern_dep_length;
|
|
|
|
extern struct file *suffix_file;
|
|
|
|
|
|
void snap_implicit_rules (void);
|
|
void convert_to_pattern (void);
|
|
void install_pattern_rule (struct pspec *p, int terminal);
|
|
void create_pattern_rule (const char **targets, const char **target_percents,
|
|
unsigned short num, int terminal, struct dep *deps,
|
|
struct commands *commands, int override);
|
|
const char *get_rule_defn (struct rule *rule);
|
|
void print_rule_data_base (void);
|