2 /* Install modified versions of certain ANSI-incompatible system header
3 files which are fixed to work correctly with ANSI C and placed in a
4 directory that GNU C will search.
6 Copyright (C) 1999, 2000 Free Software Foundation, Inc.
8 This file is part of GNU CC.
10 GNU CC is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 2, or (at your option)
15 GNU CC 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.
20 You should have received a copy of the GNU General Public License
21 along with GNU CC; see the file COPYING. If not, write to
22 the Free Software Foundation, 59 Temple Place - Suite 330,
23 Boston, MA 02111-1307, USA. */
27 /* * * * * * * * * * * * *
29 load_file_data loads all the contents of a file into malloc-ed memory.
30 Its argument is the file pointer of the file to read in; the returned
31 result is the NUL terminated contents of the file. The file
32 is presumed to be an ASCII text file containing no NULs. */
38 char *pz_data
= (char*)NULL
;
39 int space_left
= -1; /* allow for terminating NUL */
40 size_t space_used
= 0;
42 if (fp
== (FILE*)NULL
)
49 if (space_left
< 1024)
52 pz_data
= xrealloc ((void*)pz_data
, space_left
+ space_used
+ 1 );
54 size_read
= fread (pz_data
+ space_used
, 1, space_left
, fp
);
65 fprintf (stderr
, "error %d (%s) reading input\n", err
,
67 free ((void *) pz_data
);
72 space_left
-= size_read
;
73 space_used
+= size_read
;
74 } while (! feof (fp
));
76 pz_data
= xrealloc ((void*)pz_data
, space_used
+1 );
77 pz_data
[ space_used
] = NUL
;
82 #ifdef IS_CXX_HEADER_NEEDED
84 is_cxx_header (fname
, text
)
88 /* First, check to see if the file is in a C++ directory */
93 case 'C': /* check for "CC/" */
94 if ((fname
[0] == 'C') && (fname
[1] == '/'))
98 case 'x': /* check for "xx/" */
99 if ((fname
[0] == 'x') && (fname
[1] == '/'))
103 case '+': /* check for "++" */
113 /* Or it might contain one of several phrases which indicate C++ code.
114 Currently recognized are:
116 -*- (Mode: )? C++ -*- (emacs mode marker)
121 extern[ \t]*\"C\\+\\+\"|\
122 -\\*-[ \t]*([mM]ode:[ \t]*)?[cC]\\+\\+[; \t]*-\\*-|\
125 (public|private|protected):|\
126 ^[ \t]*#[ \t]*pragma[ \t]+(interface|implementation)\
128 static regex_t cxxre
;
132 compile_re (cxxpat
, &cxxre
, 0, "contents check", "is_cxx_header");
134 if (regexec (&cxxre
, text
, 0, 0, 0) == 0)
140 #endif /* CXX_TYPE_NEEDED */
142 #ifdef SKIP_QUOTE_NEEDED
144 * Skip over a quoted string. Single quote strings may
145 * contain multiple characters if the first character is
146 * a backslash. Especially a backslash followed by octal digits.
147 * We are not doing a correctness syntax check here.
150 skip_quote( q
, text
)
160 text
++; /* skip over whatever character follows */
177 #endif /* SKIP_QUOTE_NEEDED */
179 /* * * * * * * * * * * * *
181 Compile one regular expression pattern for later use. PAT contains
182 the pattern, RE points to a regex_t structure (which should have
183 been bzeroed). MATCH is 1 if we need to know where the regex
184 matched, 0 if not. If regcomp fails, prints an error message and
185 aborts; E1 and E2 are strings to shove into the error message.
187 The patterns we search for are all egrep patterns.
188 REG_EXTENDED|REG_NEWLINE produces identical regex syntax/semantics
189 to egrep (verified from 4.4BSD Programmer's Reference Manual). */
191 compile_re( pat
, re
, match
, e1
, e2
)
198 tSCC z_bad_comp
[] = "fixincl ERROR: cannot compile %s regex for %s\n\
199 \texpr = `%s'\n\terror %s\n";
202 flags
= (match
? REG_EXTENDED
|REG_NEWLINE
203 : REG_EXTENDED
|REG_NEWLINE
|REG_NOSUB
);
204 err
= regcomp (re
, pat
, flags
);
209 regerror (err
, re
, rerrbuf
, 1024);
210 fprintf (stderr
, z_bad_comp
, e1
, e2
, pat
, rerrbuf
);
215 /* * * * * * * * * * * * *
217 Helper routine and data for the machine_name test and fix.
218 machname.h is created by black magic in the Makefile. */
222 tSCC mn_label_pat
[] = "^[ \t]*#[ \t]*(if|ifdef|ifndef)[ \t]+";
223 static regex_t mn_label_re
;
225 tSCC mn_name_pat
[] = MN_NAME_PAT
;
226 static regex_t mn_name_re
;
228 static int mn_compiled
= 0;
231 mn_get_regexps( label_re
, name_re
, who
)
238 compile_re (mn_label_pat
, &mn_label_re
, 1, "label pattern", who
);
239 compile_re (mn_name_pat
, &mn_name_re
, 1, "name pattern", who
);
242 *label_re
= &mn_label_re
;
243 *name_re
= &mn_name_re
;
248 #ifdef SEPARATE_FIX_PROC
251 make_raw_shell_str( pz_d
, pz_s
, smax
)
258 char* pz_d_start
= pz_d
;
260 smax
--; /* adjust for trailing NUL */
262 dtaSize
= strlen( pz_s
) + 3;
265 const char* pz
= pz_s
- 1;
268 pz
= strchr( pz
+1, '\'' );
269 if (pz
== (char*)NULL
)
271 dtaSize
+= sizeof( zQ
)-1;
280 if (pz_d
- pz_d_start
>= smax
)
282 switch (*(pz_d
++) = *(pz_s
++)) {
287 if (pz_d
- pz_d_start
>= smax
- sizeof( zQ
)-1)
289 strcpy( pz_d
-1, zQ
);
290 pz_d
+= sizeof( zQ
)-2;