]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/fortran/options.c
Daily bump.
[thirdparty/gcc.git] / gcc / fortran / options.c
CommitLineData
4ee9c684 1/* Parse and display command line options.
c84b470d 2 Copyright (C) 2000, 2001, 2002, 2003, 2004 Free Software Foundation,
3 Inc.
4ee9c684 4 Contributed by Andy Vaught
5
c84b470d 6This file is part of GCC.
4ee9c684 7
c84b470d 8GCC is free software; you can redistribute it and/or modify it under
9the terms of the GNU General Public License as published by the Free
10Software Foundation; either version 2, or (at your option) any later
11version.
4ee9c684 12
c84b470d 13GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14WARRANTY; without even the implied warranty of MERCHANTABILITY or
15FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16for more details.
4ee9c684 17
18You should have received a copy of the GNU General Public License
c84b470d 19along with GCC; see the file COPYING. If not, write to the Free
20Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2102111-1307, USA. */
4ee9c684 22
23#include <string.h>
24#include <stdlib.h>
25
26#include "config.h"
27#include "system.h"
28#include "coretypes.h"
29#include "tree.h"
30#include "flags.h"
31#include "intl.h"
32#include "opts.h"
33#include "options.h"
34#include "tree-inline.h"
35
36#include "gfortran.h"
37
38gfc_option_t gfc_option;
39
40
41/* Get ready for options handling. */
42
43unsigned int
44gfc_init_options (unsigned int argc ATTRIBUTE_UNUSED,
45 const char **argv ATTRIBUTE_UNUSED)
46{
47
48 gfc_option.source = NULL;
49 gfc_option.module_dir = NULL;
50 gfc_option.source_form = FORM_UNKNOWN;
51 gfc_option.fixed_line_length = 72;
52 gfc_option.max_identifier_length = GFC_MAX_SYMBOL_LEN;
53 gfc_option.verbose = 0;
54
55 gfc_option.warn_aliasing = 0;
56 gfc_option.warn_conversion = 0;
57 gfc_option.warn_implicit_interface = 0;
58 gfc_option.warn_line_truncation = 0;
9857bf0d 59 gfc_option.warn_underflow = 1;
4ee9c684 60 gfc_option.warn_surprising = 0;
61 gfc_option.warn_unused_labels = 0;
62
63 gfc_option.flag_dollar_ok = 0;
64 gfc_option.flag_underscoring = 1;
65 gfc_option.flag_second_underscore = 1;
66 gfc_option.flag_implicit_none = 0;
67 gfc_option.flag_max_stack_var_size = 32768;
68 gfc_option.flag_module_access_private = 0;
69 gfc_option.flag_no_backend = 0;
70 gfc_option.flag_pack_derived = 0;
71 gfc_option.flag_repack_arrays = 0;
72
b8a891cb 73 gfc_option.q_kind = gfc_default_double_kind;
4ee9c684 74 gfc_option.i8 = 0;
75 gfc_option.r8 = 0;
76 gfc_option.d8 = 0;
77
78 flag_argument_noalias = 2;
79
80 gfc_option.allow_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
81 | GFC_STD_F2003_OBS | GFC_STD_F2003_DEL | GFC_STD_F2003 | GFC_STD_GNU;
82 gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
675e3934 83 | GFC_STD_F2003;
4ee9c684 84
85 return CL_F95;
86}
87
88
89/* Finalize commandline options. */
90
91bool
92gfc_post_options (const char **pfilename)
93{
94 const char *filename = *pfilename;
95
96 /* Verify the input file name. */
97 if (!filename || strcmp (filename, "-") == 0)
98 {
99 filename = "";
100 }
101
102 gfc_option.source = filename;
103
104 flag_inline_trees = 1;
105
106 /* Use tree inlining. */
107 if (!flag_no_inline)
108 flag_no_inline = 1;
109 if (flag_inline_functions)
110 {
111 flag_inline_trees = 2;
112 flag_inline_functions = 0;
113 }
675e3934 114
115 /* If -pedantic, warn about the use of GNU extensions. */
116 if (pedantic && (gfc_option.allow_std & GFC_STD_GNU) != 0)
117 gfc_option.warn_std |= GFC_STD_GNU;
118
4ee9c684 119 return false;
120}
121
122
123/* Set the options for -Wall. */
124
125static void
126set_Wall (void)
127{
128
129 gfc_option.warn_aliasing = 1;
130 gfc_option.warn_line_truncation = 1;
9857bf0d 131 gfc_option.warn_underflow = 1;
4ee9c684 132 gfc_option.warn_surprising = 1;
133 gfc_option.warn_unused_labels = 1;
134
135 set_Wunused (1);
136 warn_return_type = 1;
137 warn_switch = 1;
138
139 /* We save the value of warn_uninitialized, since if they put
140 -Wuninitialized on the command line, we need to generate a
141 warning about not using it without also specifying -O. */
142
143 if (warn_uninitialized != 1)
144 warn_uninitialized = 2;
145}
146
147
148static void
149gfc_handle_module_path_options (const char *arg)
150{
151
152 if (gfc_option.module_dir != NULL)
153 {
154 gfc_status ("gfortran: Only one -M option allowed\n");
155 exit (3);
156 }
157
158 if (arg == NULL)
159 {
160 gfc_status ("gfortran: Directory required after -M\n");
161 exit (3);
162 }
163
3f1e4cec 164 gfc_option.module_dir = (char *) gfc_getmem (strlen (arg) + 2);
4ee9c684 165 strcpy (gfc_option.module_dir, arg);
166 strcat (gfc_option.module_dir, "/");
167}
168
169/* Handle command-line options. Returns 0 if unrecognized, 1 if
170 recognized and handled. */
171int
172gfc_handle_option (size_t scode, const char *arg, int value)
173{
174 int result = 1;
175 enum opt_code code = (enum opt_code) scode;
176
177 /* Ignore file names. */
178 if (code == N_OPTS)
179 return 1;
180
181 switch (code)
182 {
183 default:
184 result = 0;
185 break;
186
187 case OPT_Wall:
188 set_Wall ();
189 break;
190
191 case OPT_Waliasing:
192 gfc_option.warn_aliasing = value;
193 break;
194
195 case OPT_Wconversion:
196 gfc_option.warn_conversion = value;
197 break;
198
199 case OPT_Wimplicit_interface:
200 gfc_option.warn_implicit_interface = value;
201 break;
202
203 case OPT_Wline_truncation:
204 gfc_option.warn_line_truncation = value;
205 break;
206
9857bf0d 207 case OPT_Wunderflow:
208 gfc_option.warn_underflow = value;
209 break;
210
4ee9c684 211 case OPT_Wsurprising:
212 gfc_option.warn_surprising = value;
213 break;
214
215 case OPT_Wunused_labels:
216 gfc_option.warn_unused_labels = value;
217 break;
218
219 case OPT_fdollar_ok:
220 gfc_option.flag_dollar_ok = value;
221 break;
222
223 case OPT_fdump_parse_tree:
224 gfc_option.verbose = value;
225 break;
226
227 case OPT_ffixed_form:
228 gfc_option.source_form = FORM_FIXED;
229 break;
230
231 case OPT_ffree_form:
232 gfc_option.source_form = FORM_FREE;
233 break;
234
235 case OPT_funderscoring:
236 gfc_option.flag_underscoring = value;
237 break;
238
239 case OPT_fsecond_underscore:
240 gfc_option.flag_second_underscore = value;
241 break;
242
243 case OPT_fimplicit_none:
244 gfc_option.flag_implicit_none = value;
245 break;
246
247 case OPT_fmax_stack_var_size_:
248 gfc_option.flag_max_stack_var_size = value;
249 break;
250
251 case OPT_fmodule_private:
252 gfc_option.flag_module_access_private = value;
253 break;
254
255 case OPT_fno_backend:
256 gfc_option.flag_no_backend = value;
257 break;
258
259 case OPT_fpack_derived:
260 gfc_option.flag_pack_derived = value;
261 break;
262
263 case OPT_frepack_arrays:
264 gfc_option.flag_repack_arrays = value;
265 break;
266
f653e99b 267 case OPT_ffixed_line_length_none:
268 gfc_option.fixed_line_length = 0;
4ee9c684 269 break;
270
f653e99b 271 case OPT_ffixed_line_length_:
272 if (value != 0 && value < 7)
273 gfc_fatal_error ("Fixed line length must be at least seven.");
274 gfc_option.fixed_line_length = value;
4ee9c684 275 break;
276
277 case OPT_fmax_identifier_length_:
278 if (value > GFC_MAX_SYMBOL_LEN)
279 gfc_fatal_error ("Maximum supported idenitifier length is %d",
280 GFC_MAX_SYMBOL_LEN);
281 gfc_option.max_identifier_length = value;
282 break;
283
284 case OPT_qkind_:
f2d4ef3b 285 if (gfc_validate_kind (BT_REAL, value, true) < 0)
4ee9c684 286 gfc_fatal_error ("Argument to -fqkind isn't a valid real kind");
287 gfc_option.q_kind = value;
288 break;
289
290 case OPT_i8:
291 gfc_option.i8 = value;
292 break;
293
294 case OPT_r8:
295 gfc_option.r8 = value;
296 break;
297
298 case OPT_d8:
299 gfc_option.d8 = value;
300 break;
301
302 case OPT_I:
303 gfc_add_include_path (arg);
304 break;
305
306 case OPT_J:
307 case OPT_M:
308 gfc_handle_module_path_options (arg);
ca9ccc0d 309 break;
4ee9c684 310
311 case OPT_std_f95:
312 gfc_option.allow_std = GFC_STD_F95_OBS | GFC_STD_F2003_OBS
313 | GFC_STD_F2003_DEL;
314 gfc_option.warn_std = GFC_STD_F95_OBS;
315 gfc_option.max_identifier_length = 31;
316 break;
317
318 case OPT_std_f2003:
319 gfc_option.allow_std = GFC_STD_F95_OBS | GFC_STD_F2003_OBS
320 | GFC_STD_F2003;
321 gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F2003_OBS;
322 gfc_option.max_identifier_length = 63;
323 break;
324
325 case OPT_std_gnu:
326 gfc_option.allow_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
327 | GFC_STD_F2003_OBS | GFC_STD_F2003_DEL | GFC_STD_F2003 | GFC_STD_GNU;
328 gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
675e3934 329 | GFC_STD_F2003_OBS | GFC_STD_F2003_DEL;
4ee9c684 330 break;
331 }
332
333 return result;
334}