PR libstdc++/56278
[official-gcc.git] / libcpp / files.c
blob105cd96974847a69235d4f34f85f6201f001cb4e
1 /* Part of CPP library. File handling.
2 Copyright (C) 1986-2013 Free Software Foundation, Inc.
3 Written by Per Bothner, 1994.
4 Based on CCCP program by Paul Rubin, June 1986
5 Adapted to ANSI C, Richard Stallman, Jan 1987
6 Split out of cpplib.c, Zack Weinberg, Oct 1998
7 Reimplemented, Neil Booth, Jul 2003
9 This program is free software; you can redistribute it and/or modify it
10 under the terms of the GNU General Public License as published by the
11 Free Software Foundation; either version 3, or (at your option) any
12 later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; see the file COPYING3. If not see
21 <http://www.gnu.org/licenses/>. */
23 #include "config.h"
24 #include "system.h"
25 #include "cpplib.h"
26 #include "internal.h"
27 #include "mkdeps.h"
28 #include "obstack.h"
29 #include "hashtab.h"
30 #include "md5.h"
31 #include <dirent.h>
33 /* Variable length record files on VMS will have a stat size that includes
34 record control characters that won't be included in the read size. */
35 #ifdef VMS
36 # define FAB_C_VAR 2 /* variable length records (see Starlet fabdef.h) */
37 # define STAT_SIZE_RELIABLE(ST) ((ST).st_fab_rfm != FAB_C_VAR)
38 #else
39 # define STAT_SIZE_RELIABLE(ST) true
40 #endif
42 #ifdef __DJGPP__
43 #include <io.h>
44 /* For DJGPP redirected input is opened in text mode. */
45 # define set_stdin_to_binary_mode() \
46 if (! isatty (0)) setmode (0, O_BINARY)
47 #else
48 # define set_stdin_to_binary_mode() /* Nothing */
49 #endif
51 /* This structure represents a file searched for by CPP, whether it
52 exists or not. An instance may be pointed to by more than one
53 file_hash_entry; at present no reference count is kept. */
54 struct _cpp_file
56 /* Filename as given to #include or command line switch. */
57 const char *name;
59 /* The full path used to find the file. */
60 const char *path;
62 /* The full path of the pch file. */
63 const char *pchname;
65 /* The file's path with the basename stripped. NULL if it hasn't
66 been calculated yet. */
67 const char *dir_name;
69 /* Chain through all files. */
70 struct _cpp_file *next_file;
72 /* The contents of NAME after calling read_file(). */
73 const uchar *buffer;
75 /* Pointer to the real start of BUFFER. read_file() might increment
76 BUFFER; when freeing, this this pointer must be used instead. */
77 const uchar *buffer_start;
79 /* The macro, if any, preventing re-inclusion. */
80 const cpp_hashnode *cmacro;
82 /* The directory in the search path where FILE was found. Used for
83 #include_next and determining whether a header is a system
84 header. */
85 cpp_dir *dir;
87 /* As filled in by stat(2) for the file. */
88 struct stat st;
90 /* File descriptor. Invalid if -1, otherwise open. */
91 int fd;
93 /* Zero if this file was successfully opened and stat()-ed,
94 otherwise errno obtained from failure. */
95 int err_no;
97 /* Number of times the file has been stacked for preprocessing. */
98 unsigned short stack_count;
100 /* If opened with #import or contains #pragma once. */
101 bool once_only;
103 /* If read() failed before. */
104 bool dont_read;
106 /* If this file is the main file. */
107 bool main_file;
109 /* If BUFFER above contains the true contents of the file. */
110 bool buffer_valid;
112 /* If this file is implicitly preincluded. */
113 bool implicit_preinclude;
116 /* A singly-linked list for all searches for a given file name, with
117 its head pointed to by a slot in FILE_HASH. The file name is what
118 appeared between the quotes in a #include directive; it can be
119 determined implicitly from the hash table location or explicitly
120 from FILE->name.
122 FILE is a structure containing details about the file that was
123 found with that search, or details of how the search failed.
125 START_DIR is the starting location of the search in the include
126 chain. The current directories for "" includes are also hashed in
127 the hash table and therefore unique. Files that are looked up
128 without using a search path, such as absolute filenames and file
129 names from the command line share a special starting directory so
130 they don't cause cache hits with normal include-chain lookups.
132 If START_DIR is NULL then the entry is for a directory, not a file,
133 and the directory is in DIR. Since the starting point in a file
134 lookup chain is never NULL, this means that simple pointer
135 comparisons against START_DIR can be made to determine cache hits
136 in file lookups.
138 If a cache lookup fails because of e.g. an extra "./" in the path,
139 then nothing will break. It is just less efficient as CPP will
140 have to do more work re-preprocessing the file, and/or comparing
141 its contents against earlier once-only files.
143 struct file_hash_entry
145 struct file_hash_entry *next;
146 cpp_dir *start_dir;
147 source_location location;
148 union
150 _cpp_file *file;
151 cpp_dir *dir;
152 } u;
155 /* Number of entries to put in a file_hash_entry pool. */
156 #define FILE_HASH_POOL_SIZE 127
158 /* A file hash entry pool. We allocate file_hash_entry object from
159 one of these. */
160 struct file_hash_entry_pool
162 /* Number of entries used from this pool. */
163 unsigned int file_hash_entries_used;
164 /* Next pool in the chain; used when freeing. */
165 struct file_hash_entry_pool *next;
166 /* The memory pool. */
167 struct file_hash_entry pool[FILE_HASH_POOL_SIZE];
170 static bool open_file (_cpp_file *file);
171 static bool pch_open_file (cpp_reader *pfile, _cpp_file *file,
172 bool *invalid_pch);
173 static bool find_file_in_dir (cpp_reader *pfile, _cpp_file *file,
174 bool *invalid_pch);
175 static bool read_file_guts (cpp_reader *pfile, _cpp_file *file);
176 static bool read_file (cpp_reader *pfile, _cpp_file *file);
177 static bool should_stack_file (cpp_reader *, _cpp_file *file, bool import);
178 static struct cpp_dir *search_path_head (cpp_reader *, const char *fname,
179 int angle_brackets, enum include_type);
180 static const char *dir_name_of_file (_cpp_file *file);
181 static void open_file_failed (cpp_reader *pfile, _cpp_file *file, int);
182 static struct file_hash_entry *search_cache (struct file_hash_entry *head,
183 const cpp_dir *start_dir);
184 static _cpp_file *make_cpp_file (cpp_reader *, cpp_dir *, const char *fname);
185 static void destroy_cpp_file (_cpp_file *);
186 static cpp_dir *make_cpp_dir (cpp_reader *, const char *dir_name, int sysp);
187 static void allocate_file_hash_entries (cpp_reader *pfile);
188 static struct file_hash_entry *new_file_hash_entry (cpp_reader *pfile);
189 static int report_missing_guard (void **slot, void *b);
190 static hashval_t file_hash_hash (const void *p);
191 static int file_hash_eq (const void *p, const void *q);
192 static char *read_filename_string (int ch, FILE *f);
193 static void read_name_map (cpp_dir *dir);
194 static char *remap_filename (cpp_reader *pfile, _cpp_file *file);
195 static char *append_file_to_dir (const char *fname, cpp_dir *dir);
196 static bool validate_pch (cpp_reader *, _cpp_file *file, const char *pchname);
197 static int pchf_save_compare (const void *e1, const void *e2);
198 static int pchf_compare (const void *d_p, const void *e_p);
199 static bool check_file_against_entries (cpp_reader *, _cpp_file *, bool);
201 /* Given a filename in FILE->PATH, with the empty string interpreted
202 as <stdin>, open it.
204 On success FILE contains an open file descriptor and stat
205 information for the file. On failure the file descriptor is -1 and
206 the appropriate errno is also stored in FILE. Returns TRUE iff
207 successful.
209 We used to open files in nonblocking mode, but that caused more
210 problems than it solved. Do take care not to acquire a controlling
211 terminal by mistake (this can't happen on sane systems, but
212 paranoia is a virtue).
214 Use the three-argument form of open even though we aren't
215 specifying O_CREAT, to defend against broken system headers.
217 O_BINARY tells some runtime libraries (notably DJGPP) not to do
218 newline translation; we can handle DOS line breaks just fine
219 ourselves. */
220 static bool
221 open_file (_cpp_file *file)
223 if (file->path[0] == '\0')
225 file->fd = 0;
226 set_stdin_to_binary_mode ();
228 else
229 file->fd = open (file->path, O_RDONLY | O_NOCTTY | O_BINARY, 0666);
231 if (file->fd != -1)
233 if (fstat (file->fd, &file->st) == 0)
235 if (!S_ISDIR (file->st.st_mode))
237 file->err_no = 0;
238 return true;
241 /* Ignore a directory and continue the search. The file we're
242 looking for may be elsewhere in the search path. */
243 errno = ENOENT;
246 close (file->fd);
247 file->fd = -1;
249 #if defined(_WIN32) && !defined(__CYGWIN__)
250 else if (errno == EACCES)
252 /* On most UNIX systems, open succeeds on a directory. Above,
253 we check if we have opened a directory and if so, set errno
254 to ENOENT. However, on Windows, opening a directory
255 fails with EACCES. We want to return ENOENT in that
256 case too. */
257 if (stat (file->path, &file->st) == 0
258 && S_ISDIR (file->st.st_mode))
259 errno = ENOENT;
260 else
261 /* The call to stat may have reset errno. */
262 errno = EACCES;
264 #endif
265 else if (errno == ENOTDIR)
266 errno = ENOENT;
268 file->err_no = errno;
270 return false;
273 /* Temporary PCH intercept of opening a file. Try to find a PCH file
274 based on FILE->name and FILE->dir, and test those found for
275 validity using PFILE->cb.valid_pch. Return true iff a valid file is
276 found. Set *INVALID_PCH if a PCH file is found but wasn't valid. */
278 static bool
279 pch_open_file (cpp_reader *pfile, _cpp_file *file, bool *invalid_pch)
281 static const char extension[] = ".gch";
282 const char *path = file->path;
283 size_t len, flen;
284 char *pchname;
285 struct stat st;
286 bool valid = false;
288 /* No PCH on <stdin> or if not requested. */
289 if (file->name[0] == '\0' || !pfile->cb.valid_pch)
290 return false;
292 /* If the file is not included as first include from either the toplevel
293 file or the command-line it is not a valid use of PCH. */
294 if (pfile->all_files
295 && pfile->all_files->next_file
296 && !(pfile->all_files->implicit_preinclude
297 || pfile->all_files->next_file->implicit_preinclude))
298 return false;
300 flen = strlen (path);
301 len = flen + sizeof (extension);
302 pchname = XNEWVEC (char, len);
303 memcpy (pchname, path, flen);
304 memcpy (pchname + flen, extension, sizeof (extension));
306 if (stat (pchname, &st) == 0)
308 DIR *pchdir;
309 struct dirent *d;
310 size_t dlen, plen = len;
312 if (!S_ISDIR (st.st_mode))
313 valid = validate_pch (pfile, file, pchname);
314 else if ((pchdir = opendir (pchname)) != NULL)
316 pchname[plen - 1] = '/';
317 while ((d = readdir (pchdir)) != NULL)
319 dlen = strlen (d->d_name) + 1;
320 if ((strcmp (d->d_name, ".") == 0)
321 || (strcmp (d->d_name, "..") == 0))
322 continue;
323 if (dlen + plen > len)
325 len += dlen + 64;
326 pchname = XRESIZEVEC (char, pchname, len);
328 memcpy (pchname + plen, d->d_name, dlen);
329 valid = validate_pch (pfile, file, pchname);
330 if (valid)
331 break;
333 closedir (pchdir);
335 if (!valid)
336 *invalid_pch = true;
339 if (valid)
340 file->pchname = pchname;
341 else
342 free (pchname);
344 return valid;
347 /* Canonicalize the path to FILE. Return the canonical form if it is
348 shorter, otherwise return NULL. This function does NOT free the
349 memory pointed by FILE. */
351 static char *
352 maybe_shorter_path (const char * file)
354 char * file2 = lrealpath (file);
355 if (file2 && strlen (file2) < strlen (file))
357 return file2;
359 else
361 free (file2);
362 return NULL;
366 /* Try to open the path FILE->name appended to FILE->dir. This is
367 where remap and PCH intercept the file lookup process. Return true
368 if the file was found, whether or not the open was successful.
369 Set *INVALID_PCH to true if a PCH file is found but wasn't valid. */
371 static bool
372 find_file_in_dir (cpp_reader *pfile, _cpp_file *file, bool *invalid_pch)
374 char *path;
376 if (CPP_OPTION (pfile, remap) && (path = remap_filename (pfile, file)))
378 else
379 if (file->dir->construct)
380 path = file->dir->construct (file->name, file->dir);
381 else
382 path = append_file_to_dir (file->name, file->dir);
384 if (path)
386 hashval_t hv;
387 char *copy;
388 void **pp;
390 /* We try to canonicalize system headers. */
391 if (CPP_OPTION (pfile, canonical_system_headers) && file->dir->sysp)
393 char * canonical_path = maybe_shorter_path (path);
394 if (canonical_path)
396 /* The canonical path was newly allocated. Let's free the
397 non-canonical one. */
398 free (path);
399 path = canonical_path;
403 hv = htab_hash_string (path);
404 if (htab_find_with_hash (pfile->nonexistent_file_hash, path, hv) != NULL)
406 file->err_no = ENOENT;
407 return false;
410 file->path = path;
411 if (pch_open_file (pfile, file, invalid_pch))
412 return true;
414 if (open_file (file))
415 return true;
417 if (file->err_no != ENOENT)
419 open_file_failed (pfile, file, 0);
420 return true;
423 /* We copy the path name onto an obstack partly so that we don't
424 leak the memory, but mostly so that we don't fragment the
425 heap. */
426 copy = (char *) obstack_copy0 (&pfile->nonexistent_file_ob, path,
427 strlen (path));
428 free (path);
429 pp = htab_find_slot_with_hash (pfile->nonexistent_file_hash,
430 copy, hv, INSERT);
431 *pp = copy;
433 file->path = file->name;
435 else
437 file->err_no = ENOENT;
438 file->path = NULL;
441 return false;
444 /* Return tue iff the missing_header callback found the given HEADER. */
445 static bool
446 search_path_exhausted (cpp_reader *pfile, const char *header, _cpp_file *file)
448 missing_header_cb func = pfile->cb.missing_header;
450 /* When the regular search path doesn't work, try context dependent
451 headers search paths. */
452 if (func
453 && file->dir == NULL)
455 if ((file->path = func (pfile, header, &file->dir)) != NULL)
457 if (open_file (file))
458 return true;
459 free ((void *)file->path);
461 file->path = file->name;
464 return false;
467 bool
468 _cpp_find_failed (_cpp_file *file)
470 return file->err_no != 0;
473 /* Given a filename FNAME search for such a file in the include path
474 starting from START_DIR. If FNAME is the empty string it is
475 interpreted as STDIN if START_DIR is PFILE->no_search_path.
477 If the file is not found in the file cache fall back to the O/S and
478 add the result to our cache.
480 If the file was not found in the filesystem, or there was an error
481 opening it, then ERR_NO is nonzero and FD is -1. If the file was
482 found, then ERR_NO is zero and FD could be -1 or an open file
483 descriptor. FD can be -1 if the file was found in the cache and
484 had previously been closed. To open it again pass the return value
485 to open_file().
487 If IMPLICIT_PREINCLUDE then it is OK for the file to be missing.
488 If present, it is OK for a precompiled header to be included after
491 _cpp_file *
492 _cpp_find_file (cpp_reader *pfile, const char *fname, cpp_dir *start_dir,
493 bool fake, int angle_brackets, bool implicit_preinclude)
495 struct file_hash_entry *entry, **hash_slot;
496 _cpp_file *file;
497 bool invalid_pch = false;
498 bool saw_bracket_include = false;
499 bool saw_quote_include = false;
500 struct cpp_dir *found_in_cache = NULL;
502 /* Ensure we get no confusion between cached files and directories. */
503 if (start_dir == NULL)
504 cpp_error (pfile, CPP_DL_ICE, "NULL directory in find_file");
506 hash_slot = (struct file_hash_entry **)
507 htab_find_slot_with_hash (pfile->file_hash, fname,
508 htab_hash_string (fname),
509 INSERT);
511 /* First check the cache before we resort to memory allocation. */
512 entry = search_cache (*hash_slot, start_dir);
513 if (entry)
514 return entry->u.file;
516 file = make_cpp_file (pfile, start_dir, fname);
517 file->implicit_preinclude = implicit_preinclude;
519 /* Try each path in the include chain. */
520 for (; !fake ;)
522 if (find_file_in_dir (pfile, file, &invalid_pch))
523 break;
525 file->dir = file->dir->next;
526 if (file->dir == NULL)
528 if (search_path_exhausted (pfile, fname, file))
530 /* Although this file must not go in the cache, because
531 the file found might depend on things (like the current file)
532 that aren't represented in the cache, it still has to go in
533 the list of all files so that #import works. */
534 file->next_file = pfile->all_files;
535 pfile->all_files = file;
536 return file;
539 if (invalid_pch)
541 cpp_error (pfile, CPP_DL_ERROR,
542 "one or more PCH files were found, but they were invalid");
543 if (!cpp_get_options (pfile)->warn_invalid_pch)
544 cpp_error (pfile, CPP_DL_ERROR,
545 "use -Winvalid-pch for more information");
547 if (implicit_preinclude)
549 free ((char *) file->name);
550 free (file);
551 return NULL;
553 else
554 open_file_failed (pfile, file, angle_brackets);
555 break;
558 /* Only check the cache for the starting location (done above)
559 and the quote and bracket chain heads because there are no
560 other possible starting points for searches. */
561 if (file->dir == pfile->bracket_include)
562 saw_bracket_include = true;
563 else if (file->dir == pfile->quote_include)
564 saw_quote_include = true;
565 else
566 continue;
568 entry = search_cache (*hash_slot, file->dir);
569 if (entry)
571 found_in_cache = file->dir;
572 break;
576 if (entry)
578 /* Cache for START_DIR too, sharing the _cpp_file structure. */
579 free ((char *) file->name);
580 free (file);
581 file = entry->u.file;
583 else
585 /* This is a new file; put it in the list. */
586 file->next_file = pfile->all_files;
587 pfile->all_files = file;
590 /* Store this new result in the hash table. */
591 entry = new_file_hash_entry (pfile);
592 entry->next = *hash_slot;
593 entry->start_dir = start_dir;
594 entry->location = pfile->line_table->highest_location;
595 entry->u.file = file;
596 *hash_slot = entry;
598 /* If we passed the quote or bracket chain heads, cache them also.
599 This speeds up processing if there are lots of -I options. */
600 if (saw_bracket_include
601 && pfile->bracket_include != start_dir
602 && found_in_cache != pfile->bracket_include)
604 entry = new_file_hash_entry (pfile);
605 entry->next = *hash_slot;
606 entry->start_dir = pfile->bracket_include;
607 entry->location = pfile->line_table->highest_location;
608 entry->u.file = file;
609 *hash_slot = entry;
611 if (saw_quote_include
612 && pfile->quote_include != start_dir
613 && found_in_cache != pfile->quote_include)
615 entry = new_file_hash_entry (pfile);
616 entry->next = *hash_slot;
617 entry->start_dir = pfile->quote_include;
618 entry->location = pfile->line_table->highest_location;
619 entry->u.file = file;
620 *hash_slot = entry;
623 return file;
626 /* Read a file into FILE->buffer, returning true on success.
628 If FILE->fd is something weird, like a block device, we don't want
629 to read it at all. Don't even try to figure out what something is,
630 except for plain files and block devices, since there is no
631 reliable portable way of doing this.
633 FIXME: Flush file cache and try again if we run out of memory. */
634 static bool
635 read_file_guts (cpp_reader *pfile, _cpp_file *file)
637 ssize_t size, total, count;
638 uchar *buf;
639 bool regular;
641 if (S_ISBLK (file->st.st_mode))
643 cpp_error (pfile, CPP_DL_ERROR, "%s is a block device", file->path);
644 return false;
647 regular = S_ISREG (file->st.st_mode) != 0;
648 if (regular)
650 /* off_t might have a wider range than ssize_t - in other words,
651 the max size of a file might be bigger than the address
652 space. We can't handle a file that large. (Anyone with
653 a single source file bigger than 2GB needs to rethink
654 their coding style.) Some systems (e.g. AIX 4.1) define
655 SSIZE_MAX to be much smaller than the actual range of the
656 type. Use INTTYPE_MAXIMUM unconditionally to ensure this
657 does not bite us. */
658 if (file->st.st_size > INTTYPE_MAXIMUM (ssize_t))
660 cpp_error (pfile, CPP_DL_ERROR, "%s is too large", file->path);
661 return false;
664 size = file->st.st_size;
666 else
667 /* 8 kilobytes is a sensible starting size. It ought to be bigger
668 than the kernel pipe buffer, and it's definitely bigger than
669 the majority of C source files. */
670 size = 8 * 1024;
672 /* The + 16 here is space for the final '\n' and 15 bytes of padding,
673 used to quiet warnings from valgrind or Address Sanitizer, when the
674 optimized lexer accesses aligned 16-byte memory chunks, including
675 the bytes after the malloced, area, and stops lexing on '\n'. */
676 buf = XNEWVEC (uchar, size + 16);
677 total = 0;
678 while ((count = read (file->fd, buf + total, size - total)) > 0)
680 total += count;
682 if (total == size)
684 if (regular)
685 break;
686 size *= 2;
687 buf = XRESIZEVEC (uchar, buf, size + 16);
691 if (count < 0)
693 cpp_errno (pfile, CPP_DL_ERROR, file->path);
694 free (buf);
695 return false;
698 if (regular && total != size && STAT_SIZE_RELIABLE (file->st))
699 cpp_error (pfile, CPP_DL_WARNING,
700 "%s is shorter than expected", file->path);
702 file->buffer = _cpp_convert_input (pfile,
703 CPP_OPTION (pfile, input_charset),
704 buf, size + 16, total,
705 &file->buffer_start,
706 &file->st.st_size);
707 file->buffer_valid = true;
709 return true;
712 /* Convenience wrapper around read_file_guts that opens the file if
713 necessary and closes the file descriptor after reading. FILE must
714 have been passed through find_file() at some stage. */
715 static bool
716 read_file (cpp_reader *pfile, _cpp_file *file)
718 /* If we already have its contents in memory, succeed immediately. */
719 if (file->buffer_valid)
720 return true;
722 /* If an earlier read failed for some reason don't try again. */
723 if (file->dont_read || file->err_no)
724 return false;
726 if (file->fd == -1 && !open_file (file))
728 open_file_failed (pfile, file, 0);
729 return false;
732 file->dont_read = !read_file_guts (pfile, file);
733 close (file->fd);
734 file->fd = -1;
736 return !file->dont_read;
739 /* Returns TRUE if FILE's contents have been successfully placed in
740 FILE->buffer and the file should be stacked, otherwise false. */
741 static bool
742 should_stack_file (cpp_reader *pfile, _cpp_file *file, bool import)
744 _cpp_file *f;
746 /* Skip once-only files. */
747 if (file->once_only)
748 return false;
750 /* We must mark the file once-only if #import now, before header
751 guard checks. Otherwise, undefining the header guard might
752 cause the file to be re-stacked. */
753 if (import)
755 _cpp_mark_file_once_only (pfile, file);
757 /* Don't stack files that have been stacked before. */
758 if (file->stack_count)
759 return false;
762 /* Skip if the file had a header guard and the macro is defined.
763 PCH relies on this appearing before the PCH handler below. */
764 if (file->cmacro && file->cmacro->type == NT_MACRO)
765 return false;
767 /* Handle PCH files immediately; don't stack them. */
768 if (file->pchname)
770 pfile->cb.read_pch (pfile, file->pchname, file->fd, file->path);
771 file->fd = -1;
772 free ((void *) file->pchname);
773 file->pchname = NULL;
774 return false;
777 if (!read_file (pfile, file))
778 return false;
780 /* Check the file against the PCH file. This is done before
781 checking against files we've already seen, since it may save on
782 I/O. */
783 if (check_file_against_entries (pfile, file, import))
785 /* If this isn't a #import, but yet we can't include the file,
786 that means that it was #import-ed in the PCH file,
787 so we can never include it again. */
788 if (! import)
789 _cpp_mark_file_once_only (pfile, file);
790 return false;
793 /* Now we've read the file's contents, we can stack it if there
794 are no once-only files. */
795 if (!pfile->seen_once_only)
796 return true;
798 /* We may have read the file under a different name. Look
799 for likely candidates and compare file contents to be sure. */
800 for (f = pfile->all_files; f; f = f->next_file)
802 if (f == file)
803 continue;
805 if ((import || f->once_only)
806 && f->err_no == 0
807 && f->st.st_mtime == file->st.st_mtime
808 && f->st.st_size == file->st.st_size)
810 _cpp_file *ref_file;
811 bool same_file_p = false;
813 if (f->buffer && !f->buffer_valid)
815 /* We already have a buffer but it is not valid, because
816 the file is still stacked. Make a new one. */
817 ref_file = make_cpp_file (pfile, f->dir, f->name);
818 ref_file->path = f->path;
820 else
821 /* The file is not stacked anymore. We can reuse it. */
822 ref_file = f;
824 same_file_p = read_file (pfile, ref_file)
825 /* Size might have changed in read_file(). */
826 && ref_file->st.st_size == file->st.st_size
827 && !memcmp (ref_file->buffer,
828 file->buffer,
829 file->st.st_size);
831 if (f->buffer && !f->buffer_valid)
833 ref_file->path = 0;
834 destroy_cpp_file (ref_file);
837 if (same_file_p)
838 break;
842 return f == NULL;
845 /* Place the file referenced by FILE into a new buffer on the buffer
846 stack if possible. IMPORT is true if this stacking attempt is
847 because of a #import directive. Returns true if a buffer is
848 stacked. */
849 bool
850 _cpp_stack_file (cpp_reader *pfile, _cpp_file *file, bool import)
852 cpp_buffer *buffer;
853 int sysp;
855 if (!should_stack_file (pfile, file, import))
856 return false;
858 if (pfile->buffer == NULL || file->dir == NULL)
859 sysp = 0;
860 else
861 sysp = MAX (pfile->buffer->sysp, file->dir->sysp);
863 /* Add the file to the dependencies on its first inclusion. */
864 if (CPP_OPTION (pfile, deps.style) > !!sysp && !file->stack_count)
866 if (!file->main_file || !CPP_OPTION (pfile, deps.ignore_main_file))
867 deps_add_dep (pfile->deps, file->path);
870 /* Clear buffer_valid since _cpp_clean_line messes it up. */
871 file->buffer_valid = false;
872 file->stack_count++;
874 /* Stack the buffer. */
875 buffer = cpp_push_buffer (pfile, file->buffer, file->st.st_size,
876 CPP_OPTION (pfile, preprocessed)
877 && !CPP_OPTION (pfile, directives_only));
878 buffer->file = file;
879 buffer->sysp = sysp;
881 /* Initialize controlling macro state. */
882 pfile->mi_valid = true;
883 pfile->mi_cmacro = 0;
885 /* Generate the call back. */
886 _cpp_do_file_change (pfile, LC_ENTER, file->path, 1, sysp);
888 return true;
891 /* Mark FILE to be included once only. */
892 void
893 _cpp_mark_file_once_only (cpp_reader *pfile, _cpp_file *file)
895 pfile->seen_once_only = true;
896 file->once_only = true;
899 /* Return the directory from which searching for FNAME should start,
900 considering the directive TYPE and ANGLE_BRACKETS. If there is
901 nothing left in the path, returns NULL. */
902 static struct cpp_dir *
903 search_path_head (cpp_reader *pfile, const char *fname, int angle_brackets,
904 enum include_type type)
906 cpp_dir *dir;
907 _cpp_file *file;
909 if (IS_ABSOLUTE_PATH (fname))
910 return &pfile->no_search_path;
912 /* pfile->buffer is NULL when processing an -include command-line flag. */
913 file = pfile->buffer == NULL ? pfile->main_file : pfile->buffer->file;
915 /* For #include_next, skip in the search path past the dir in which
916 the current file was found, but if it was found via an absolute
917 path use the normal search logic. */
918 if (type == IT_INCLUDE_NEXT && file->dir
919 && file->dir != &pfile->no_search_path)
920 dir = file->dir->next;
921 else if (angle_brackets)
922 dir = pfile->bracket_include;
923 else if (type == IT_CMDLINE)
924 /* -include and -imacros use the #include "" chain with the
925 preprocessor's cwd prepended. */
926 return make_cpp_dir (pfile, "./", false);
927 else if (pfile->quote_ignores_source_dir)
928 dir = pfile->quote_include;
929 else
930 return make_cpp_dir (pfile, dir_name_of_file (file),
931 pfile->buffer ? pfile->buffer->sysp : 0);
933 if (dir == NULL)
934 cpp_error (pfile, CPP_DL_ERROR,
935 "no include path in which to search for %s", fname);
937 return dir;
940 /* Strip the basename from the file's path. It ends with a slash if
941 of nonzero length. Note that this procedure also works for
942 <stdin>, which is represented by the empty string. */
943 static const char *
944 dir_name_of_file (_cpp_file *file)
946 if (!file->dir_name)
948 size_t len = lbasename (file->path) - file->path;
949 char *dir_name = XNEWVEC (char, len + 1);
951 memcpy (dir_name, file->path, len);
952 dir_name[len] = '\0';
953 file->dir_name = dir_name;
956 return file->dir_name;
959 /* Handles #include-family directives (distinguished by TYPE),
960 including HEADER, and the command line -imacros and -include.
961 Returns true if a buffer was stacked. */
962 bool
963 _cpp_stack_include (cpp_reader *pfile, const char *fname, int angle_brackets,
964 enum include_type type)
966 struct cpp_dir *dir;
967 _cpp_file *file;
969 dir = search_path_head (pfile, fname, angle_brackets, type);
970 if (!dir)
971 return false;
973 file = _cpp_find_file (pfile, fname, dir, false, angle_brackets,
974 type == IT_DEFAULT);
975 if (type == IT_DEFAULT && file == NULL)
976 return false;
978 /* Compensate for the increment in linemap_add that occurs in
979 _cpp_stack_file. In the case of a normal #include, we're
980 currently at the start of the line *following* the #include. A
981 separate source_location for this location makes no sense (until
982 we do the LC_LEAVE), and complicates LAST_SOURCE_LINE_LOCATION.
983 This does not apply if we found a PCH file (in which case
984 linemap_add is not called) or we were included from the
985 command-line. */
986 if (file->pchname == NULL && file->err_no == 0
987 && type != IT_CMDLINE && type != IT_DEFAULT)
988 pfile->line_table->highest_location--;
990 return _cpp_stack_file (pfile, file, type == IT_IMPORT);
993 /* Could not open FILE. The complication is dependency output. */
994 static void
995 open_file_failed (cpp_reader *pfile, _cpp_file *file, int angle_brackets)
997 int sysp = pfile->line_table->highest_line > 1 && pfile->buffer ? pfile->buffer->sysp : 0;
998 bool print_dep = CPP_OPTION (pfile, deps.style) > (angle_brackets || !!sysp);
1000 errno = file->err_no;
1001 if (print_dep && CPP_OPTION (pfile, deps.missing_files) && errno == ENOENT)
1003 deps_add_dep (pfile->deps, file->name);
1004 /* If the preprocessor output (other than dependency information) is
1005 being used, we must also flag an error. */
1006 if (CPP_OPTION (pfile, deps.need_preprocessor_output))
1007 cpp_errno (pfile, CPP_DL_FATAL, file->path);
1009 else
1011 /* If we are not outputting dependencies, or if we are and dependencies
1012 were requested for this file, or if preprocessor output is needed
1013 in addition to dependency information, this is an error.
1015 Otherwise (outputting dependencies but not for this file, and not
1016 using the preprocessor output), we can still produce correct output
1017 so it's only a warning. */
1018 if (CPP_OPTION (pfile, deps.style) == DEPS_NONE
1019 || print_dep
1020 || CPP_OPTION (pfile, deps.need_preprocessor_output))
1021 cpp_errno (pfile, CPP_DL_FATAL, file->path);
1022 else
1023 cpp_errno (pfile, CPP_DL_WARNING, file->path);
1027 /* Search in the chain beginning at HEAD for a file whose search path
1028 started at START_DIR != NULL. */
1029 static struct file_hash_entry *
1030 search_cache (struct file_hash_entry *head, const cpp_dir *start_dir)
1032 while (head && head->start_dir != start_dir)
1033 head = head->next;
1035 return head;
1038 /* Allocate a new _cpp_file structure. */
1039 static _cpp_file *
1040 make_cpp_file (cpp_reader *pfile, cpp_dir *dir, const char *fname)
1042 _cpp_file *file;
1044 file = XCNEW (_cpp_file);
1045 file->main_file = !pfile->buffer;
1046 file->fd = -1;
1047 file->dir = dir;
1048 file->name = xstrdup (fname);
1050 return file;
1053 /* Release a _cpp_file structure. */
1054 static void
1055 destroy_cpp_file (_cpp_file *file)
1057 free ((void *) file->buffer_start);
1058 free ((void *) file->name);
1059 free (file);
1062 /* Release all the files allocated by this reader. */
1063 static void
1064 destroy_all_cpp_files (cpp_reader *pfile)
1066 _cpp_file *iter = pfile->all_files;
1067 while (iter)
1069 _cpp_file *next = iter->next_file;
1070 destroy_cpp_file (iter);
1071 iter = next;
1075 /* A hash of directory names. The directory names are the path names
1076 of files which contain a #include "", the included file name is
1077 appended to this directories.
1079 To avoid duplicate entries we follow the convention that all
1080 non-empty directory names should end in a '/'. DIR_NAME must be
1081 stored in permanently allocated memory. */
1082 static cpp_dir *
1083 make_cpp_dir (cpp_reader *pfile, const char *dir_name, int sysp)
1085 struct file_hash_entry *entry, **hash_slot;
1086 cpp_dir *dir;
1088 hash_slot = (struct file_hash_entry **)
1089 htab_find_slot_with_hash (pfile->dir_hash, dir_name,
1090 htab_hash_string (dir_name),
1091 INSERT);
1093 /* Have we already hashed this directory? */
1094 for (entry = *hash_slot; entry; entry = entry->next)
1095 if (entry->start_dir == NULL)
1096 return entry->u.dir;
1098 dir = XCNEW (cpp_dir);
1099 dir->next = pfile->quote_include;
1100 dir->name = (char *) dir_name;
1101 dir->len = strlen (dir_name);
1102 dir->sysp = sysp;
1103 dir->construct = 0;
1105 /* Store this new result in the hash table. */
1106 entry = new_file_hash_entry (pfile);
1107 entry->next = *hash_slot;
1108 entry->start_dir = NULL;
1109 entry->location = pfile->line_table->highest_location;
1110 entry->u.dir = dir;
1111 *hash_slot = entry;
1113 return dir;
1116 /* Create a new block of memory for file hash entries. */
1117 static void
1118 allocate_file_hash_entries (cpp_reader *pfile)
1120 struct file_hash_entry_pool *pool = XNEW (struct file_hash_entry_pool);
1121 pool->file_hash_entries_used = 0;
1122 pool->next = pfile->file_hash_entries;
1123 pfile->file_hash_entries = pool;
1126 /* Return a new file hash entry. */
1127 static struct file_hash_entry *
1128 new_file_hash_entry (cpp_reader *pfile)
1130 unsigned int idx;
1131 if (pfile->file_hash_entries->file_hash_entries_used == FILE_HASH_POOL_SIZE)
1132 allocate_file_hash_entries (pfile);
1134 idx = pfile->file_hash_entries->file_hash_entries_used++;
1135 return &pfile->file_hash_entries->pool[idx];
1138 /* Free the file hash entry pools. */
1139 static void
1140 free_file_hash_entries (cpp_reader *pfile)
1142 struct file_hash_entry_pool *iter = pfile->file_hash_entries;
1143 while (iter)
1145 struct file_hash_entry_pool *next = iter->next;
1146 free (iter);
1147 iter = next;
1151 /* Returns TRUE if a file FNAME has ever been successfully opened.
1152 This routine is not intended to correctly handle filenames aliased
1153 by links or redundant . or .. traversals etc. */
1154 bool
1155 cpp_included (cpp_reader *pfile, const char *fname)
1157 struct file_hash_entry *entry;
1159 entry = (struct file_hash_entry *)
1160 htab_find_with_hash (pfile->file_hash, fname, htab_hash_string (fname));
1162 while (entry && (entry->start_dir == NULL || entry->u.file->err_no))
1163 entry = entry->next;
1165 return entry != NULL;
1168 /* Returns TRUE if a file FNAME has ever been successfully opened
1169 before LOCATION. This routine is not intended to correctly handle
1170 filenames aliased by links or redundant . or .. traversals etc. */
1171 bool
1172 cpp_included_before (cpp_reader *pfile, const char *fname,
1173 source_location location)
1175 struct file_hash_entry *entry;
1177 entry = (struct file_hash_entry *)
1178 htab_find_with_hash (pfile->file_hash, fname, htab_hash_string (fname));
1180 while (entry && (entry->start_dir == NULL || entry->u.file->err_no
1181 || entry->location > location))
1182 entry = entry->next;
1184 return entry != NULL;
1187 /* Calculate the hash value of a file hash entry P. */
1189 static hashval_t
1190 file_hash_hash (const void *p)
1192 struct file_hash_entry *entry = (struct file_hash_entry *) p;
1193 const char *hname;
1194 if (entry->start_dir)
1195 hname = entry->u.file->name;
1196 else
1197 hname = entry->u.dir->name;
1199 return htab_hash_string (hname);
1202 /* Compare a string Q against a file hash entry P. */
1203 static int
1204 file_hash_eq (const void *p, const void *q)
1206 struct file_hash_entry *entry = (struct file_hash_entry *) p;
1207 const char *fname = (const char *) q;
1208 const char *hname;
1210 if (entry->start_dir)
1211 hname = entry->u.file->name;
1212 else
1213 hname = entry->u.dir->name;
1215 return filename_cmp (hname, fname) == 0;
1218 /* Compare entries in the nonexistent file hash table. These are just
1219 strings. */
1220 static int
1221 nonexistent_file_hash_eq (const void *p, const void *q)
1223 return filename_cmp ((const char *) p, (const char *) q) == 0;
1226 /* Initialize everything in this source file. */
1227 void
1228 _cpp_init_files (cpp_reader *pfile)
1230 pfile->file_hash = htab_create_alloc (127, file_hash_hash, file_hash_eq,
1231 NULL, xcalloc, free);
1232 pfile->dir_hash = htab_create_alloc (127, file_hash_hash, file_hash_eq,
1233 NULL, xcalloc, free);
1234 allocate_file_hash_entries (pfile);
1235 pfile->nonexistent_file_hash = htab_create_alloc (127, htab_hash_string,
1236 nonexistent_file_hash_eq,
1237 NULL, xcalloc, free);
1238 _obstack_begin (&pfile->nonexistent_file_ob, 0, 0,
1239 (void *(*) (long)) xmalloc,
1240 (void (*) (void *)) free);
1243 /* Finalize everything in this source file. */
1244 void
1245 _cpp_cleanup_files (cpp_reader *pfile)
1247 htab_delete (pfile->file_hash);
1248 htab_delete (pfile->dir_hash);
1249 htab_delete (pfile->nonexistent_file_hash);
1250 obstack_free (&pfile->nonexistent_file_ob, 0);
1251 free_file_hash_entries (pfile);
1252 destroy_all_cpp_files (pfile);
1255 /* Make the parser forget about files it has seen. This can be useful
1256 for resetting the parser to start another run. */
1257 void
1258 cpp_clear_file_cache (cpp_reader *pfile)
1260 _cpp_cleanup_files (pfile);
1261 pfile->file_hash_entries = NULL;
1262 pfile->all_files = NULL;
1263 _cpp_init_files (pfile);
1266 /* Enter a file name in the hash for the sake of cpp_included. */
1267 void
1268 _cpp_fake_include (cpp_reader *pfile, const char *fname)
1270 _cpp_find_file (pfile, fname, pfile->buffer->file->dir, true, 0, false);
1273 /* Not everyone who wants to set system-header-ness on a buffer can
1274 see the details of a buffer. This is an exported interface because
1275 fix-header needs it. */
1276 void
1277 cpp_make_system_header (cpp_reader *pfile, int syshdr, int externc)
1279 int flags = 0;
1280 const struct line_maps *line_table = pfile->line_table;
1281 const struct line_map *map = LINEMAPS_LAST_ORDINARY_MAP (line_table);
1282 /* 1 = system header, 2 = system header to be treated as C. */
1283 if (syshdr)
1284 flags = 1 + (externc != 0);
1285 pfile->buffer->sysp = flags;
1286 _cpp_do_file_change (pfile, LC_RENAME, ORDINARY_MAP_FILE_NAME (map),
1287 SOURCE_LINE (map, pfile->line_table->highest_line), flags);
1290 /* Allow the client to change the current file. Used by the front end
1291 to achieve pseudo-file names like <built-in>.
1292 If REASON is LC_LEAVE, then NEW_NAME must be NULL. */
1293 void
1294 cpp_change_file (cpp_reader *pfile, enum lc_reason reason,
1295 const char *new_name)
1297 _cpp_do_file_change (pfile, reason, new_name, 1, 0);
1300 struct report_missing_guard_data
1302 const char **paths;
1303 size_t count;
1306 /* Callback function for htab_traverse. */
1307 static int
1308 report_missing_guard (void **slot, void *d)
1310 struct file_hash_entry *entry = (struct file_hash_entry *) *slot;
1311 struct report_missing_guard_data *data
1312 = (struct report_missing_guard_data *) d;
1314 /* Skip directories. */
1315 if (entry->start_dir != NULL)
1317 _cpp_file *file = entry->u.file;
1319 /* We don't want MI guard advice for the main file. */
1320 if (!file->once_only && file->cmacro == NULL
1321 && file->stack_count == 1 && !file->main_file)
1323 if (data->paths == NULL)
1325 data->paths = XCNEWVEC (const char *, data->count);
1326 data->count = 0;
1329 data->paths[data->count++] = file->path;
1333 /* Keep traversing the hash table. */
1334 return 1;
1337 /* Comparison function for qsort. */
1338 static int
1339 report_missing_guard_cmp (const void *p1, const void *p2)
1341 return strcmp (*(const char *const *) p1, *(const char *const *) p2);
1344 /* Report on all files that might benefit from a multiple include guard.
1345 Triggered by -H. */
1346 void
1347 _cpp_report_missing_guards (cpp_reader *pfile)
1349 struct report_missing_guard_data data;
1351 data.paths = NULL;
1352 data.count = htab_elements (pfile->file_hash);
1353 htab_traverse (pfile->file_hash, report_missing_guard, &data);
1355 if (data.paths != NULL)
1357 size_t i;
1359 /* Sort the paths to avoid outputting them in hash table
1360 order. */
1361 qsort (data.paths, data.count, sizeof (const char *),
1362 report_missing_guard_cmp);
1363 fputs (_("Multiple include guards may be useful for:\n"),
1364 stderr);
1365 for (i = 0; i < data.count; i++)
1367 fputs (data.paths[i], stderr);
1368 putc ('\n', stderr);
1370 free (data.paths);
1374 /* Locate HEADER, and determine whether it is newer than the current
1375 file. If it cannot be located or dated, return -1, if it is
1376 newer, return 1, otherwise 0. */
1378 _cpp_compare_file_date (cpp_reader *pfile, const char *fname,
1379 int angle_brackets)
1381 _cpp_file *file;
1382 struct cpp_dir *dir;
1384 dir = search_path_head (pfile, fname, angle_brackets, IT_INCLUDE);
1385 if (!dir)
1386 return -1;
1388 file = _cpp_find_file (pfile, fname, dir, false, angle_brackets, false);
1389 if (file->err_no)
1390 return -1;
1392 if (file->fd != -1)
1394 close (file->fd);
1395 file->fd = -1;
1398 return file->st.st_mtime > pfile->buffer->file->st.st_mtime;
1401 /* Pushes the given file onto the buffer stack. Returns nonzero if
1402 successful. */
1403 bool
1404 cpp_push_include (cpp_reader *pfile, const char *fname)
1406 return _cpp_stack_include (pfile, fname, false, IT_CMDLINE);
1409 /* Pushes the given file, implicitly included at the start of a
1410 compilation, onto the buffer stack but without any errors if the
1411 file is not found. Returns nonzero if successful. */
1412 bool
1413 cpp_push_default_include (cpp_reader *pfile, const char *fname)
1415 return _cpp_stack_include (pfile, fname, true, IT_DEFAULT);
1418 /* Do appropriate cleanup when a file INC's buffer is popped off the
1419 input stack. */
1420 void
1421 _cpp_pop_file_buffer (cpp_reader *pfile, _cpp_file *file)
1423 /* Record the inclusion-preventing macro, which could be NULL
1424 meaning no controlling macro. */
1425 if (pfile->mi_valid && file->cmacro == NULL)
1426 file->cmacro = pfile->mi_cmacro;
1428 /* Invalidate control macros in the #including file. */
1429 pfile->mi_valid = false;
1431 if (file->buffer_start)
1433 free ((void *) file->buffer_start);
1434 file->buffer_start = NULL;
1435 file->buffer = NULL;
1436 file->buffer_valid = false;
1440 /* Return the file name associated with FILE. */
1441 const char *
1442 _cpp_get_file_name (_cpp_file *file)
1444 return file->name;
1447 /* Inteface to file statistics record in _cpp_file structure. */
1448 struct stat *
1449 _cpp_get_file_stat (_cpp_file *file)
1451 return &file->st;
1454 /* Set the include chain for "" to QUOTE, for <> to BRACKET. If
1455 QUOTE_IGNORES_SOURCE_DIR, then "" includes do not look in the
1456 directory of the including file.
1458 If BRACKET does not lie in the QUOTE chain, it is set to QUOTE. */
1459 void
1460 cpp_set_include_chains (cpp_reader *pfile, cpp_dir *quote, cpp_dir *bracket,
1461 int quote_ignores_source_dir)
1463 pfile->quote_include = quote;
1464 pfile->bracket_include = quote;
1465 pfile->quote_ignores_source_dir = quote_ignores_source_dir;
1467 for (; quote; quote = quote->next)
1469 quote->name_map = NULL;
1470 quote->len = strlen (quote->name);
1471 if (quote == bracket)
1472 pfile->bracket_include = bracket;
1476 /* Append the file name to the directory to create the path, but don't
1477 turn / into // or // into ///; // may be a namespace escape. */
1478 static char *
1479 append_file_to_dir (const char *fname, cpp_dir *dir)
1481 size_t dlen, flen;
1482 char *path;
1484 dlen = dir->len;
1485 flen = strlen (fname);
1486 path = XNEWVEC (char, dlen + 1 + flen + 1);
1487 memcpy (path, dir->name, dlen);
1488 if (dlen && !IS_DIR_SEPARATOR (path[dlen - 1]))
1489 path[dlen++] = '/';
1490 memcpy (&path[dlen], fname, flen + 1);
1492 return path;
1495 /* Read a space delimited string of unlimited length from a stdio
1496 file F. */
1497 static char *
1498 read_filename_string (int ch, FILE *f)
1500 char *alloc, *set;
1501 int len;
1503 len = 20;
1504 set = alloc = XNEWVEC (char, len + 1);
1505 if (! is_space (ch))
1507 *set++ = ch;
1508 while ((ch = getc (f)) != EOF && ! is_space (ch))
1510 if (set - alloc == len)
1512 len *= 2;
1513 alloc = XRESIZEVEC (char, alloc, len + 1);
1514 set = alloc + len / 2;
1516 *set++ = ch;
1519 *set = '\0';
1520 ungetc (ch, f);
1521 return alloc;
1524 /* Read the file name map file for DIR. */
1525 static void
1526 read_name_map (cpp_dir *dir)
1528 static const char FILE_NAME_MAP_FILE[] = "header.gcc";
1529 char *name;
1530 FILE *f;
1531 size_t len, count = 0, room = 9;
1533 len = dir->len;
1534 name = (char *) alloca (len + sizeof (FILE_NAME_MAP_FILE) + 1);
1535 memcpy (name, dir->name, len);
1536 if (len && !IS_DIR_SEPARATOR (name[len - 1]))
1537 name[len++] = '/';
1538 strcpy (name + len, FILE_NAME_MAP_FILE);
1539 f = fopen (name, "r");
1541 dir->name_map = XNEWVEC (const char *, room);
1543 /* Silently return NULL if we cannot open. */
1544 if (f)
1546 int ch;
1548 while ((ch = getc (f)) != EOF)
1550 char *to;
1552 if (is_space (ch))
1553 continue;
1555 if (count + 2 > room)
1557 room += 8;
1558 dir->name_map = XRESIZEVEC (const char *, dir->name_map, room);
1561 dir->name_map[count] = read_filename_string (ch, f);
1562 while ((ch = getc (f)) != EOF && is_hspace (ch))
1565 to = read_filename_string (ch, f);
1566 if (IS_ABSOLUTE_PATH (to))
1567 dir->name_map[count + 1] = to;
1568 else
1570 dir->name_map[count + 1] = append_file_to_dir (to, dir);
1571 free (to);
1574 count += 2;
1575 while ((ch = getc (f)) != '\n')
1576 if (ch == EOF)
1577 break;
1580 fclose (f);
1583 /* Terminate the list of maps. */
1584 dir->name_map[count] = NULL;
1587 /* Remap a FILE's name based on the file_name_map, if any, for
1588 FILE->dir. If the file name has any directory separators,
1589 recursively check those directories too. */
1590 static char *
1591 remap_filename (cpp_reader *pfile, _cpp_file *file)
1593 const char *fname, *p;
1594 char *new_dir;
1595 cpp_dir *dir;
1596 size_t index, len;
1598 dir = file->dir;
1599 fname = file->name;
1601 for (;;)
1603 if (!dir->name_map)
1604 read_name_map (dir);
1606 for (index = 0; dir->name_map[index]; index += 2)
1607 if (!filename_cmp (dir->name_map[index], fname))
1608 return xstrdup (dir->name_map[index + 1]);
1609 if (IS_ABSOLUTE_PATH (fname))
1610 return NULL;
1611 p = strchr (fname, '/');
1612 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
1614 char *p2 = strchr (fname, '\\');
1615 if (!p || (p > p2))
1616 p = p2;
1618 #endif
1619 if (!p || p == fname)
1620 return NULL;
1622 len = dir->len + (p - fname + 1);
1623 new_dir = XNEWVEC (char, len + 1);
1624 memcpy (new_dir, dir->name, dir->len);
1625 memcpy (new_dir + dir->len, fname, p - fname + 1);
1626 new_dir[len] = '\0';
1628 dir = make_cpp_dir (pfile, new_dir, dir->sysp);
1629 fname = p + 1;
1633 /* Returns true if PCHNAME is a valid PCH file for FILE. */
1634 static bool
1635 validate_pch (cpp_reader *pfile, _cpp_file *file, const char *pchname)
1637 const char *saved_path = file->path;
1638 bool valid = false;
1640 file->path = pchname;
1641 if (open_file (file))
1643 valid = 1 & pfile->cb.valid_pch (pfile, pchname, file->fd);
1645 if (!valid)
1647 close (file->fd);
1648 file->fd = -1;
1651 if (CPP_OPTION (pfile, print_include_names))
1653 unsigned int i;
1654 for (i = 1; i < pfile->line_table->depth; i++)
1655 putc ('.', stderr);
1656 fprintf (stderr, "%c %s\n",
1657 valid ? '!' : 'x', pchname);
1661 file->path = saved_path;
1662 return valid;
1665 /* Get the path associated with the _cpp_file F. The path includes
1666 the base name from the include directive and the directory it was
1667 found in via the search path. */
1669 const char *
1670 cpp_get_path (struct _cpp_file *f)
1672 return f->path;
1675 /* Get the directory associated with the _cpp_file F. */
1677 cpp_dir *
1678 cpp_get_dir (struct _cpp_file *f)
1680 return f->dir;
1683 /* Get the cpp_buffer currently associated with the cpp_reader
1684 PFILE. */
1686 cpp_buffer *
1687 cpp_get_buffer (cpp_reader *pfile)
1689 return pfile->buffer;
1692 /* Get the _cpp_file associated with the cpp_buffer B. */
1694 _cpp_file *
1695 cpp_get_file (cpp_buffer *b)
1697 return b->file;
1700 /* Get the previous cpp_buffer given a cpp_buffer B. The previous
1701 buffer is the buffer that included the given buffer. */
1703 cpp_buffer *
1704 cpp_get_prev (cpp_buffer *b)
1706 return b->prev;
1709 /* This data structure holds the list of header files that were seen
1710 while the PCH was being built. The 'entries' field is kept sorted
1711 in memcmp() order; yes, this means that on little-endian systems,
1712 it's sorted initially by the least-significant byte of 'size', but
1713 that's OK. The code does rely on having entries with the same size
1714 next to each other. */
1716 struct pchf_entry {
1717 /* The size of this file. This is used to save running a MD5 checksum
1718 if the sizes don't match. */
1719 off_t size;
1720 /* The MD5 checksum of this file. */
1721 unsigned char sum[16];
1722 /* Is this file to be included only once? */
1723 bool once_only;
1726 struct pchf_data {
1727 /* Number of pchf_entry structures. */
1728 size_t count;
1730 /* Are there any values with once_only set?
1731 This is used as an optimisation, it means we don't have to search
1732 the structure if we're processing a regular #include. */
1733 bool have_once_only;
1735 struct pchf_entry entries[1];
1738 static struct pchf_data *pchf;
1740 /* A qsort ordering function for pchf_entry structures. */
1742 static int
1743 pchf_save_compare (const void *e1, const void *e2)
1745 return memcmp (e1, e2, sizeof (struct pchf_entry));
1748 /* Create and write to F a pchf_data structure. */
1750 bool
1751 _cpp_save_file_entries (cpp_reader *pfile, FILE *fp)
1753 size_t count = 0;
1754 struct pchf_data *result;
1755 size_t result_size;
1756 _cpp_file *f;
1758 for (f = pfile->all_files; f; f = f->next_file)
1759 ++count;
1761 result_size = (sizeof (struct pchf_data)
1762 + sizeof (struct pchf_entry) * (count - 1));
1763 result = XCNEWVAR (struct pchf_data, result_size);
1765 result->count = 0;
1766 result->have_once_only = false;
1768 for (f = pfile->all_files; f; f = f->next_file)
1770 size_t count;
1772 /* This should probably never happen, since if a read error occurred
1773 the PCH file shouldn't be written... */
1774 if (f->dont_read || f->err_no)
1775 continue;
1777 if (f->stack_count == 0)
1778 continue;
1780 count = result->count++;
1782 result->entries[count].once_only = f->once_only;
1783 /* |= is avoided in the next line because of an HP C compiler bug */
1784 result->have_once_only = result->have_once_only | f->once_only;
1785 if (f->buffer_valid)
1786 md5_buffer ((const char *)f->buffer,
1787 f->st.st_size, result->entries[count].sum);
1788 else
1790 FILE *ff;
1791 int oldfd = f->fd;
1793 if (!open_file (f))
1795 open_file_failed (pfile, f, 0);
1796 free (result);
1797 return false;
1799 ff = fdopen (f->fd, "rb");
1800 md5_stream (ff, result->entries[count].sum);
1801 fclose (ff);
1802 f->fd = oldfd;
1804 result->entries[count].size = f->st.st_size;
1807 result_size = (sizeof (struct pchf_data)
1808 + sizeof (struct pchf_entry) * (result->count - 1));
1810 qsort (result->entries, result->count, sizeof (struct pchf_entry),
1811 pchf_save_compare);
1813 return fwrite (result, result_size, 1, fp) == 1;
1816 /* Read the pchf_data structure from F. */
1818 bool
1819 _cpp_read_file_entries (cpp_reader *pfile ATTRIBUTE_UNUSED, FILE *f)
1821 struct pchf_data d;
1823 if (fread (&d, sizeof (struct pchf_data) - sizeof (struct pchf_entry), 1, f)
1824 != 1)
1825 return false;
1827 pchf = XNEWVAR (struct pchf_data, sizeof (struct pchf_data)
1828 + sizeof (struct pchf_entry) * (d.count - 1));
1829 memcpy (pchf, &d, sizeof (struct pchf_data) - sizeof (struct pchf_entry));
1830 if (fread (pchf->entries, sizeof (struct pchf_entry), d.count, f)
1831 != d.count)
1832 return false;
1833 return true;
1836 /* The parameters for pchf_compare. */
1838 struct pchf_compare_data
1840 /* The size of the file we're looking for. */
1841 off_t size;
1843 /* The MD5 checksum of the file, if it's been computed. */
1844 unsigned char sum[16];
1846 /* Is SUM valid? */
1847 bool sum_computed;
1849 /* Do we need to worry about entries that don't have ONCE_ONLY set? */
1850 bool check_included;
1852 /* The file that we're searching for. */
1853 _cpp_file *f;
1856 /* bsearch comparison function; look for D_P in E_P. */
1858 static int
1859 pchf_compare (const void *d_p, const void *e_p)
1861 const struct pchf_entry *e = (const struct pchf_entry *)e_p;
1862 struct pchf_compare_data *d = (struct pchf_compare_data *)d_p;
1863 int result;
1865 result = memcmp (&d->size, &e->size, sizeof (off_t));
1866 if (result != 0)
1867 return result;
1869 if (! d->sum_computed)
1871 _cpp_file *const f = d->f;
1873 md5_buffer ((const char *)f->buffer, f->st.st_size, d->sum);
1874 d->sum_computed = true;
1877 result = memcmp (d->sum, e->sum, 16);
1878 if (result != 0)
1879 return result;
1881 if (d->check_included || e->once_only)
1882 return 0;
1883 else
1884 return 1;
1887 /* Check that F is not in a list read from a PCH file (if any).
1888 Assumes that f->buffer_valid is true. Return TRUE if the file
1889 should not be read. */
1891 static bool
1892 check_file_against_entries (cpp_reader *pfile ATTRIBUTE_UNUSED,
1893 _cpp_file *f,
1894 bool check_included)
1896 struct pchf_compare_data d;
1898 if (pchf == NULL
1899 || (! check_included && ! pchf->have_once_only))
1900 return false;
1902 d.size = f->st.st_size;
1903 d.sum_computed = false;
1904 d.f = f;
1905 d.check_included = check_included;
1906 return bsearch (&d, pchf->entries, pchf->count, sizeof (struct pchf_entry),
1907 pchf_compare) != NULL;