From: Joey Ye Date: Fri, 9 May 2014 08:50:22 +0000 (+0000) Subject: files.c (find_file_in_dir): Always try to shorten for DOS non-system headers. X-Git-Tag: releases/gcc-5.1.0~7677 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=eac3e079667d0a56f2ba84469a764407f3aee2a9;p=thirdparty%2Fgcc.git files.c (find_file_in_dir): Always try to shorten for DOS non-system headers. 2014-05-09 Joey Ye * files.c (find_file_in_dir): Always try to shorten for DOS non-system headers. * init.c (ENABLE_CANONICAL_SYSTEM_HEADERS): Default enabled for DOS. From-SVN: r210264 --- diff --git a/libcpp/ChangeLog b/libcpp/ChangeLog index 20171bc8e9ec..619dfd8308aa 100644 --- a/libcpp/ChangeLog +++ b/libcpp/ChangeLog @@ -1,3 +1,9 @@ +2014-05-09 Joey Ye + + * files.c (find_file_in_dir): Always try to shorten for DOS + non-system headers. + * init.c (ENABLE_CANONICAL_SYSTEM_HEADERS): Default enabled for DOS. + 2014-05-07 Richard Biener * configure.ac: Always set need_64bit_hwint to yes. diff --git a/libcpp/files.c b/libcpp/files.c index 7e8877854445..ad68682e99e7 100644 --- a/libcpp/files.c +++ b/libcpp/files.c @@ -387,8 +387,14 @@ find_file_in_dir (cpp_reader *pfile, _cpp_file *file, bool *invalid_pch) char *copy; void **pp; - /* We try to canonicalize system headers. */ - if (CPP_OPTION (pfile, canonical_system_headers) && file->dir->sysp) + /* We try to canonicalize system headers. For DOS based file + * system, we always try to shorten non-system headers, as DOS + * has a tighter constraint on max path length. */ + if (CPP_OPTION (pfile, canonical_system_headers) && file->dir->sysp +#ifdef HAVE_DOS_BASED_FILE_SYSTEM + || !file->dir->sysp +#endif + ) { char * canonical_path = maybe_shorter_path (path); if (canonical_path) diff --git a/libcpp/init.c b/libcpp/init.c index f10413ab3eb5..b80951544d4a 100644 --- a/libcpp/init.c +++ b/libcpp/init.c @@ -27,8 +27,12 @@ along with this program; see the file COPYING3. If not see #include "filenames.h" #ifndef ENABLE_CANONICAL_SYSTEM_HEADERS +#ifdef HAVE_DOS_BASED_FILE_SYSTEM +#define ENABLE_CANONICAL_SYSTEM_HEADERS 1 +#else #define ENABLE_CANONICAL_SYSTEM_HEADERS 0 #endif +#endif static void init_library (void); static void mark_named_operators (cpp_reader *, int);