diff options
author | Ben Elliston <bje@au.ibm.com> | 2004-05-22 02:39:35 +0000 |
---|---|---|
committer | Ben Elliston <bje@gcc.gnu.org> | 2004-05-22 12:39:35 +1000 |
commit | b02398bd5bebe35bc44def2963fee7a4c4cf3568 (patch) | |
tree | 0fb35652621330c19f8e8ce0ffeb987cb15f69d5 /gcc/c-opts.c | |
parent | 12fea1f9fcb7129531fa3f30a0688a80e68b5353 (diff) | |
download | gcc-b02398bd5bebe35bc44def2963fee7a4c4cf3568.tar.gz |
c.opt (Wmissing-include-dirs): New.
* c.opt (Wmissing-include-dirs): New.
* c-opts.c (c_common_handle_option): Pass true for user_supplied_p
to add_path () for -I, but false for OPT_idirafter, OPT_iquote and
OPT_isystem. Handle case OPT_Wmissing_include_dirs.
* c-incpath.h (add_path): Add fourth (bool) argument.
* c-incpath.c (add_env_var_paths): Pass false to add_path ().
(add_standard_paths): Likewise.
(remove_duplicates) [REASON_NOENT]: Warn if -Wmissing-include-dirs
is used and the directory was user-supplied via -I.
(add_path): Set p->user_supplied_p. Remove duplicated code by
using add_cpp_dir_path ().
* cpplib.h (struct cpp_options): Add warn_missing_include_dirs.
(struct cpp_dir): Add user_supplied_p.
* doc/invoke.texi (Warning Options): Document new option.
[testsuite]
* gcc.dg/cpp/Wmissingdirs.c: New.
From-SVN: r82121
Diffstat (limited to 'gcc/c-opts.c')
-rw-r--r-- | gcc/c-opts.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/gcc/c-opts.c b/gcc/c-opts.c index 1300b69cd0b..47c702474c7 100644 --- a/gcc/c-opts.c +++ b/gcc/c-opts.c @@ -297,7 +297,7 @@ c_common_handle_option (size_t scode, const char *arg, int value) case OPT_I: if (strcmp (arg, "-")) - add_path (xstrdup (arg), BRACKET, 0); + add_path (xstrdup (arg), BRACKET, 0, true); else { if (quote_chain_split) @@ -541,6 +541,10 @@ c_common_handle_option (size_t scode, const char *arg, int value) warn_missing_format_attribute = value; break; + case OPT_Wmissing_include_dirs: + cpp_opts->warn_missing_include_dirs = value; + break; + case OPT_Wmissing_prototypes: warn_missing_prototypes = value; break; @@ -939,7 +943,7 @@ c_common_handle_option (size_t scode, const char *arg, int value) break; case OPT_idirafter: - add_path (xstrdup (arg), AFTER, 0); + add_path (xstrdup (arg), AFTER, 0, true); break; case OPT_imacros: @@ -952,7 +956,7 @@ c_common_handle_option (size_t scode, const char *arg, int value) break; case OPT_iquote: - add_path (xstrdup (arg), QUOTE, 0); + add_path (xstrdup (arg), QUOTE, 0, true); break; case OPT_isysroot: @@ -960,7 +964,7 @@ c_common_handle_option (size_t scode, const char *arg, int value) break; case OPT_isystem: - add_path (xstrdup (arg), SYSTEM, 0); + add_path (xstrdup (arg), SYSTEM, 0, true); break; case OPT_iwithprefix: @@ -1390,7 +1394,7 @@ add_prefixed_path (const char *suffix, size_t chain) memcpy (path + prefix_len, suffix, suffix_len); path[prefix_len + suffix_len] = '\0'; - add_path (path, chain, 0); + add_path (path, chain, 0, false); } /* Handle -D, -U, -A, -imacros, and the first -include. */ |