Blame SOURCES/make-3.82-warn_undefined_function.patch

5589dc
diff --git a/make-3.82-gbuild/function.c b/make-3.82-gbuild/function.c
5589dc
index e2f6c8c..ff0527f 100644
5589dc
--- a/make-3.82/function.c
5589dc
+++ b/make-3.82/function.c
5589dc
@@ -2333,8 +2333,10 @@ func_call (char *o, char **argv, const char *funcname UNUSED)
5589dc
   v = lookup_variable (fname, flen);
5589dc
 
5589dc
   if (v == 0)
5589dc
-    warn_undefined (fname, flen);
5589dc
-
5589dc
+    {
5589dc
+      warn_undefined (fname, flen);
5589dc
+      warn_undefined_function (fname, flen);
5589dc
+    }
5589dc
   if (v == 0 || *v->value == '\0')
5589dc
     return o;
5589dc
 
5589dc
diff --git a/make-3.82-gbuild/main.c b/make-3.82-gbuild/main.c
5589dc
index c6989e3..2f545a7 100644
5589dc
--- a/make-3.82/main.c
5589dc
+++ b/make-3.82/main.c
5589dc
@@ -275,6 +275,11 @@ static int print_usage_flag = 0;
5589dc
 
5589dc
 int warn_undefined_variables_flag;
5589dc
 
5589dc
+/* If nonzero, we should print a warning message
5589dc
+   for each attemtp to call an undefined user function.  */
5589dc
+
5589dc
+int warn_undefined_functions_flag;
5589dc
+
5589dc
 /* If nonzero, always build all targets, regardless of whether
5589dc
    they appear out of date or not.  */
5589dc
 
5589dc
@@ -368,6 +373,8 @@ static const char *const usage[] =
5589dc
                               Consider FILE to be infinitely new.\n"),
5589dc
     N_("\
5589dc
   --warn-undefined-variables  Warn when an undefined variable is referenced.\n"),
5589dc
+    N_("\
5589dc
+  --warn-undefined-functions  Warn when an undefined user function is called.\n"),
5589dc
     NULL
5589dc
   };
5589dc
 
5589dc
@@ -424,6 +431,8 @@ static const struct command_switch switches[] =
5589dc
     { CHAR_MAX+5, flag, &warn_undefined_variables_flag, 1, 1, 0, 0, 0,
5589dc
       "warn-undefined-variables" },
5589dc
     { CHAR_MAX+6, string, &eval_strings, 1, 0, 0, 0, 0, "eval" },
5589dc
+    { CHAR_MAX+7, flag, &warn_undefined_functions_flag, 1, 1, 0, 0, 0,
5589dc
+      "warn-undefined-functions" },
5589dc
     { 0, 0, 0, 0, 0, 0, 0, 0, 0 }
5589dc
   };
5589dc
 
5589dc
diff --git a/make-3.82-gbuild/make.h b/make-3.82-gbuild/make.h
5589dc
index 60ade4c..f2ebb56 100644
5589dc
--- a/make-3.82/make.h
5589dc
+++ b/make-3.82/make.h
5589dc
@@ -513,7 +513,7 @@ extern int env_overrides, no_builtin_rules_flag, no_builtin_variables_flag;
5589dc
 extern int print_version_flag, print_directory_flag, check_symlink_flag;
5589dc
 extern int warn_undefined_variables_flag, posix_pedantic, not_parallel;
5589dc
 extern int second_expansion, clock_skew_detected, rebuilding_makefiles;
5589dc
-extern int one_shell;
5589dc
+extern int one_shell, warn_undefined_functions_flag;
5589dc
 
5589dc
 /* can we run commands via 'sh -c xxx' or must we use batch files? */
5589dc
 extern int batch_mode_shell;
5589dc
diff --git a/make-3.82-gbuild/variable.h b/make-3.82-gbuild/variable.h
5589dc
index c215867..02713c1 100644
5589dc
--- a/make-3.82/variable.h
5589dc
+++ b/make-3.82/variable.h
5589dc
@@ -220,6 +220,13 @@ void undefine_variable_in_set (const char *name, unsigned int length,
5589dc
                                 (int)(l), (n)); \
5589dc
                               }while(0)
5589dc
 
5589dc
+#define warn_undefined_function(n,l) do{\
5589dc
+                              if (warn_undefined_functions_flag) \
5589dc
+                                error (reading_file, \
5589dc
+                                       _("warning: undefined function `%.*s'"), \
5589dc
+                                (int)(l), (n)); \
5589dc
+                              }while(0)
5589dc
+
5589dc
 char **target_environment (struct file *file);
5589dc
 
5589dc
 struct pattern_var *create_pattern_var (const char *target,
5589dc
--
5589dc
cgit v0.9.0.2-2-gbebe