Sort includes for files gdb/[a-f]*.[chyl].
[external/binutils.git] / gdb / filename-seen-cache.c
1 /* Filename-seen cache for the GNU debugger, GDB.
2
3    Copyright (C) 1986-2019 Free Software Foundation, Inc.
4
5    This file is part of GDB.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
19
20 #include "defs.h"
21
22 /* Local non-gdb includes.  */
23 #include "filename-seen-cache.h"
24 #include "filenames.h"
25
26   /* Initial size of the table.  It automagically grows from here.  */
27 #define INITIAL_FILENAME_SEEN_CACHE_SIZE 100
28
29 /* filename_seen_cache constructor.  */
30
31 filename_seen_cache::filename_seen_cache ()
32 {
33   m_tab = htab_create_alloc (INITIAL_FILENAME_SEEN_CACHE_SIZE,
34                              filename_hash, filename_eq,
35                              NULL, xcalloc, xfree);
36 }
37
38 /* See filename-seen-cache.h.  */
39
40 void
41 filename_seen_cache::clear ()
42 {
43   htab_empty (m_tab);
44 }
45
46 /* See filename-seen-cache.h.  */
47
48 filename_seen_cache::~filename_seen_cache ()
49 {
50   htab_delete (m_tab);
51 }
52
53 /* See filename-seen-cache.h.  */
54
55 bool
56 filename_seen_cache::seen (const char *file)
57 {
58   void **slot;
59
60   /* Is FILE in tab?  */
61   slot = htab_find_slot (m_tab, file, INSERT);
62   if (*slot != NULL)
63     return true;
64
65   /* No; add it to tab.  */
66   *slot = (char *) file;
67   return false;
68 }