annotate libcc1/findcomp.cc @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Find the correct compiler.
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 2014-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of GCC.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
7 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
8 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
9 version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
14 for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
17 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
18 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 #include <config.h>
kono
parents:
diff changeset
21 #include <string>
kono
parents:
diff changeset
22 #include <dirent.h>
kono
parents:
diff changeset
23 #include <stdlib.h>
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 #include "libiberty.h"
kono
parents:
diff changeset
26 #include "xregex.h"
kono
parents:
diff changeset
27 #include "findcomp.hh"
kono
parents:
diff changeset
28 #include "system.h"
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 class scanner
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 public:
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 scanner (const std::string &dir)
kono
parents:
diff changeset
35 {
kono
parents:
diff changeset
36 m_dir = opendir (dir.c_str ());
kono
parents:
diff changeset
37 }
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 ~scanner ()
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 if (m_dir != NULL)
kono
parents:
diff changeset
42 closedir (m_dir);
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 const char *next ()
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 if (m_dir == NULL)
kono
parents:
diff changeset
48 return NULL;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 struct dirent *entry = readdir (m_dir);
kono
parents:
diff changeset
51 if (entry == NULL)
kono
parents:
diff changeset
52 return NULL;
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 return entry->d_name;
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 private:
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 DIR *m_dir;
kono
parents:
diff changeset
60 };
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 static bool
kono
parents:
diff changeset
63 search_dir (const regex_t &regexp, const std::string &dir, std::string *result)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 scanner scan (dir);
kono
parents:
diff changeset
66 const char *filename;
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 while ((filename = scan.next ()) != NULL)
kono
parents:
diff changeset
69 {
kono
parents:
diff changeset
70 if (regexec (&regexp, filename, 0, NULL, 0) == 0)
kono
parents:
diff changeset
71 {
kono
parents:
diff changeset
72 *result = dir + DIR_SEPARATOR + filename;
kono
parents:
diff changeset
73 return true;
kono
parents:
diff changeset
74 }
kono
parents:
diff changeset
75 }
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 return false;
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 class tokenizer
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 public:
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 tokenizer (const char *str)
kono
parents:
diff changeset
85 : m_str (str),
kono
parents:
diff changeset
86 m_pos (0)
kono
parents:
diff changeset
87 {
kono
parents:
diff changeset
88 }
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 bool done () const
kono
parents:
diff changeset
91 {
kono
parents:
diff changeset
92 return m_pos == std::string::npos;
kono
parents:
diff changeset
93 }
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 std::string next ()
kono
parents:
diff changeset
96 {
kono
parents:
diff changeset
97 std::string::size_type last_pos = m_pos;
kono
parents:
diff changeset
98 std::string::size_type colon = m_str.find(':', last_pos);
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 std::string result;
kono
parents:
diff changeset
101 if (colon == std::string::npos)
kono
parents:
diff changeset
102 {
kono
parents:
diff changeset
103 m_pos = colon;
kono
parents:
diff changeset
104 result = m_str.substr(last_pos, colon);
kono
parents:
diff changeset
105 }
kono
parents:
diff changeset
106 else
kono
parents:
diff changeset
107 {
kono
parents:
diff changeset
108 m_pos = colon + 1;
kono
parents:
diff changeset
109 result = m_str.substr(last_pos, colon - last_pos);
kono
parents:
diff changeset
110 }
kono
parents:
diff changeset
111 if (result == "")
kono
parents:
diff changeset
112 result = ".";
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 return result;
kono
parents:
diff changeset
115 }
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 private:
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 std::string m_str;
kono
parents:
diff changeset
120 std::string::size_type m_pos;
kono
parents:
diff changeset
121 };
kono
parents:
diff changeset
122
kono
parents:
diff changeset
123 bool
kono
parents:
diff changeset
124 find_compiler (const regex_t &regexp, std::string *result)
kono
parents:
diff changeset
125 {
kono
parents:
diff changeset
126 const char *cpath = getenv ("PATH");
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 if (cpath == NULL)
kono
parents:
diff changeset
129 return false;
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 tokenizer dirs (cpath);
kono
parents:
diff changeset
132 while (!dirs.done ())
kono
parents:
diff changeset
133 {
kono
parents:
diff changeset
134 std::string dir = dirs.next ();
kono
parents:
diff changeset
135 if (search_dir (regexp, dir, result))
kono
parents:
diff changeset
136 return true;
kono
parents:
diff changeset
137 }
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 return false;
kono
parents:
diff changeset
140 }