xref: /openbsd/gnu/gcc/libcpp/files.c (revision 5af055cd)
1 /* Part of CPP library.  File handling.
2    Copyright (C) 1986, 1987, 1989, 1992, 1993, 1994, 1995, 1998,
3    1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
4    Written by Per Bothner, 1994.
5    Based on CCCP program by Paul Rubin, June 1986
6    Adapted to ANSI C, Richard Stallman, Jan 1987
7    Split out of cpplib.c, Zack Weinberg, Oct 1998
8    Reimplemented, Neil Booth, Jul 2003
9 
10 This program is free software; you can redistribute it and/or modify it
11 under the terms of the GNU General Public License as published by the
12 Free Software Foundation; either version 2, or (at your option) any
13 later version.
14 
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 GNU General Public License for more details.
19 
20 You should have received a copy of the GNU General Public License
21 along with this program; if not, write to the Free Software
22 Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
23 
24 #include "config.h"
25 #include "system.h"
26 #include "cpplib.h"
27 #include "internal.h"
28 #include "mkdeps.h"
29 #include "hashtab.h"
30 #include "md5.h"
31 #include <dirent.h>
32 
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
41 
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
50 
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
55 {
56   /* Filename as given to #include or command line switch.  */
57   const char *name;
58 
59   /* The full path used to find the file.  */
60   const char *path;
61 
62   /* The full path of the pch file.  */
63   const char *pchname;
64 
65   /* The file's path with the basename stripped.  NULL if it hasn't
66      been calculated yet.  */
67   const char *dir_name;
68 
69   /* Chain through all files.  */
70   struct _cpp_file *next_file;
71 
72   /* The contents of NAME after calling read_file().  */
73   const uchar *buffer;
74 
75   /* The macro, if any, preventing re-inclusion.  */
76   const cpp_hashnode *cmacro;
77 
78   /* The directory in the search path where FILE was found.  Used for
79      #include_next and determining whether a header is a system
80      header.  */
81   cpp_dir *dir;
82 
83   /* As filled in by stat(2) for the file.  */
84   struct stat st;
85 
86   /* File descriptor.  Invalid if -1, otherwise open.  */
87   int fd;
88 
89   /* Zero if this file was successfully opened and stat()-ed,
90      otherwise errno obtained from failure.  */
91   int err_no;
92 
93   /* Number of times the file has been stacked for preprocessing.  */
94   unsigned short stack_count;
95 
96   /* If opened with #import or contains #pragma once.  */
97   bool once_only;
98 
99   /* If read() failed before.  */
100   bool dont_read;
101 
102   /* If this file is the main file.  */
103   bool main_file;
104 
105   /* If BUFFER above contains the true contents of the file.  */
106   bool buffer_valid;
107 
108   /* File is a PCH (on return from find_include_file).  */
109   bool pch;
110 };
111 
112 /* A singly-linked list for all searches for a given file name, with
113    its head pointed to by a slot in FILE_HASH.  The file name is what
114    appeared between the quotes in a #include directive; it can be
115    determined implicitly from the hash table location or explicitly
116    from FILE->name.
117 
118    FILE is a structure containing details about the file that was
119    found with that search, or details of how the search failed.
120 
121    START_DIR is the starting location of the search in the include
122    chain.  The current directories for "" includes are also hashed in
123    the hash table and therefore unique.  Files that are looked up
124    without using a search path, such as absolute filenames and file
125    names from the command line share a special starting directory so
126    they don't cause cache hits with normal include-chain lookups.
127 
128    If START_DIR is NULL then the entry is for a directory, not a file,
129    and the directory is in DIR.  Since the starting point in a file
130    lookup chain is never NULL, this means that simple pointer
131    comparisons against START_DIR can be made to determine cache hits
132    in file lookups.
133 
134    If a cache lookup fails because of e.g. an extra "./" in the path,
135    then nothing will break.  It is just less efficient as CPP will
136    have to do more work re-preprocessing the file, and/or comparing
137    its contents against earlier once-only files.
138 */
139 struct file_hash_entry
140 {
141   struct file_hash_entry *next;
142   cpp_dir *start_dir;
143   union
144   {
145     _cpp_file *file;
146     cpp_dir *dir;
147   } u;
148 };
149 
150 static bool open_file (_cpp_file *file);
151 static bool pch_open_file (cpp_reader *pfile, _cpp_file *file,
152 			   bool *invalid_pch);
153 static bool find_file_in_dir (cpp_reader *pfile, _cpp_file *file,
154 			      bool *invalid_pch);
155 static bool read_file_guts (cpp_reader *pfile, _cpp_file *file);
156 static bool read_file (cpp_reader *pfile, _cpp_file *file);
157 static bool should_stack_file (cpp_reader *, _cpp_file *file, bool import);
158 static struct cpp_dir *search_path_head (cpp_reader *, const char *fname,
159 				 int angle_brackets, enum include_type);
160 static const char *dir_name_of_file (_cpp_file *file);
161 static void open_file_failed (cpp_reader *pfile, _cpp_file *file, int);
162 static struct file_hash_entry *search_cache (struct file_hash_entry *head,
163 					     const cpp_dir *start_dir);
164 static _cpp_file *make_cpp_file (cpp_reader *, cpp_dir *, const char *fname);
165 static void destroy_cpp_file (_cpp_file *);
166 static cpp_dir *make_cpp_dir (cpp_reader *, const char *dir_name, int sysp);
167 static void allocate_file_hash_entries (cpp_reader *pfile);
168 static struct file_hash_entry *new_file_hash_entry (cpp_reader *pfile);
169 static int report_missing_guard (void **slot, void *b);
170 static hashval_t file_hash_hash (const void *p);
171 static int file_hash_eq (const void *p, const void *q);
172 static char *read_filename_string (int ch, FILE *f);
173 static void read_name_map (cpp_dir *dir);
174 static char *remap_filename (cpp_reader *pfile, _cpp_file *file);
175 static char *append_file_to_dir (const char *fname, cpp_dir *dir);
176 static bool validate_pch (cpp_reader *, _cpp_file *file, const char *pchname);
177 static int pchf_save_compare (const void *e1, const void *e2);
178 static int pchf_compare (const void *d_p, const void *e_p);
179 static bool check_file_against_entries (cpp_reader *, _cpp_file *, bool);
180 
181 /* Given a filename in FILE->PATH, with the empty string interpreted
182    as <stdin>, open it.
183 
184    On success FILE contains an open file descriptor and stat
185    information for the file.  On failure the file descriptor is -1 and
186    the appropriate errno is also stored in FILE.  Returns TRUE iff
187    successful.
188 
189    We used to open files in nonblocking mode, but that caused more
190    problems than it solved.  Do take care not to acquire a controlling
191    terminal by mistake (this can't happen on sane systems, but
192    paranoia is a virtue).
193 
194    Use the three-argument form of open even though we aren't
195    specifying O_CREAT, to defend against broken system headers.
196 
197    O_BINARY tells some runtime libraries (notably DJGPP) not to do
198    newline translation; we can handle DOS line breaks just fine
199    ourselves.  */
200 static bool
201 open_file (_cpp_file *file)
202 {
203   if (file->path[0] == '\0')
204     {
205       file->fd = 0;
206       set_stdin_to_binary_mode ();
207     }
208   else
209     file->fd = open (file->path, O_RDONLY | O_NOCTTY | O_BINARY, 0666);
210 
211   if (file->fd != -1)
212     {
213       if (fstat (file->fd, &file->st) == 0)
214 	{
215 	  if (!S_ISDIR (file->st.st_mode))
216 	    {
217 	      file->err_no = 0;
218 	      return true;
219 	    }
220 
221 	  /* Ignore a directory and continue the search.  The file we're
222 	     looking for may be elsewhere in the search path.  */
223 	  errno = ENOENT;
224 	}
225 
226       close (file->fd);
227       file->fd = -1;
228     }
229   else if (errno == ENOTDIR)
230     errno = ENOENT;
231 
232   file->err_no = errno;
233 
234   return false;
235 }
236 
237 /* Temporary PCH intercept of opening a file.  Try to find a PCH file
238    based on FILE->name and FILE->dir, and test those found for
239    validity using PFILE->cb.valid_pch.  Return true iff a valid file is
240    found.  Set *INVALID_PCH if a PCH file is found but wasn't valid.  */
241 
242 static bool
243 pch_open_file (cpp_reader *pfile, _cpp_file *file, bool *invalid_pch)
244 {
245   static const char extension[] = ".gch";
246   const char *path = file->path;
247   size_t len, flen;
248   char *pchname;
249   struct stat st;
250   bool valid = false;
251 
252   /* No PCH on <stdin> or if not requested.  */
253   if (file->name[0] == '\0' || !pfile->cb.valid_pch)
254     return false;
255 
256   flen = strlen (path);
257   len = flen + sizeof (extension);
258   pchname = XNEWVEC (char, len);
259   memcpy (pchname, path, flen);
260   memcpy (pchname + flen, extension, sizeof (extension));
261 
262   if (stat (pchname, &st) == 0)
263     {
264       DIR *pchdir;
265       struct dirent *d;
266       size_t dlen, plen = len;
267 
268       if (!S_ISDIR (st.st_mode))
269 	valid = validate_pch (pfile, file, pchname);
270       else if ((pchdir = opendir (pchname)) != NULL)
271 	{
272 	  pchname[plen - 1] = '/';
273 	  while ((d = readdir (pchdir)) != NULL)
274 	    {
275 	      dlen = strlen (d->d_name) + 1;
276 	      if ((strcmp (d->d_name, ".") == 0)
277 		  || (strcmp (d->d_name, "..") == 0))
278 		continue;
279 	      if (dlen + plen > len)
280 		{
281 		  len += dlen + 64;
282 		  pchname = XRESIZEVEC (char, pchname, len);
283 		}
284 	      memcpy (pchname + plen, d->d_name, dlen);
285 	      valid = validate_pch (pfile, file, pchname);
286 	      if (valid)
287 		break;
288 	    }
289 	  closedir (pchdir);
290 	}
291       if (valid)
292 	file->pch = true;
293       else
294 	*invalid_pch = true;
295     }
296 
297   if (valid)
298     file->pchname = pchname;
299   else
300     free (pchname);
301 
302   return valid;
303 }
304 
305 /* Try to open the path FILE->name appended to FILE->dir.  This is
306    where remap and PCH intercept the file lookup process.  Return true
307    if the file was found, whether or not the open was successful.
308    Set *INVALID_PCH to true if a PCH file is found but wasn't valid.  */
309 
310 static bool
311 find_file_in_dir (cpp_reader *pfile, _cpp_file *file, bool *invalid_pch)
312 {
313   char *path;
314 
315   if (CPP_OPTION (pfile, remap) && (path = remap_filename (pfile, file)))
316     ;
317   else
318     if (file->dir->construct)
319       path = file->dir->construct (file->name, file->dir);
320     else
321       path = append_file_to_dir (file->name, file->dir);
322 
323   if (path)
324     {
325       file->path = path;
326       if (pch_open_file (pfile, file, invalid_pch))
327 	return true;
328 
329       if (open_file (file))
330 	return true;
331 
332       if (file->err_no != ENOENT)
333 	{
334 	  open_file_failed (pfile, file, 0);
335 	  return true;
336 	}
337 
338       free (path);
339       file->path = file->name;
340     }
341   else
342     {
343       file->err_no = ENOENT;
344       file->path = NULL;
345     }
346 
347   return false;
348 }
349 
350 /* Return tue iff the missing_header callback found the given HEADER.  */
351 static bool
352 search_path_exhausted (cpp_reader *pfile, const char *header, _cpp_file *file)
353 {
354   missing_header_cb func = pfile->cb.missing_header;
355 
356   /* When the regular search path doesn't work, try context dependent
357      headers search paths.  */
358   if (func
359       && file->dir == NULL)
360     {
361       if ((file->path = func (pfile, header, &file->dir)) != NULL)
362 	{
363 	  if (open_file (file))
364 	    return true;
365 	  free ((void *)file->path);
366 	}
367       file->path = file->name;
368     }
369 
370   return false;
371 }
372 
373 bool
374 _cpp_find_failed (_cpp_file *file)
375 {
376   return file->err_no != 0;
377 }
378 
379 /* Given a filename FNAME search for such a file in the include path
380    starting from START_DIR.  If FNAME is the empty string it is
381    interpreted as STDIN if START_DIR is PFILE->no_search_path.
382 
383    If the file is not found in the file cache fall back to the O/S and
384    add the result to our cache.
385 
386    If the file was not found in the filesystem, or there was an error
387    opening it, then ERR_NO is nonzero and FD is -1.  If the file was
388    found, then ERR_NO is zero and FD could be -1 or an open file
389    descriptor.  FD can be -1 if the file was found in the cache and
390    had previously been closed.  To open it again pass the return value
391    to open_file().
392 */
393 _cpp_file *
394 _cpp_find_file (cpp_reader *pfile, const char *fname, cpp_dir *start_dir, bool fake, int angle_brackets)
395 {
396   struct file_hash_entry *entry, **hash_slot;
397   _cpp_file *file;
398   bool invalid_pch = false;
399 
400   /* Ensure we get no confusion between cached files and directories.  */
401   if (start_dir == NULL)
402     cpp_error (pfile, CPP_DL_ICE, "NULL directory in find_file");
403 
404   hash_slot = (struct file_hash_entry **)
405     htab_find_slot_with_hash (pfile->file_hash, fname,
406 			      htab_hash_string (fname),
407 			      INSERT);
408 
409   /* First check the cache before we resort to memory allocation.  */
410   entry = search_cache (*hash_slot, start_dir);
411   if (entry)
412     return entry->u.file;
413 
414   file = make_cpp_file (pfile, start_dir, fname);
415 
416   /* Try each path in the include chain.  */
417   for (; !fake ;)
418     {
419       if (find_file_in_dir (pfile, file, &invalid_pch))
420 	break;
421 
422       file->dir = file->dir->next;
423       if (file->dir == NULL)
424 	{
425 	  if (search_path_exhausted (pfile, fname, file))
426 	    {
427 	      /* Although this file must not go in the cache, because
428 		 the file found might depend on things (like the current file)
429 		 that aren't represented in the cache, it still has to go in
430 		 the list of all files so that #import works.  */
431 	      file->next_file = pfile->all_files;
432 	      pfile->all_files = file;
433 	      return file;
434 	    }
435 
436 	  open_file_failed (pfile, file, angle_brackets);
437 	  if (invalid_pch)
438 	    {
439 	      cpp_error (pfile, CPP_DL_ERROR,
440 	       "one or more PCH files were found, but they were invalid");
441 	      if (!cpp_get_options (pfile)->warn_invalid_pch)
442 		cpp_error (pfile, CPP_DL_ERROR,
443 			   "use -Winvalid-pch for more information");
444 	    }
445 	  break;
446 	}
447 
448       /* Only check the cache for the starting location (done above)
449 	 and the quote and bracket chain heads because there are no
450 	 other possible starting points for searches.  */
451       if (file->dir != pfile->bracket_include
452 	  && file->dir != pfile->quote_include)
453 	continue;
454 
455       entry = search_cache (*hash_slot, file->dir);
456       if (entry)
457 	break;
458     }
459 
460   if (entry)
461     {
462       /* Cache for START_DIR too, sharing the _cpp_file structure.  */
463       free ((char *) file->name);
464       free (file);
465       file = entry->u.file;
466     }
467   else
468     {
469       /* This is a new file; put it in the list.  */
470       file->next_file = pfile->all_files;
471       pfile->all_files = file;
472     }
473 
474   /* Store this new result in the hash table.  */
475   entry = new_file_hash_entry (pfile);
476   entry->next = *hash_slot;
477   entry->start_dir = start_dir;
478   entry->u.file = file;
479   *hash_slot = entry;
480 
481   return file;
482 }
483 
484 /* Read a file into FILE->buffer, returning true on success.
485 
486    If FILE->fd is something weird, like a block device, we don't want
487    to read it at all.  Don't even try to figure out what something is,
488    except for plain files and block devices, since there is no
489    reliable portable way of doing this.
490 
491    FIXME: Flush file cache and try again if we run out of memory.  */
492 static bool
493 read_file_guts (cpp_reader *pfile, _cpp_file *file)
494 {
495   ssize_t size, total, count;
496   uchar *buf;
497   bool regular;
498 
499   if (S_ISBLK (file->st.st_mode))
500     {
501       cpp_error (pfile, CPP_DL_ERROR, "%s is a block device", file->path);
502       return false;
503     }
504 
505   regular = S_ISREG (file->st.st_mode);
506   if (regular)
507     {
508       /* off_t might have a wider range than ssize_t - in other words,
509 	 the max size of a file might be bigger than the address
510 	 space.  We can't handle a file that large.  (Anyone with
511 	 a single source file bigger than 2GB needs to rethink
512 	 their coding style.)  Some systems (e.g. AIX 4.1) define
513 	 SSIZE_MAX to be much smaller than the actual range of the
514 	 type.  Use INTTYPE_MAXIMUM unconditionally to ensure this
515 	 does not bite us.  */
516       if (file->st.st_size > INTTYPE_MAXIMUM (ssize_t))
517 	{
518 	  cpp_error (pfile, CPP_DL_ERROR, "%s is too large", file->path);
519 	  return false;
520 	}
521 
522       size = file->st.st_size;
523     }
524   else
525     /* 8 kilobytes is a sensible starting size.  It ought to be bigger
526        than the kernel pipe buffer, and it's definitely bigger than
527        the majority of C source files.  */
528     size = 8 * 1024;
529 
530   buf = XNEWVEC (uchar, size + 1);
531   total = 0;
532   while ((count = read (file->fd, buf + total, size - total)) > 0)
533     {
534       total += count;
535 
536       if (total == size)
537 	{
538 	  if (regular)
539 	    break;
540 	  size *= 2;
541 	  buf = XRESIZEVEC (uchar, buf, size + 1);
542 	}
543     }
544 
545   if (count < 0)
546     {
547       cpp_errno (pfile, CPP_DL_ERROR, file->path);
548       return false;
549     }
550 
551   if (regular && total != size && STAT_SIZE_RELIABLE (file->st))
552     cpp_error (pfile, CPP_DL_WARNING,
553 	       "%s is shorter than expected", file->path);
554 
555   file->buffer = _cpp_convert_input (pfile, CPP_OPTION (pfile, input_charset),
556 				     buf, size, total, &file->st.st_size);
557   file->buffer_valid = true;
558 
559   return true;
560 }
561 
562 /* Convenience wrapper around read_file_guts that opens the file if
563    necessary and closes the file descriptor after reading.  FILE must
564    have been passed through find_file() at some stage.  */
565 static bool
566 read_file (cpp_reader *pfile, _cpp_file *file)
567 {
568   /* If we already have its contents in memory, succeed immediately.  */
569   if (file->buffer_valid)
570     return true;
571 
572   /* If an earlier read failed for some reason don't try again.  */
573   if (file->dont_read || file->err_no)
574     return false;
575 
576   if (file->fd == -1 && !open_file (file))
577     {
578       open_file_failed (pfile, file, 0);
579       return false;
580     }
581 
582   file->dont_read = !read_file_guts (pfile, file);
583   close (file->fd);
584   file->fd = -1;
585 
586   return !file->dont_read;
587 }
588 
589 /* Returns TRUE if FILE's contents have been successfully placed in
590    FILE->buffer and the file should be stacked, otherwise false.  */
591 static bool
592 should_stack_file (cpp_reader *pfile, _cpp_file *file, bool import)
593 {
594   _cpp_file *f;
595 
596   /* Skip once-only files.  */
597   if (file->once_only)
598     return false;
599 
600   /* We must mark the file once-only if #import now, before header
601      guard checks.  Otherwise, undefining the header guard might
602      cause the file to be re-stacked.  */
603   if (import)
604     {
605       _cpp_mark_file_once_only (pfile, file);
606 
607       /* Don't stack files that have been stacked before.  */
608       if (file->stack_count)
609 	return false;
610     }
611 
612   /* Skip if the file had a header guard and the macro is defined.
613      PCH relies on this appearing before the PCH handler below.  */
614   if (file->cmacro && file->cmacro->type == NT_MACRO)
615     return false;
616 
617   /* Handle PCH files immediately; don't stack them.  */
618   if (file->pch)
619     {
620       pfile->cb.read_pch (pfile, file->pchname, file->fd, file->path);
621       close (file->fd);
622       file->fd = -1;
623       return false;
624     }
625 
626   if (!read_file (pfile, file))
627     return false;
628 
629   /* Check the file against the PCH file.  This is done before
630      checking against files we've already seen, since it may save on
631      I/O.  */
632   if (check_file_against_entries (pfile, file, import))
633     {
634       /* If this isn't a #import, but yet we can't include the file,
635 	 that means that it was #import-ed in the PCH file,
636 	 so we can never include it again.  */
637       if (! import)
638 	_cpp_mark_file_once_only (pfile, file);
639       return false;
640     }
641 
642   /* Now we've read the file's contents, we can stack it if there
643      are no once-only files.  */
644   if (!pfile->seen_once_only)
645     return true;
646 
647   /* We may have read the file under a different name.  Look
648      for likely candidates and compare file contents to be sure.  */
649   for (f = pfile->all_files; f; f = f->next_file)
650     {
651       if (f == file)
652 	continue;
653 
654       if ((import || f->once_only)
655 	  && f->err_no == 0
656 	  && f->st.st_mtime == file->st.st_mtime
657 	  && f->st.st_size == file->st.st_size)
658 	{
659 	  _cpp_file *ref_file;
660 	  bool same_file_p = false;
661 
662 	  if (f->buffer && !f->buffer_valid)
663 	    {
664 	      /* We already have a buffer but it is not valid, because
665 		 the file is still stacked.  Make a new one.  */
666 	      ref_file = make_cpp_file (pfile, f->dir, f->name);
667 	      ref_file->path = f->path;
668 	    }
669 	  else
670 	    /* The file is not stacked anymore.  We can reuse it.  */
671 	    ref_file = f;
672 
673 	  same_file_p = read_file (pfile, ref_file)
674 			/* Size might have changed in read_file().  */
675 			&& ref_file->st.st_size == file->st.st_size
676 			&& !memcmp (ref_file->buffer,
677 				    file->buffer,
678 				    file->st.st_size);
679 
680 	  if (f->buffer && !f->buffer_valid)
681 	    {
682 	      ref_file->path = 0;
683 	      destroy_cpp_file (ref_file);
684 	    }
685 
686 	  if (same_file_p)
687 	    break;
688 	}
689     }
690 
691   return f == NULL;
692 }
693 
694 /* Place the file referenced by FILE into a new buffer on the buffer
695    stack if possible.  IMPORT is true if this stacking attempt is
696    because of a #import directive.  Returns true if a buffer is
697    stacked.  */
698 bool
699 _cpp_stack_file (cpp_reader *pfile, _cpp_file *file, bool import)
700 {
701   cpp_buffer *buffer;
702   int sysp;
703 
704   if (!should_stack_file (pfile, file, import))
705       return false;
706 
707   if (pfile->buffer == NULL || file->dir == NULL)
708     sysp = 0;
709   else
710     sysp = MAX (pfile->buffer->sysp,  file->dir->sysp);
711 
712   /* Add the file to the dependencies on its first inclusion.  */
713   if (CPP_OPTION (pfile, deps.style) > !!sysp && !file->stack_count)
714     {
715       if (!file->main_file || !CPP_OPTION (pfile, deps.ignore_main_file))
716 	deps_add_dep (pfile->deps, file->path);
717     }
718 
719   /* Clear buffer_valid since _cpp_clean_line messes it up.  */
720   file->buffer_valid = false;
721   file->stack_count++;
722 
723   /* Stack the buffer.  */
724   buffer = cpp_push_buffer (pfile, file->buffer, file->st.st_size,
725 			    CPP_OPTION (pfile, preprocessed));
726   buffer->file = file;
727   buffer->sysp = sysp;
728 
729   /* Initialize controlling macro state.  */
730   pfile->mi_valid = true;
731   pfile->mi_cmacro = 0;
732 
733   /* Generate the call back.  */
734   _cpp_do_file_change (pfile, LC_ENTER, file->path, 1, sysp);
735 
736   return true;
737 }
738 
739 /* Mark FILE to be included once only.  */
740 void
741 _cpp_mark_file_once_only (cpp_reader *pfile, _cpp_file *file)
742 {
743   pfile->seen_once_only = true;
744   file->once_only = true;
745 }
746 
747 /* Return the directory from which searching for FNAME should start,
748    considering the directive TYPE and ANGLE_BRACKETS.  If there is
749    nothing left in the path, returns NULL.  */
750 static struct cpp_dir *
751 search_path_head (cpp_reader *pfile, const char *fname, int angle_brackets,
752 		  enum include_type type)
753 {
754   cpp_dir *dir;
755   _cpp_file *file;
756 
757   if (IS_ABSOLUTE_PATH (fname))
758     return &pfile->no_search_path;
759 
760   /* pfile->buffer is NULL when processing an -include command-line flag.  */
761   file = pfile->buffer == NULL ? pfile->main_file : pfile->buffer->file;
762 
763   /* For #include_next, skip in the search path past the dir in which
764      the current file was found, but if it was found via an absolute
765      path use the normal search logic.  */
766   if (type == IT_INCLUDE_NEXT && file->dir)
767     dir = file->dir->next;
768   else if (angle_brackets)
769     dir = pfile->bracket_include;
770   else if (type == IT_CMDLINE)
771     /* -include and -imacros use the #include "" chain with the
772        preprocessor's cwd prepended.  */
773     return make_cpp_dir (pfile, "./", false);
774   else if (pfile->quote_ignores_source_dir)
775     dir = pfile->quote_include;
776   else
777     return make_cpp_dir (pfile, dir_name_of_file (file),
778 			 pfile->buffer ? pfile->buffer->sysp : 0);
779 
780   if (dir == NULL)
781     cpp_error (pfile, CPP_DL_ERROR,
782 	       "no include path in which to search for %s", fname);
783 
784   return dir;
785 }
786 
787 /* Strip the basename from the file's path.  It ends with a slash if
788    of nonzero length.  Note that this procedure also works for
789    <stdin>, which is represented by the empty string.  */
790 static const char *
791 dir_name_of_file (_cpp_file *file)
792 {
793   if (!file->dir_name)
794     {
795       size_t len = lbasename (file->path) - file->path;
796       char *dir_name = XNEWVEC (char, len + 1);
797 
798       memcpy (dir_name, file->path, len);
799       dir_name[len] = '\0';
800       file->dir_name = dir_name;
801     }
802 
803   return file->dir_name;
804 }
805 
806 /* Handles #include-family directives (distinguished by TYPE),
807    including HEADER, and the command line -imacros and -include.
808    Returns true if a buffer was stacked.  */
809 bool
810 _cpp_stack_include (cpp_reader *pfile, const char *fname, int angle_brackets,
811 		    enum include_type type)
812 {
813   struct cpp_dir *dir;
814   _cpp_file *file;
815 
816   dir = search_path_head (pfile, fname, angle_brackets, type);
817   if (!dir)
818     return false;
819 
820   file = _cpp_find_file (pfile, fname, dir, false, angle_brackets);
821 
822   /* Compensate for the increment in linemap_add.  In the case of a
823      normal #include, we're currently at the start of the line
824      *following* the #include.  A separate source_location for this
825      location makes no sense (until we do the LC_LEAVE), and
826      complicates LAST_SOURCE_LINE_LOCATION.  This does not apply if we
827      found a PCH file (in which case linemap_add is not called) or we
828      were included from the command-line.  */
829   if (! file->pch && file->err_no == 0 && type != IT_CMDLINE)
830     pfile->line_table->highest_location--;
831 
832   return _cpp_stack_file (pfile, file, type == IT_IMPORT);
833 }
834 
835 /* Could not open FILE.  The complication is dependency output.  */
836 static void
837 open_file_failed (cpp_reader *pfile, _cpp_file *file, int angle_brackets)
838 {
839   int sysp = pfile->line_table->highest_line > 1 && pfile->buffer ? pfile->buffer->sysp : 0;
840   bool print_dep = CPP_OPTION (pfile, deps.style) > (angle_brackets || !!sysp);
841 
842   errno = file->err_no;
843   if (print_dep && CPP_OPTION (pfile, deps.missing_files) && errno == ENOENT)
844     deps_add_dep (pfile->deps, file->name);
845   else
846     {
847       /* If we are outputting dependencies but not for this file then
848 	 don't error because we can still produce correct output.  */
849       if (CPP_OPTION (pfile, deps.style) && ! print_dep)
850 	cpp_errno (pfile, CPP_DL_WARNING, file->path);
851       else
852 	cpp_errno (pfile, CPP_DL_ERROR, file->path);
853     }
854 }
855 
856 /* Search in the chain beginning at HEAD for a file whose search path
857    started at START_DIR != NULL.  */
858 static struct file_hash_entry *
859 search_cache (struct file_hash_entry *head, const cpp_dir *start_dir)
860 {
861   while (head && head->start_dir != start_dir)
862     head = head->next;
863 
864   return head;
865 }
866 
867 /* Allocate a new _cpp_file structure.  */
868 static _cpp_file *
869 make_cpp_file (cpp_reader *pfile, cpp_dir *dir, const char *fname)
870 {
871   _cpp_file *file;
872 
873   file = XCNEW (_cpp_file);
874   file->main_file = !pfile->buffer;
875   file->fd = -1;
876   file->dir = dir;
877   file->name = xstrdup (fname);
878 
879   return file;
880 }
881 
882 /* Release a _cpp_file structure.  */
883 static void
884 destroy_cpp_file (_cpp_file *file)
885 {
886   if (file->buffer)
887     free ((void *) file->buffer);
888   free ((void *) file->name);
889   free (file);
890 }
891 
892 /* A hash of directory names.  The directory names are the path names
893    of files which contain a #include "", the included file name is
894    appended to this directories.
895 
896    To avoid duplicate entries we follow the convention that all
897    non-empty directory names should end in a '/'.  DIR_NAME must be
898    stored in permanently allocated memory.  */
899 static cpp_dir *
900 make_cpp_dir (cpp_reader *pfile, const char *dir_name, int sysp)
901 {
902   struct file_hash_entry *entry, **hash_slot;
903   cpp_dir *dir;
904 
905   hash_slot = (struct file_hash_entry **)
906     htab_find_slot_with_hash (pfile->dir_hash, dir_name,
907 			      htab_hash_string (dir_name),
908 			      INSERT);
909 
910   /* Have we already hashed this directory?  */
911   for (entry = *hash_slot; entry; entry = entry->next)
912     if (entry->start_dir == NULL)
913       return entry->u.dir;
914 
915   dir = XCNEW (cpp_dir);
916   dir->next = pfile->quote_include;
917   dir->name = (char *) dir_name;
918   dir->len = strlen (dir_name);
919   dir->sysp = sysp;
920   dir->construct = 0;
921 
922   /* Store this new result in the hash table.  */
923   entry = new_file_hash_entry (pfile);
924   entry->next = *hash_slot;
925   entry->start_dir = NULL;
926   entry->u.dir = dir;
927   *hash_slot = entry;
928 
929   return dir;
930 }
931 
932 /* Create a new block of memory for file hash entries.  */
933 static void
934 allocate_file_hash_entries (cpp_reader *pfile)
935 {
936   pfile->file_hash_entries_used = 0;
937   pfile->file_hash_entries_allocated = 127;
938   pfile->file_hash_entries = XNEWVEC (struct file_hash_entry,
939                                       pfile->file_hash_entries_allocated);
940 }
941 
942 /* Return a new file hash entry.  */
943 static struct file_hash_entry *
944 new_file_hash_entry (cpp_reader *pfile)
945 {
946   if (pfile->file_hash_entries_used == pfile->file_hash_entries_allocated)
947     allocate_file_hash_entries (pfile);
948 
949   return &pfile->file_hash_entries[pfile->file_hash_entries_used++];
950 }
951 
952 /* Returns TRUE if a file FNAME has ever been successfully opened.
953    This routine is not intended to correctly handle filenames aliased
954    by links or redundant . or .. traversals etc.  */
955 bool
956 cpp_included (cpp_reader *pfile, const char *fname)
957 {
958   struct file_hash_entry *entry;
959 
960   entry = (struct file_hash_entry *)
961      htab_find_with_hash (pfile->file_hash, fname, htab_hash_string (fname));
962 
963   while (entry && (entry->start_dir == NULL || entry->u.file->err_no))
964     entry = entry->next;
965 
966   return entry != NULL;
967 }
968 
969 /* Calculate the hash value of a file hash entry P.  */
970 
971 static hashval_t
972 file_hash_hash (const void *p)
973 {
974   struct file_hash_entry *entry = (struct file_hash_entry *) p;
975   const char *hname;
976   if (entry->start_dir)
977     hname = entry->u.file->name;
978   else
979     hname = entry->u.dir->name;
980 
981   return htab_hash_string (hname);
982 }
983 
984 /* Compare a string Q against a file hash entry P.  */
985 static int
986 file_hash_eq (const void *p, const void *q)
987 {
988   struct file_hash_entry *entry = (struct file_hash_entry *) p;
989   const char *fname = (const char *) q;
990   const char *hname;
991 
992   if (entry->start_dir)
993     hname = entry->u.file->name;
994   else
995     hname = entry->u.dir->name;
996 
997   return strcmp (hname, fname) == 0;
998 }
999 
1000 /* Initialize everything in this source file.  */
1001 void
1002 _cpp_init_files (cpp_reader *pfile)
1003 {
1004   pfile->file_hash = htab_create_alloc (127, file_hash_hash, file_hash_eq,
1005 					NULL, xcalloc, free);
1006   pfile->dir_hash = htab_create_alloc (127, file_hash_hash, file_hash_eq,
1007 					NULL, xcalloc, free);
1008   allocate_file_hash_entries (pfile);
1009 }
1010 
1011 /* Finalize everything in this source file.  */
1012 void
1013 _cpp_cleanup_files (cpp_reader *pfile)
1014 {
1015   htab_delete (pfile->file_hash);
1016   htab_delete (pfile->dir_hash);
1017 }
1018 
1019 /* Enter a file name in the hash for the sake of cpp_included.  */
1020 void
1021 _cpp_fake_include (cpp_reader *pfile, const char *fname)
1022 {
1023   _cpp_find_file (pfile, fname, pfile->buffer->file->dir, true, 0);
1024 }
1025 
1026 /* Not everyone who wants to set system-header-ness on a buffer can
1027    see the details of a buffer.  This is an exported interface because
1028    fix-header needs it.  */
1029 void
1030 cpp_make_system_header (cpp_reader *pfile, int syshdr, int externc)
1031 {
1032   int flags = 0;
1033   const struct line_maps *line_table = pfile->line_table;
1034   const struct line_map *map = &line_table->maps[line_table->used-1];
1035 
1036   /* 1 = system header, 2 = system header to be treated as C.  */
1037   if (syshdr)
1038     flags = 1 + (externc != 0);
1039   pfile->buffer->sysp = flags;
1040   _cpp_do_file_change (pfile, LC_RENAME, map->to_file,
1041 		       SOURCE_LINE (map, pfile->line_table->highest_line), flags);
1042 }
1043 
1044 /* Allow the client to change the current file.  Used by the front end
1045    to achieve pseudo-file names like <built-in>.
1046    If REASON is LC_LEAVE, then NEW_NAME must be NULL.  */
1047 void
1048 cpp_change_file (cpp_reader *pfile, enum lc_reason reason,
1049 		 const char *new_name)
1050 {
1051   _cpp_do_file_change (pfile, reason, new_name, 1, 0);
1052 }
1053 
1054 /* Callback function for htab_traverse.  */
1055 static int
1056 report_missing_guard (void **slot, void *b)
1057 {
1058   struct file_hash_entry *entry = (struct file_hash_entry *) *slot;
1059   int *bannerp = (int *) b;
1060 
1061   /* Skip directories.  */
1062   if (entry->start_dir != NULL)
1063     {
1064       _cpp_file *file = entry->u.file;
1065 
1066       /* We don't want MI guard advice for the main file.  */
1067       if (file->cmacro == NULL && file->stack_count == 1 && !file->main_file)
1068 	{
1069 	  if (*bannerp == 0)
1070 	    {
1071 	      fputs (_("Multiple include guards may be useful for:\n"),
1072 		     stderr);
1073 	      *bannerp = 1;
1074 	    }
1075 
1076 	  fputs (entry->u.file->path, stderr);
1077 	  putc ('\n', stderr);
1078 	}
1079     }
1080 
1081   return 0;
1082 }
1083 
1084 /* Report on all files that might benefit from a multiple include guard.
1085    Triggered by -H.  */
1086 void
1087 _cpp_report_missing_guards (cpp_reader *pfile)
1088 {
1089   int banner = 0;
1090 
1091   htab_traverse (pfile->file_hash, report_missing_guard, &banner);
1092 }
1093 
1094 /* Locate HEADER, and determine whether it is newer than the current
1095    file.  If it cannot be located or dated, return -1, if it is
1096    newer, return 1, otherwise 0.  */
1097 int
1098 _cpp_compare_file_date (cpp_reader *pfile, const char *fname,
1099 			int angle_brackets)
1100 {
1101   _cpp_file *file;
1102   struct cpp_dir *dir;
1103 
1104   dir = search_path_head (pfile, fname, angle_brackets, IT_INCLUDE);
1105   if (!dir)
1106     return -1;
1107 
1108   file = _cpp_find_file (pfile, fname, dir, false, angle_brackets);
1109   if (file->err_no)
1110     return -1;
1111 
1112   if (file->fd != -1)
1113     {
1114       close (file->fd);
1115       file->fd = -1;
1116     }
1117 
1118   return file->st.st_mtime > pfile->buffer->file->st.st_mtime;
1119 }
1120 
1121 /* Pushes the given file onto the buffer stack.  Returns nonzero if
1122    successful.  */
1123 bool
1124 cpp_push_include (cpp_reader *pfile, const char *fname)
1125 {
1126   return _cpp_stack_include (pfile, fname, false, IT_CMDLINE);
1127 }
1128 
1129 /* Do appropriate cleanup when a file INC's buffer is popped off the
1130    input stack.  */
1131 void
1132 _cpp_pop_file_buffer (cpp_reader *pfile, _cpp_file *file)
1133 {
1134   /* Record the inclusion-preventing macro, which could be NULL
1135      meaning no controlling macro.  */
1136   if (pfile->mi_valid && file->cmacro == NULL)
1137     file->cmacro = pfile->mi_cmacro;
1138 
1139   /* Invalidate control macros in the #including file.  */
1140   pfile->mi_valid = false;
1141 
1142   if (file->buffer)
1143     {
1144       free ((void *) file->buffer);
1145       file->buffer = NULL;
1146       file->buffer_valid = false;
1147     }
1148 }
1149 
1150 /* Inteface to file statistics record in _cpp_file structure. */
1151 struct stat *
1152 _cpp_get_file_stat (_cpp_file *file)
1153 {
1154     return &file->st;
1155 }
1156 
1157 /* Set the include chain for "" to QUOTE, for <> to BRACKET.  If
1158    QUOTE_IGNORES_SOURCE_DIR, then "" includes do not look in the
1159    directory of the including file.
1160 
1161    If BRACKET does not lie in the QUOTE chain, it is set to QUOTE.  */
1162 void
1163 cpp_set_include_chains (cpp_reader *pfile, cpp_dir *quote, cpp_dir *bracket,
1164 			int quote_ignores_source_dir)
1165 {
1166   pfile->quote_include = quote;
1167   pfile->bracket_include = quote;
1168   pfile->quote_ignores_source_dir = quote_ignores_source_dir;
1169 
1170   for (; quote; quote = quote->next)
1171     {
1172       quote->name_map = NULL;
1173       quote->len = strlen (quote->name);
1174       if (quote == bracket)
1175 	pfile->bracket_include = bracket;
1176     }
1177 }
1178 
1179 /* Append the file name to the directory to create the path, but don't
1180    turn / into // or // into ///; // may be a namespace escape.  */
1181 static char *
1182 append_file_to_dir (const char *fname, cpp_dir *dir)
1183 {
1184   size_t dlen, flen;
1185   char *path;
1186 
1187   dlen = dir->len;
1188   flen = strlen (fname);
1189   path = XNEWVEC (char, dlen + 1 + flen + 1);
1190   memcpy (path, dir->name, dlen);
1191   if (dlen && path[dlen - 1] != '/')
1192     path[dlen++] = '/';
1193   memcpy (&path[dlen], fname, flen + 1);
1194 
1195   return path;
1196 }
1197 
1198 /* Read a space delimited string of unlimited length from a stdio
1199    file F.  */
1200 static char *
1201 read_filename_string (int ch, FILE *f)
1202 {
1203   char *alloc, *set;
1204   int len;
1205 
1206   len = 20;
1207   set = alloc = XNEWVEC (char, len + 1);
1208   if (! is_space (ch))
1209     {
1210       *set++ = ch;
1211       while ((ch = getc (f)) != EOF && ! is_space (ch))
1212 	{
1213 	  if (set - alloc == len)
1214 	    {
1215 	      len *= 2;
1216 	      alloc = XRESIZEVEC (char, alloc, len + 1);
1217 	      set = alloc + len / 2;
1218 	    }
1219 	  *set++ = ch;
1220 	}
1221     }
1222   *set = '\0';
1223   ungetc (ch, f);
1224   return alloc;
1225 }
1226 
1227 /* Read the file name map file for DIR.  */
1228 static void
1229 read_name_map (cpp_dir *dir)
1230 {
1231   static const char FILE_NAME_MAP_FILE[] = "header.gcc";
1232   char *name;
1233   FILE *f;
1234   size_t len, count = 0, room = 9;
1235 
1236   len = dir->len;
1237   name = (char *) alloca (len + sizeof (FILE_NAME_MAP_FILE) + 1);
1238   memcpy (name, dir->name, len);
1239   if (len && name[len - 1] != '/')
1240     name[len++] = '/';
1241   strcpy (name + len, FILE_NAME_MAP_FILE);
1242   f = fopen (name, "r");
1243 
1244   dir->name_map = XNEWVEC (const char *, room);
1245 
1246   /* Silently return NULL if we cannot open.  */
1247   if (f)
1248     {
1249       int ch;
1250 
1251       while ((ch = getc (f)) != EOF)
1252 	{
1253 	  char *to;
1254 
1255 	  if (is_space (ch))
1256 	    continue;
1257 
1258 	  if (count + 2 > room)
1259 	    {
1260 	      room += 8;
1261 	      dir->name_map = XRESIZEVEC (const char *, dir->name_map, room);
1262 	    }
1263 
1264 	  dir->name_map[count] = read_filename_string (ch, f);
1265 	  while ((ch = getc (f)) != EOF && is_hspace (ch))
1266 	    ;
1267 
1268 	  to = read_filename_string (ch, f);
1269 	  if (IS_ABSOLUTE_PATH (to))
1270 	    dir->name_map[count + 1] = to;
1271 	  else
1272 	    {
1273 	      dir->name_map[count + 1] = append_file_to_dir (to, dir);
1274 	      free (to);
1275 	    }
1276 
1277 	  count += 2;
1278 	  while ((ch = getc (f)) != '\n')
1279 	    if (ch == EOF)
1280 	      break;
1281 	}
1282 
1283       fclose (f);
1284     }
1285 
1286   /* Terminate the list of maps.  */
1287   dir->name_map[count] = NULL;
1288 }
1289 
1290 /* Remap a FILE's name based on the file_name_map, if any, for
1291    FILE->dir.  If the file name has any directory separators,
1292    recursively check those directories too.  */
1293 static char *
1294 remap_filename (cpp_reader *pfile, _cpp_file *file)
1295 {
1296   const char *fname, *p;
1297   char *new_dir;
1298   cpp_dir *dir;
1299   size_t index, len;
1300 
1301   dir = file->dir;
1302   fname = file->name;
1303 
1304   for (;;)
1305     {
1306       if (!dir->name_map)
1307 	read_name_map (dir);
1308 
1309       for (index = 0; dir->name_map[index]; index += 2)
1310 	if (!strcmp (dir->name_map[index], fname))
1311 	    return xstrdup (dir->name_map[index + 1]);
1312 
1313       p = strchr (fname, '/');
1314       if (!p || p == fname)
1315 	return NULL;
1316 
1317       len = dir->len + (p - fname + 1);
1318       new_dir = XNEWVEC (char, len + 1);
1319       memcpy (new_dir, dir->name, dir->len);
1320       memcpy (new_dir + dir->len, fname, p - fname + 1);
1321       new_dir[len] = '\0';
1322 
1323       dir = make_cpp_dir (pfile, new_dir, dir->sysp);
1324       fname = p + 1;
1325     }
1326 }
1327 
1328 /* Returns true if PCHNAME is a valid PCH file for FILE.  */
1329 static bool
1330 validate_pch (cpp_reader *pfile, _cpp_file *file, const char *pchname)
1331 {
1332   const char *saved_path = file->path;
1333   bool valid = false;
1334 
1335   file->path = pchname;
1336   if (open_file (file))
1337     {
1338       valid = 1 & pfile->cb.valid_pch (pfile, pchname, file->fd);
1339 
1340       if (!valid)
1341 	{
1342 	  close (file->fd);
1343 	  file->fd = -1;
1344 	}
1345 
1346       if (CPP_OPTION (pfile, print_include_names))
1347 	{
1348 	  unsigned int i;
1349 	  for (i = 1; i < pfile->line_table->depth; i++)
1350 	    putc ('.', stderr);
1351 	  fprintf (stderr, "%c %s\n",
1352 		   valid ? '!' : 'x', pchname);
1353 	}
1354     }
1355 
1356   file->path = saved_path;
1357   return valid;
1358 }
1359 
1360 /* Get the path associated with the _cpp_file F.  The path includes
1361    the base name from the include directive and the directory it was
1362    found in via the search path.  */
1363 
1364 const char *
1365 cpp_get_path (struct _cpp_file *f)
1366 {
1367   return f->path;
1368 }
1369 
1370 /* Get the directory associated with the _cpp_file F.  */
1371 
1372 cpp_dir *
1373 cpp_get_dir (struct _cpp_file *f)
1374 {
1375   return f->dir;
1376 }
1377 
1378 /* Get the cpp_buffer currently associated with the cpp_reader
1379    PFILE.  */
1380 
1381 cpp_buffer *
1382 cpp_get_buffer (cpp_reader *pfile)
1383 {
1384   return pfile->buffer;
1385 }
1386 
1387 /* Get the _cpp_file associated with the cpp_buffer B.  */
1388 
1389 _cpp_file *
1390 cpp_get_file (cpp_buffer *b)
1391 {
1392   return b->file;
1393 }
1394 
1395 /* Get the previous cpp_buffer given a cpp_buffer B.  The previous
1396    buffer is the buffer that included the given buffer.  */
1397 
1398 cpp_buffer *
1399 cpp_get_prev (cpp_buffer *b)
1400 {
1401   return b->prev;
1402 }
1403 
1404 /* This data structure holds the list of header files that were seen
1405    while the PCH was being built.  The 'entries' field is kept sorted
1406    in memcmp() order; yes, this means that on little-endian systems,
1407    it's sorted initially by the least-significant byte of 'size', but
1408    that's OK.  The code does rely on having entries with the same size
1409    next to each other.  */
1410 
1411 struct pchf_entry {
1412   /* The size of this file.  This is used to save running a MD5 checksum
1413      if the sizes don't match.  */
1414   off_t size;
1415   /* The MD5 checksum of this file.  */
1416   unsigned char sum[16];
1417   /* Is this file to be included only once?  */
1418   bool once_only;
1419 };
1420 
1421 struct pchf_data {
1422   /* Number of pchf_entry structures.  */
1423   size_t count;
1424 
1425   /* Are there any values with once_only set?
1426      This is used as an optimisation, it means we don't have to search
1427      the structure if we're processing a regular #include.  */
1428   bool have_once_only;
1429 
1430   struct pchf_entry entries[1];
1431 };
1432 
1433 static struct pchf_data *pchf;
1434 
1435 /* A qsort ordering function for pchf_entry structures.  */
1436 
1437 static int
1438 pchf_save_compare (const void *e1, const void *e2)
1439 {
1440   return memcmp (e1, e2, sizeof (struct pchf_entry));
1441 }
1442 
1443 /* Create and write to F a pchf_data structure.  */
1444 
1445 bool
1446 _cpp_save_file_entries (cpp_reader *pfile, FILE *fp)
1447 {
1448   size_t count = 0;
1449   struct pchf_data *result;
1450   size_t result_size;
1451   _cpp_file *f;
1452 
1453   for (f = pfile->all_files; f; f = f->next_file)
1454     ++count;
1455 
1456   result_size = (sizeof (struct pchf_data)
1457 		 + sizeof (struct pchf_entry) * (count - 1));
1458   result = XCNEWVAR (struct pchf_data, result_size);
1459 
1460   result->count = 0;
1461   result->have_once_only = false;
1462 
1463   for (f = pfile->all_files; f; f = f->next_file)
1464     {
1465       size_t count;
1466 
1467       /* This should probably never happen, since if a read error occurred
1468 	 the PCH file shouldn't be written...  */
1469       if (f->dont_read || f->err_no)
1470 	continue;
1471 
1472       if (f->stack_count == 0)
1473 	continue;
1474 
1475       count = result->count++;
1476 
1477       result->entries[count].once_only = f->once_only;
1478       /* |= is avoided in the next line because of an HP C compiler bug */
1479       result->have_once_only = result->have_once_only | f->once_only;
1480       if (f->buffer_valid)
1481 	md5_buffer ((const char *)f->buffer,
1482 		    f->st.st_size, result->entries[count].sum);
1483       else
1484 	{
1485 	  FILE *ff;
1486 	  int oldfd = f->fd;
1487 
1488 	  if (!open_file (f))
1489 	    {
1490 	      open_file_failed (pfile, f, 0);
1491 	      return false;
1492 	    }
1493 	  ff = fdopen (f->fd, "rb");
1494 	  md5_stream (ff, result->entries[count].sum);
1495 	  fclose (ff);
1496 	  f->fd = oldfd;
1497 	}
1498       result->entries[count].size = f->st.st_size;
1499     }
1500 
1501   result_size = (sizeof (struct pchf_data)
1502                  + sizeof (struct pchf_entry) * (result->count - 1));
1503 
1504   qsort (result->entries, result->count, sizeof (struct pchf_entry),
1505 	 pchf_save_compare);
1506 
1507   return fwrite (result, result_size, 1, fp) == 1;
1508 }
1509 
1510 /* Read the pchf_data structure from F.  */
1511 
1512 bool
1513 _cpp_read_file_entries (cpp_reader *pfile ATTRIBUTE_UNUSED, FILE *f)
1514 {
1515   struct pchf_data d;
1516 
1517   if (fread (&d, sizeof (struct pchf_data) - sizeof (struct pchf_entry), 1, f)
1518        != 1)
1519     return false;
1520 
1521   pchf = XNEWVAR (struct pchf_data, sizeof (struct pchf_data)
1522 		  + sizeof (struct pchf_entry) * (d.count - 1));
1523   memcpy (pchf, &d, sizeof (struct pchf_data) - sizeof (struct pchf_entry));
1524   if (fread (pchf->entries, sizeof (struct pchf_entry), d.count, f)
1525       != d.count)
1526     return false;
1527   return true;
1528 }
1529 
1530 /* The parameters for pchf_compare.  */
1531 
1532 struct pchf_compare_data
1533 {
1534   /* The size of the file we're looking for.  */
1535   off_t size;
1536 
1537   /* The MD5 checksum of the file, if it's been computed.  */
1538   unsigned char sum[16];
1539 
1540   /* Is SUM valid?  */
1541   bool sum_computed;
1542 
1543   /* Do we need to worry about entries that don't have ONCE_ONLY set?  */
1544   bool check_included;
1545 
1546   /* The file that we're searching for.  */
1547   _cpp_file *f;
1548 };
1549 
1550 /* bsearch comparison function; look for D_P in E_P.  */
1551 
1552 static int
1553 pchf_compare (const void *d_p, const void *e_p)
1554 {
1555   const struct pchf_entry *e = (const struct pchf_entry *)e_p;
1556   struct pchf_compare_data *d = (struct pchf_compare_data *)d_p;
1557   int result;
1558 
1559   result = memcmp (&d->size, &e->size, sizeof (off_t));
1560   if (result != 0)
1561     return result;
1562 
1563   if (! d->sum_computed)
1564     {
1565       _cpp_file *const f = d->f;
1566 
1567       md5_buffer ((const char *)f->buffer, f->st.st_size, d->sum);
1568       d->sum_computed = true;
1569     }
1570 
1571   result = memcmp (d->sum, e->sum, 16);
1572   if (result != 0)
1573     return result;
1574 
1575   if (d->check_included || e->once_only)
1576     return 0;
1577   else
1578     return 1;
1579 }
1580 
1581 /* Check that F is not in a list read from a PCH file (if any).
1582    Assumes that f->buffer_valid is true.  Return TRUE if the file
1583    should not be read.  */
1584 
1585 static bool
1586 check_file_against_entries (cpp_reader *pfile ATTRIBUTE_UNUSED,
1587 			    _cpp_file *f,
1588 			    bool check_included)
1589 {
1590   struct pchf_compare_data d;
1591 
1592   if (pchf == NULL
1593       || (! check_included && ! pchf->have_once_only))
1594     return false;
1595 
1596   d.size = f->st.st_size;
1597   d.sum_computed = false;
1598   d.f = f;
1599   d.check_included = check_included;
1600   return bsearch (&d, pchf->entries, pchf->count, sizeof (struct pchf_entry),
1601 		  pchf_compare) != NULL;
1602 }
1603