OSDN Git Service

* Makefile.in (opts.o): Depend on target.h.
[pf3gnuchains/gcc-fork.git] / gcc / opts.c
1 /* Command line option handling.
2    Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
3    Contributed by Neil Booth.
4
5 This file is part of GCC.
6
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
11
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15 for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING.  If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.  */
21
22 #include "config.h"
23 #include "system.h"
24 #include "intl.h"
25 #include "coretypes.h"
26 #include "tm.h"
27 #include "tree.h"
28 #include "rtl.h"
29 #include "ggc.h"
30 #include "output.h"
31 #include "langhooks.h"
32 #include "opts.h"
33 #include "options.h"
34 #include "flags.h"
35 #include "toplev.h"
36 #include "params.h"
37 #include "diagnostic.h"
38 #include "tm_p.h"               /* For OPTIMIZATION_OPTIONS.  */
39 #include "insn-attr.h"          /* For INSN_SCHEDULING.  */
40 #include "target.h"
41
42 /* Value of the -G xx switch, and whether it was passed or not.  */
43 unsigned HOST_WIDE_INT g_switch_value;
44 bool g_switch_set;
45
46 /* True if we should exit after parsing options.  */
47 bool exit_after_options;
48
49 /* If -version.  */
50 bool version_flag;
51
52 /* Print various extra warnings.  -W/-Wextra.  */
53 bool extra_warnings;
54
55 /* Don't print warning messages.  -w.  */
56 bool inhibit_warnings;
57
58 /* Treat warnings as errors.  -Werror.  */
59 bool warnings_are_errors;
60
61 /* Warn if a function returns an aggregate, since there are often
62    incompatible calling conventions for doing this.  */
63 bool warn_aggregate_return;
64
65 /* Nonzero means warn about pointer casts that increase the required
66    alignment of the target type (and might therefore lead to a crash
67    due to a misaligned access).  */
68 bool warn_cast_align;
69
70 /* Nonzero means warn about uses of __attribute__((deprecated))
71    declarations.  */
72 bool warn_deprecated_decl = true;
73
74 /* Warn when an optimization pass is disabled.  */
75 bool warn_disabled_optimization;
76
77 /* Nonzero means warn if inline function is too large.  */
78 bool warn_inline;
79
80 /* True to warn about any objects definitions whose size is larger
81    than N bytes.  Also want about function definitions whose returned
82    values are larger than N bytes, where N is `larger_than_size'.  */
83 bool warn_larger_than;
84 HOST_WIDE_INT larger_than_size;
85
86 /* Warn about functions which might be candidates for attribute noreturn.  */
87 bool warn_missing_noreturn;
88
89 /* True to warn about code which is never reached.  */
90 bool warn_notreached;
91
92 /* Warn if packed attribute on struct is unnecessary and inefficient.  */
93 bool warn_packed;
94
95 /* Warn when gcc pads a structure to an alignment boundary.  */
96 bool warn_padded;
97
98 /* True means warn about all declarations which shadow others.  */
99 bool warn_shadow;
100
101 /* Nonzero means warn about constructs which might not be
102    strict-aliasing safe.  */
103 bool warn_strict_aliasing;
104
105 /* True to warn if a switch on an enum, that does not have a default
106    case, fails to have a case for every enum value.  */
107 bool warn_switch;
108
109 /* Warn if a switch does not have a default case.  */
110 bool warn_switch_default;
111
112 /* Warn if a switch on an enum fails to have a case for every enum
113    value (regardless of the presence or otherwise of a default case).  */
114 bool warn_switch_enum;
115
116 /* Don't suppress warnings from system headers.  -Wsystem-headers.  */
117 bool warn_system_headers;
118
119 /* True to warn about variables used before they are initialized.  */
120 int warn_uninitialized;
121
122 /* True to warn about unused variables, functions et.al.  */
123 bool warn_unused_function;
124 bool warn_unused_label;
125 bool warn_unused_parameter;
126 bool warn_unused_variable;
127 bool warn_unused_value;
128
129 /* Hack for cooperation between set_Wunused and set_Wextra.  */
130 static bool maybe_warn_unused_parameter;
131
132 /* Type(s) of debugging information we are producing (if any).  See
133    flags.h for the definitions of the different possible types of
134    debugging information.  */
135 enum debug_info_type write_symbols = NO_DEBUG;
136
137 /* Level of debugging information we are producing.  See flags.h for
138    the definitions of the different possible levels.  */
139 enum debug_info_level debug_info_level = DINFO_LEVEL_NONE;
140
141 /* Nonzero means use GNU-only extensions in the generated symbolic
142    debugging information.  Currently, this only has an effect when
143    write_symbols is set to DBX_DEBUG, XCOFF_DEBUG, or DWARF_DEBUG.  */
144 bool use_gnu_debug_info_extensions;
145
146 /* Columns of --help display.  */
147 static unsigned int columns = 80;
148
149 /* What to print when a switch has no documentation.  */
150 static const char undocumented_msg[] = N_("This switch lacks documentation");
151
152 /* Used for bookkeeping on whether user set these flags so
153    -fprofile-use/-fprofile-generate does not use them.  */
154 static bool profile_arc_flag_set, flag_profile_values_set;
155 static bool flag_unroll_loops_set, flag_tracer_set;
156 static bool flag_value_profile_transformations_set;
157 static bool flag_peel_loops_set, flag_branch_probabilities_set;
158
159 /* Input file names.  */
160 const char **in_fnames;
161 unsigned num_in_fnames;
162
163 static size_t find_opt (const char *, int);
164 static int common_handle_option (size_t scode, const char *arg, int value);
165 static void handle_param (const char *);
166 static void set_Wextra (int);
167 static unsigned int handle_option (const char **argv, unsigned int lang_mask);
168 static char *write_langs (unsigned int lang_mask);
169 static void complain_wrong_lang (const char *, const struct cl_option *,
170                                  unsigned int lang_mask);
171 static void handle_options (unsigned int, const char **, unsigned int);
172 static void wrap_help (const char *help, const char *item, unsigned int);
173 static void print_help (void);
174 static void print_param_help (void);
175 static void print_filtered_help (unsigned int flag);
176 static unsigned int print_switch (const char *text, unsigned int indent);
177 static void set_debug_level (enum debug_info_type type, int extended,
178                              const char *arg);
179
180 /* Perform a binary search to find which option the command-line INPUT
181    matches.  Returns its index in the option array, and N_OPTS
182    (cl_options_count) on failure.
183
184    This routine is quite subtle.  A normal binary search is not good
185    enough because some options can be suffixed with an argument, and
186    multiple sub-matches can occur, e.g. input of "-pedantic" matching
187    the initial substring of "-pedantic-errors".
188
189    A more complicated example is -gstabs.  It should match "-g" with
190    an argument of "stabs".  Suppose, however, that the number and list
191    of switches are such that the binary search tests "-gen-decls"
192    before having tested "-g".  This doesn't match, and as "-gen-decls"
193    is less than "-gstabs", it will become the lower bound of the
194    binary search range, and "-g" will never be seen.  To resolve this
195    issue, opts.sh makes "-gen-decls" point, via the back_chain member,
196    to "-g" so that failed searches that end between "-gen-decls" and
197    the lexicographically subsequent switch know to go back and see if
198    "-g" causes a match (which it does in this example).
199
200    This search is done in such a way that the longest match for the
201    front end in question wins.  If there is no match for the current
202    front end, the longest match for a different front end is returned
203    (or N_OPTS if none) and the caller emits an error message.  */
204 static size_t
205 find_opt (const char *input, int lang_mask)
206 {
207   size_t mn, mx, md, opt_len;
208   size_t match_wrong_lang;
209   int comp;
210
211   mn = 0;
212   mx = cl_options_count;
213
214   /* Find mn such this lexicographical inequality holds:
215      cl_options[mn] <= input < cl_options[mn + 1].  */
216   while (mx - mn > 1)
217     {
218       md = (mn + mx) / 2;
219       opt_len = cl_options[md].opt_len;
220       comp = strncmp (input, cl_options[md].opt_text + 1, opt_len);
221
222       if (comp < 0)
223         mx = md;
224       else
225         mn = md;
226     }
227
228   /* This is the switch that is the best match but for a different
229      front end, or cl_options_count if there is no match at all.  */
230   match_wrong_lang = cl_options_count;
231
232   /* Backtrace the chain of possible matches, returning the longest
233      one, if any, that fits best.  With current GCC switches, this
234      loop executes at most twice.  */
235   do
236     {
237       const struct cl_option *opt = &cl_options[mn];
238
239       /* Is this switch a prefix of the input?  */
240       if (!strncmp (input, opt->opt_text + 1, opt->opt_len))
241         {
242           /* If language is OK, and the match is exact or the switch
243              takes a joined argument, return it.  */
244           if ((opt->flags & lang_mask)
245               && (input[opt->opt_len] == '\0' || (opt->flags & CL_JOINED)))
246             return mn;
247
248           /* If we haven't remembered a prior match, remember this
249              one.  Any prior match is necessarily better.  */
250           if (match_wrong_lang == cl_options_count)
251             match_wrong_lang = mn;
252         }
253
254       /* Try the next possibility.  This is cl_options_count if there
255          are no more.  */
256       mn = opt->back_chain;
257     }
258   while (mn != cl_options_count);
259
260   /* Return the best wrong match, or cl_options_count if none.  */
261   return match_wrong_lang;
262 }
263
264 /* If ARG is a non-negative integer made up solely of digits, return its
265    value, otherwise return -1.  */
266 static int
267 integral_argument (const char *arg)
268 {
269   const char *p = arg;
270
271   while (*p && ISDIGIT (*p))
272     p++;
273
274   if (*p == '\0')
275     return atoi (arg);
276
277   return -1;
278 }
279
280 /* Return a malloced slash-separated list of languages in MASK.  */
281 static char *
282 write_langs (unsigned int mask)
283 {
284   unsigned int n = 0, len = 0;
285   const char *lang_name;
286   char *result;
287
288   for (n = 0; (lang_name = lang_names[n]) != 0; n++)
289     if (mask & (1U << n))
290       len += strlen (lang_name) + 1;
291
292   result = xmalloc (len);
293   len = 0;
294   for (n = 0; (lang_name = lang_names[n]) != 0; n++)
295     if (mask & (1U << n))
296       {
297         if (len)
298           result[len++] = '/';
299         strcpy (result + len, lang_name);
300         len += strlen (lang_name);
301       }
302
303   result[len] = 0;
304
305   return result;
306 }
307
308 /* Complain that switch OPT_INDEX does not apply to this front end.  */
309 static void
310 complain_wrong_lang (const char *text, const struct cl_option *option,
311                      unsigned int lang_mask)
312 {
313   char *ok_langs, *bad_lang;
314
315   ok_langs = write_langs (option->flags);
316   bad_lang = write_langs (lang_mask);
317
318   /* Eventually this should become a hard error IMO.  */
319   warning ("command line option \"%s\" is valid for %s but not for %s",
320            text, ok_langs, bad_lang);
321
322   free (ok_langs);
323   free (bad_lang);
324 }
325
326 /* Handle the switch beginning at ARGV for the language indicated by
327    LANG_MASK.  Returns the number of switches consumed.  */
328 static unsigned int
329 handle_option (const char **argv, unsigned int lang_mask)
330 {
331   size_t opt_index;
332   const char *opt, *arg = 0;
333   char *dup = 0;
334   int value = 1;
335   unsigned int result = 0;
336   const struct cl_option *option;
337
338   opt = argv[0];
339
340   /* Drop the "no-" from negative switches.  */
341   if ((opt[1] == 'W' || opt[1] == 'f')
342       && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-')
343     {
344       size_t len = strlen (opt) - 3;
345
346       dup = xmalloc (len + 1);
347       dup[0] = '-';
348       dup[1] = opt[1];
349       memcpy (dup + 2, opt + 5, len - 2 + 1);
350       opt = dup;
351       value = 0;
352     }
353
354   opt_index = find_opt (opt + 1, lang_mask | CL_COMMON);
355   if (opt_index == cl_options_count)
356     goto done;
357
358   option = &cl_options[opt_index];
359
360   /* Reject negative form of switches that don't take negatives as
361      unrecognized.  */
362   if (!value && (option->flags & CL_REJECT_NEGATIVE))
363     goto done;
364
365   /* We've recognized this switch.  */
366   result = 1;
367
368   /* Sort out any argument the switch takes.  */
369   if (option->flags & CL_JOINED)
370     {
371       /* Have arg point to the original switch.  This is because
372          some code, such as disable_builtin_function, expects its
373          argument to be persistent until the program exits.  */
374       arg = argv[0] + cl_options[opt_index].opt_len + 1;
375       if (!value)
376         arg += strlen ("no-");
377
378       if (*arg == '\0' && !(option->flags & CL_MISSING_OK))
379         {
380           if (option->flags & CL_SEPARATE)
381             {
382               arg = argv[1];
383               result = 2;
384             }
385           else
386             /* Missing argument.  */
387             arg = NULL;
388         }
389     }
390   else if (option->flags & CL_SEPARATE)
391     {
392       arg = argv[1];
393       result = 2;
394     }
395
396   /* Now we've swallowed any potential argument, complain if this
397      is a switch for a different front end.  */
398   if (!(option->flags & (lang_mask | CL_COMMON)))
399     {
400       complain_wrong_lang (argv[0], option, lang_mask);
401       goto done;
402     }
403
404   if (arg == NULL && (option->flags & (CL_JOINED | CL_SEPARATE)))
405     {
406       if (!(*lang_hooks.missing_argument) (opt, opt_index))
407         error ("missing argument to \"%s\"", opt);
408       goto done;
409     }
410
411   /* If the switch takes an integer, convert it.  */
412   if (arg && (option->flags & CL_UINTEGER))
413     {
414       value = integral_argument (arg);
415       if (value == -1)
416         {
417           error ("argument to \"%s\" should be a non-negative integer",
418                  option->opt_text);
419           goto done;
420         }
421     }
422
423   if (option->flags & lang_mask)
424     if ((*lang_hooks.handle_option) (opt_index, arg, value) == 0)
425       result = 0;
426
427   if (result && (option->flags & CL_COMMON))
428     if (common_handle_option (opt_index, arg, value) == 0)
429       result = 0;
430
431  done:
432   if (dup)
433     free (dup);
434   return result;
435 }
436
437 /* Decode and handle the vector of command line options.  LANG_MASK
438    contains has a single bit set representing the current
439    language.  */
440 static void
441 handle_options (unsigned int argc, const char **argv, unsigned int lang_mask)
442 {
443   unsigned int n, i;
444
445   for (i = 1; i < argc; i += n)
446     {
447       const char *opt = argv[i];
448
449       /* Interpret "-" or a non-switch as a file name.  */
450       if (opt[0] != '-' || opt[1] == '\0')
451         {
452           if (main_input_filename == NULL)
453             main_input_filename = opt;
454           add_input_filename (opt);
455           n = 1;
456           continue;
457         }
458
459       n = handle_option (argv + i, lang_mask);
460
461       if (!n)
462         {
463           n = 1;
464           error ("unrecognized command line option \"%s\"", opt);
465         }
466     }
467 }
468
469 /* Handle FILENAME from the command line.  */
470 void
471 add_input_filename (const char *filename)
472 {
473   num_in_fnames++;
474   in_fnames = xrealloc (in_fnames, num_in_fnames * sizeof (in_fnames[0]));
475   in_fnames[num_in_fnames - 1] = filename;
476 }
477
478 /* Parse command line options and set default flag values.  Do minimal
479    options processing.  */
480 void
481 decode_options (unsigned int argc, const char **argv)
482 {
483   unsigned int i, lang_mask;
484
485   /* Perform language-specific options initialization.  */
486   lang_mask = (*lang_hooks.init_options) (argc, argv);
487
488   lang_hooks.initialize_diagnostics (global_dc);
489
490   /* Scan to see what optimization level has been specified.  That will
491      determine the default value of many flags.  */
492   for (i = 1; i < argc; i++)
493     {
494       if (!strcmp (argv[i], "-O"))
495         {
496           optimize = 1;
497           optimize_size = 0;
498         }
499       else if (argv[i][0] == '-' && argv[i][1] == 'O')
500         {
501           /* Handle -Os, -O2, -O3, -O69, ...  */
502           const char *p = &argv[i][2];
503
504           if ((p[0] == 's') && (p[1] == 0))
505             {
506               optimize_size = 1;
507
508               /* Optimizing for size forces optimize to be 2.  */
509               optimize = 2;
510             }
511           else
512             {
513               const int optimize_val = read_integral_parameter (p, p - 2, -1);
514               if (optimize_val != -1)
515                 {
516                   optimize = optimize_val;
517                   optimize_size = 0;
518                 }
519             }
520         }
521     }
522
523   if (!optimize)
524     {
525       flag_merge_constants = 0;
526     }
527
528   if (optimize >= 1)
529     {
530       flag_defer_pop = 1;
531       flag_thread_jumps = 1;
532 #ifdef DELAY_SLOTS
533       flag_delayed_branch = 1;
534 #endif
535 #ifdef CAN_DEBUG_WITHOUT_FP
536       flag_omit_frame_pointer = 1;
537 #endif
538       flag_guess_branch_prob = 1;
539       flag_cprop_registers = 1;
540       flag_loop_optimize = 1;
541       flag_if_conversion = 1;
542       flag_if_conversion2 = 1;
543     }
544
545   if (optimize >= 2)
546     {
547       flag_crossjumping = 1;
548       flag_optimize_sibling_calls = 1;
549       flag_cse_follow_jumps = 1;
550       flag_cse_skip_blocks = 1;
551       flag_gcse = 1;
552       flag_expensive_optimizations = 1;
553       flag_strength_reduce = 1;
554       flag_rerun_cse_after_loop = 1;
555       flag_rerun_loop_opt = 1;
556       flag_caller_saves = 1;
557       flag_force_mem = 1;
558       flag_peephole2 = 1;
559 #ifdef INSN_SCHEDULING
560       flag_schedule_insns = 1;
561       flag_schedule_insns_after_reload = 1;
562 #endif
563       flag_regmove = 1;
564       flag_strict_aliasing = 1;
565       flag_delete_null_pointer_checks = 1;
566       flag_reorder_blocks = 1;
567       flag_reorder_functions = 1;
568       flag_unit_at_a_time = 1;
569     }
570
571   if (optimize >= 3)
572     {
573       flag_inline_functions = 1;
574       flag_rename_registers = 1;
575       flag_unswitch_loops = 1;
576       flag_web = 1;
577     }
578
579   if (optimize < 2 || optimize_size)
580     {
581       align_loops = 1;
582       align_jumps = 1;
583       align_labels = 1;
584       align_functions = 1;
585
586       /* Don't reorder blocks when optimizing for size because extra
587          jump insns may be created; also barrier may create extra padding.
588
589          More correctly we should have a block reordering mode that tried
590          to minimize the combined size of all the jumps.  This would more
591          or less automatically remove extra jumps, but would also try to
592          use more short jumps instead of long jumps.  */
593       flag_reorder_blocks = 0;
594     }
595
596   /* Initialize whether `char' is signed.  */
597   flag_signed_char = DEFAULT_SIGNED_CHAR;
598   /* Initialize how much space enums occupy, by default.  */
599   flag_short_enums = targetm.default_short_enums ();
600
601   /* Initialize target_flags before OPTIMIZATION_OPTIONS so the latter can
602      modify it.  */
603   target_flags = 0;
604   set_target_switch ("");
605
606   /* Unwind tables are always present in an ABI-conformant IA-64
607      object file, so the default should be ON.  */
608 #ifdef IA64_UNWIND_INFO
609   flag_unwind_tables = IA64_UNWIND_INFO;
610 #endif
611
612 #ifdef OPTIMIZATION_OPTIONS
613   /* Allow default optimizations to be specified on a per-machine basis.  */
614   OPTIMIZATION_OPTIONS (optimize, optimize_size);
615 #endif
616
617   handle_options (argc, argv, lang_mask);
618
619   if (flag_pie)
620     flag_pic = flag_pie;
621   if (flag_pic && !flag_pie)
622     flag_shlib = 1;
623
624   if (flag_no_inline == 2)
625     flag_no_inline = 0;
626   else
627     flag_really_no_inline = flag_no_inline;
628
629   /* Set flag_no_inline before the post_options () hook.  The C front
630      ends use it to determine tree inlining defaults.  FIXME: such
631      code should be lang-independent when all front ends use tree
632      inlining, in which case it, and this condition, should be moved
633      to the top of process_options() instead.  */
634   if (optimize == 0)
635     {
636       /* Inlining does not work if not optimizing,
637          so force it not to be done.  */
638       flag_no_inline = 1;
639       warn_inline = 0;
640
641       /* The c_decode_option function and decode_option hook set
642          this to `2' if -Wall is used, so we can avoid giving out
643          lots of errors for people who don't realize what -Wall does.  */
644       if (warn_uninitialized == 1)
645         warning ("-Wuninitialized is not supported without -O");
646     }
647
648   if (flag_really_no_inline == 2)
649     flag_really_no_inline = flag_no_inline;
650 }
651
652 /* Handle target- and language-independent options.  Return zero to
653    generate an "unknown option" message.  */
654 static int
655 common_handle_option (size_t scode, const char *arg,
656                       int value ATTRIBUTE_UNUSED)
657 {
658   enum opt_code code = (enum opt_code) scode;
659
660   switch (code)
661     {
662     default:
663       abort ();
664
665     case OPT__help:
666       print_help ();
667       exit_after_options = true;
668       break;
669
670     case OPT__param:
671       handle_param (arg);
672       break;
673
674     case OPT__target_help:
675       display_target_options ();
676       exit_after_options = true;
677       break;
678
679     case OPT__version:
680       print_version (stderr, "");
681       exit_after_options = true;
682       break;
683
684     case OPT_G:
685       g_switch_value = value;
686       g_switch_set = true;
687       break;
688
689     case OPT_O:
690     case OPT_Os:
691       /* Currently handled in a prescan.  */
692       break;
693
694     case OPT_W:
695       /* For backward compatibility, -W is the same as -Wextra.  */
696       set_Wextra (value);
697       break;
698
699     case OPT_Waggregate_return:
700       warn_aggregate_return = value;
701       break;
702
703     case OPT_Wcast_align:
704       warn_cast_align = value;
705       break;
706
707     case OPT_Wdeprecated_declarations:
708       warn_deprecated_decl = value;
709       break;
710
711     case OPT_Wdisabled_optimization:
712       warn_disabled_optimization = value;
713       break;
714
715     case OPT_Werror:
716       warnings_are_errors = value;
717       break;
718
719     case OPT_Wextra:
720       set_Wextra (value);
721       break;
722
723     case OPT_Winline:
724       warn_inline = value;
725       break;
726
727     case OPT_Wlarger_than_:
728       larger_than_size = value;
729       warn_larger_than = value != -1;
730       break;
731
732     case OPT_Wmissing_noreturn:
733       warn_missing_noreturn = value;
734       break;
735
736     case OPT_Wpacked:
737       warn_packed = value;
738       break;
739
740     case OPT_Wpadded:
741       warn_padded = value;
742       break;
743
744     case OPT_Wshadow:
745       warn_shadow = value;
746       break;
747
748     case OPT_Wstrict_aliasing:
749       warn_strict_aliasing = value;
750       break;
751
752     case OPT_Wswitch:
753       warn_switch = value;
754       break;
755
756     case OPT_Wswitch_default:
757       warn_switch_default = value;
758       break;
759
760     case OPT_Wswitch_enum:
761       warn_switch_enum = value;
762       break;
763
764     case OPT_Wsystem_headers:
765       warn_system_headers = value;
766       break;
767
768     case OPT_Wuninitialized:
769       warn_uninitialized = value;
770       break;
771
772     case OPT_Wunreachable_code:
773       warn_notreached = value;
774       break;
775
776     case OPT_Wunused:
777       set_Wunused (value);
778       break;
779
780     case OPT_Wunused_function:
781       warn_unused_function = value;
782       break;
783
784     case OPT_Wunused_label:
785       warn_unused_label = value;
786       break;
787
788     case OPT_Wunused_parameter:
789       warn_unused_parameter = value;
790       break;
791
792     case OPT_Wunused_value:
793       warn_unused_value = value;
794       break;
795
796     case OPT_Wunused_variable:
797       warn_unused_variable = value;
798       break;
799
800     case OPT_aux_info:
801     case OPT_aux_info_:
802       aux_info_file_name = arg;
803       flag_gen_aux_info = 1;
804       break;
805
806     case OPT_auxbase:
807       aux_base_name = arg;
808       break;
809
810     case OPT_auxbase_strip:
811       {
812         char *tmp = xstrdup (arg);
813         strip_off_ending (tmp, strlen (tmp));
814         if (tmp[0])
815           aux_base_name = tmp;
816       }
817       break;
818
819     case OPT_d:
820       decode_d_option (arg);
821       break;
822
823     case OPT_dumpbase:
824       dump_base_name = arg;
825       break;
826
827     case OPT_fPIC:
828       flag_pic = value + value;
829       break;
830
831     case OPT_fPIE:
832       flag_pie = value + value;
833       break;
834
835     case OPT_fabi_version_:
836       flag_abi_version = value;
837       break;
838
839     case OPT_falign_functions:
840       align_functions = !value;
841       break;
842
843     case OPT_falign_functions_:
844       align_functions = value;
845       break;
846
847     case OPT_falign_jumps:
848       align_jumps = !value;
849       break;
850
851     case OPT_falign_jumps_:
852       align_jumps = value;
853       break;
854
855     case OPT_falign_labels:
856       align_labels = !value;
857       break;
858
859     case OPT_falign_labels_:
860       align_labels = value;
861       break;
862
863     case OPT_falign_loops:
864       align_loops = !value;
865       break;
866
867     case OPT_falign_loops_:
868       align_loops = value;
869       break;
870
871     case OPT_fargument_alias:
872       flag_argument_noalias = !value;
873       break;
874
875     case OPT_fargument_noalias:
876       flag_argument_noalias = value;
877       break;
878
879     case OPT_fargument_noalias_global:
880       flag_argument_noalias = value + value;
881       break;
882
883     case OPT_fasynchronous_unwind_tables:
884       flag_asynchronous_unwind_tables = value;
885       break;
886
887     case OPT_fbounds_check:
888       flag_bounds_check = value;
889       break;
890
891     case OPT_fbranch_count_reg:
892       flag_branch_on_count_reg = value;
893       break;
894
895     case OPT_fbranch_probabilities:
896       flag_branch_probabilities_set = true;
897       flag_branch_probabilities = value;
898       break;
899
900     case OPT_fbranch_target_load_optimize:
901       flag_branch_target_load_optimize = value;
902       break;
903
904     case OPT_fbranch_target_load_optimize2:
905       flag_branch_target_load_optimize2 = value;
906       break;
907
908     case OPT_fbtr_bb_exclusive:
909       flag_btr_bb_exclusive = value;
910       break;
911
912     case OPT_fcall_used_:
913       fix_register (arg, 0, 1);
914       break;
915
916     case OPT_fcall_saved_:
917       fix_register (arg, 0, 0);
918       break;
919
920     case OPT_fcaller_saves:
921       flag_caller_saves = value;
922       break;
923
924     case OPT_fcommon:
925       flag_no_common = !value;
926       break;
927
928     case OPT_fcprop_registers:
929       flag_cprop_registers = value;
930       break;
931
932     case OPT_fcrossjumping:
933       flag_crossjumping = value;
934       break;
935
936     case OPT_fcse_follow_jumps:
937       flag_cse_follow_jumps = value;
938       break;
939
940     case OPT_fcse_skip_blocks:
941       flag_cse_skip_blocks = value;
942       break;
943
944     case OPT_fdata_sections:
945       flag_data_sections = value;
946       break;
947
948     case OPT_fdefer_pop:
949       flag_defer_pop = value;
950       break;
951
952     case OPT_fdelayed_branch:
953       flag_delayed_branch = value;
954       break;
955
956     case OPT_fdelete_null_pointer_checks:
957       flag_delete_null_pointer_checks = value;
958       break;
959
960     case OPT_fdiagnostics_show_location_:
961       if (!strcmp (arg, "once"))
962         diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
963       else if (!strcmp (arg, "every-line"))
964         diagnostic_prefixing_rule (global_dc)
965           = DIAGNOSTICS_SHOW_PREFIX_EVERY_LINE;
966       else
967         return 0;
968       break;
969
970     case OPT_fdump_unnumbered:
971       flag_dump_unnumbered = value;
972       break;
973
974     case OPT_feliminate_dwarf2_dups:
975       flag_eliminate_dwarf2_dups = value;
976       break;
977
978     case OPT_feliminate_unused_debug_types:
979       flag_eliminate_unused_debug_types = value;
980       break;
981
982     case OPT_feliminate_unused_debug_symbols:
983       flag_debug_only_used_symbols = value;
984       break;
985
986     case OPT_fexceptions:
987       flag_exceptions = value;
988       break;
989
990     case OPT_fexpensive_optimizations:
991       flag_expensive_optimizations = value;
992       break;
993
994     case OPT_ffast_math:
995       set_fast_math_flags (value);
996       break;
997
998     case OPT_ffinite_math_only:
999       flag_finite_math_only = value;
1000       break;
1001
1002     case OPT_ffixed_:
1003       fix_register (arg, 1, 1);
1004       break;
1005
1006     case OPT_ffunction_cse:
1007       flag_no_function_cse = !value;
1008       break;
1009
1010     case OPT_ffloat_store:
1011       flag_float_store = value;
1012       break;
1013
1014     case OPT_fforce_addr:
1015       flag_force_addr = value;
1016       break;
1017
1018     case OPT_fforce_mem:
1019       flag_force_mem = value;
1020       break;
1021
1022     case OPT_ffunction_sections:
1023       flag_function_sections = value;
1024       break;
1025
1026     case OPT_fgcse:
1027       flag_gcse = value;
1028       break;
1029
1030     case OPT_fgcse_lm:
1031       flag_gcse_lm = value;
1032       break;
1033
1034     case OPT_fgcse_sm:
1035       flag_gcse_sm = value;
1036       break;
1037
1038     case OPT_fgcse_las:
1039       flag_gcse_las = value;
1040       break;
1041
1042     case OPT_fguess_branch_probability:
1043       flag_guess_branch_prob = value;
1044       break;
1045
1046     case OPT_fident:
1047       flag_no_ident = !value;
1048       break;
1049
1050     case OPT_fif_conversion:
1051       flag_if_conversion = value;
1052       break;
1053
1054     case OPT_fif_conversion2:
1055       flag_if_conversion2 = value;
1056       break;
1057
1058     case OPT_finhibit_size_directive:
1059       flag_inhibit_size_directive = value;
1060       break;
1061
1062     case OPT_finline:
1063       flag_no_inline = !value;
1064       break;
1065
1066     case OPT_finline_functions:
1067       flag_inline_functions = value;
1068       break;
1069
1070     case OPT_finline_limit_:
1071     case OPT_finline_limit_eq:
1072       set_param_value ("max-inline-insns-single", value / 2);
1073       set_param_value ("max-inline-insns-auto", value / 2);
1074       set_param_value ("max-inline-insns-rtl", value);
1075       break;
1076
1077     case OPT_finstrument_functions:
1078       flag_instrument_function_entry_exit = value;
1079       break;
1080
1081     case OPT_fkeep_inline_functions:
1082       flag_keep_inline_functions =value;
1083       break;
1084
1085     case OPT_fkeep_static_consts:
1086       flag_keep_static_consts = value;
1087       break;
1088
1089     case OPT_fleading_underscore:
1090       flag_leading_underscore = value;
1091       break;
1092
1093     case OPT_floop_optimize:
1094       flag_loop_optimize = value;
1095       break;
1096
1097     case OPT_fmath_errno:
1098       flag_errno_math = value;
1099       break;
1100
1101     case OPT_fmem_report:
1102       mem_report = value;
1103       break;
1104
1105     case OPT_fmerge_all_constants:
1106       flag_merge_constants = value + value;
1107       break;
1108
1109     case OPT_fmerge_constants:
1110       flag_merge_constants = value;
1111       break;
1112
1113     case OPT_fmessage_length_:
1114       pp_set_line_maximum_length (global_dc->printer, value);
1115       break;
1116
1117     case OPT_fmove_all_movables:
1118       flag_move_all_movables = value;
1119       break;
1120
1121     case OPT_fnew_ra:
1122       flag_new_regalloc = value;
1123       break;
1124
1125     case OPT_fnon_call_exceptions:
1126       flag_non_call_exceptions = value;
1127       break;
1128
1129     case OPT_fold_unroll_all_loops:
1130       flag_old_unroll_all_loops = value;
1131       break;
1132
1133     case OPT_fold_unroll_loops:
1134       flag_old_unroll_loops = value;
1135       break;
1136
1137     case OPT_fomit_frame_pointer:
1138       flag_omit_frame_pointer = value;
1139       break;
1140
1141     case OPT_foptimize_register_move:
1142       flag_regmove = value;
1143       break;
1144
1145     case OPT_foptimize_sibling_calls:
1146       flag_optimize_sibling_calls = value;
1147       break;
1148
1149     case OPT_fpack_struct:
1150       flag_pack_struct = value;
1151       break;
1152
1153     case OPT_fpeel_loops:
1154       flag_peel_loops_set = true;
1155       flag_peel_loops = value;
1156       break;
1157
1158     case OPT_fpcc_struct_return:
1159       flag_pcc_struct_return = value;
1160       break;
1161
1162     case OPT_fpeephole:
1163       flag_no_peephole = !value;
1164       break;
1165
1166     case OPT_fpeephole2:
1167       flag_peephole2 = value;
1168       break;
1169
1170     case OPT_fpic:
1171       flag_pic = value;
1172       break;
1173
1174     case OPT_fpie:
1175       flag_pie = value;
1176       break;
1177
1178     case OPT_fprefetch_loop_arrays:
1179       flag_prefetch_loop_arrays = value;
1180       break;
1181
1182     case OPT_fprofile:
1183       profile_flag = value;
1184       break;
1185
1186     case OPT_fprofile_arcs:
1187       profile_arc_flag_set = true;
1188       profile_arc_flag = value;
1189       break;
1190
1191     case OPT_fprofile_use:
1192       if (!flag_branch_probabilities_set)
1193         flag_branch_probabilities = value;
1194       if (!flag_profile_values_set)
1195         flag_profile_values = value;
1196       if (!flag_unroll_loops_set)
1197         flag_unroll_loops = value;
1198       if (!flag_peel_loops_set)
1199         flag_peel_loops = value;
1200       if (!flag_tracer_set)
1201         flag_tracer = value;
1202       if (!flag_value_profile_transformations_set)
1203         flag_value_profile_transformations = value;
1204       break;
1205
1206     case OPT_fprofile_generate:
1207       if (!profile_arc_flag_set)
1208         profile_arc_flag = value;
1209       if (!flag_profile_values_set)
1210         flag_profile_values = value;
1211       if (!flag_value_profile_transformations_set)
1212         flag_value_profile_transformations = value;
1213       break;
1214
1215     case OPT_fprofile_values:
1216       flag_profile_values_set = true;
1217       flag_profile_values = value;
1218       break;
1219
1220     case OPT_fvpt:
1221       flag_value_profile_transformations_set = value;
1222       flag_value_profile_transformations = value;
1223       break;
1224
1225     case OPT_frandom_seed:
1226       /* The real switch is -fno-random-seed.  */
1227       if (value)
1228         return 0;
1229       flag_random_seed = NULL;
1230       break;
1231
1232     case OPT_frandom_seed_:
1233       flag_random_seed = arg;
1234       break;
1235
1236     case OPT_freduce_all_givs:
1237       flag_reduce_all_givs = value;
1238       break;
1239
1240     case OPT_freg_struct_return:
1241       flag_pcc_struct_return = !value;
1242       break;
1243
1244     case OPT_fregmove:
1245       flag_regmove = value;
1246       break;
1247
1248     case OPT_frename_registers:
1249       flag_rename_registers = value;
1250       break;
1251
1252     case OPT_freorder_blocks:
1253       flag_reorder_blocks = value;
1254       break;
1255
1256     case OPT_freorder_functions:
1257       flag_reorder_functions = value;
1258       break;
1259
1260     case OPT_frerun_cse_after_loop:
1261       flag_rerun_cse_after_loop = value;
1262       break;
1263
1264     case OPT_frerun_loop_opt:
1265       flag_rerun_loop_opt = value;
1266       break;
1267
1268     case OPT_frounding_math:
1269       flag_rounding_math = value;
1270       break;
1271
1272     case OPT_fsched_interblock:
1273       flag_schedule_interblock = value;
1274       break;
1275
1276     case OPT_fsched_spec:
1277       flag_schedule_speculative = value;
1278       break;
1279
1280     case OPT_fsched_spec_load:
1281       flag_schedule_speculative_load = value;
1282       break;
1283
1284     case OPT_fsched_spec_load_dangerous:
1285       flag_schedule_speculative_load_dangerous = value;
1286       break;
1287
1288     case OPT_fsched_verbose_:
1289 #ifdef INSN_SCHEDULING
1290       fix_sched_param ("verbose", arg);
1291       break;
1292 #else
1293       return 0;
1294 #endif
1295
1296     case OPT_fsched2_use_superblocks:
1297       flag_sched2_use_superblocks = value;
1298       break;
1299
1300     case OPT_fsched2_use_traces:
1301       flag_sched2_use_traces = value;
1302       break;
1303
1304     case OPT_fschedule_insns:
1305       flag_schedule_insns = value;
1306       break;
1307
1308     case OPT_fschedule_insns2:
1309       flag_schedule_insns_after_reload = value;
1310       break;
1311
1312     case OPT_fsched_stalled_insns:
1313       flag_sched_stalled_insns = value;
1314       break;
1315
1316     case OPT_fsched_stalled_insns_:
1317       flag_sched_stalled_insns = value;
1318       if (flag_sched_stalled_insns == 0)
1319         flag_sched_stalled_insns = -1;
1320       break;
1321
1322     case OPT_fsched_stalled_insns_dep:
1323       flag_sched_stalled_insns_dep = 1;
1324       break;
1325
1326     case OPT_fsched_stalled_insns_dep_:
1327       flag_sched_stalled_insns_dep = value;
1328       break;
1329
1330     case OPT_fshared_data:
1331       flag_shared_data = value;
1332       break;
1333
1334     case OPT_fsignaling_nans:
1335       flag_signaling_nans = value;
1336       break;
1337
1338     case OPT_fsingle_precision_constant:
1339       flag_single_precision_constant = value;
1340       break;
1341
1342     case OPT_fstack_check:
1343       flag_stack_check = value;
1344       break;
1345
1346     case OPT_fstack_limit:
1347       /* The real switch is -fno-stack-limit.  */
1348       if (value)
1349         return 0;
1350       stack_limit_rtx = NULL_RTX;
1351       break;
1352
1353     case OPT_fstack_limit_register_:
1354       {
1355         int reg = decode_reg_name (arg);
1356         if (reg < 0)
1357           error ("unrecognized register name \"%s\"", arg);
1358         else
1359           stack_limit_rtx = gen_rtx_REG (Pmode, reg);
1360       }
1361       break;
1362
1363     case OPT_fstack_limit_symbol_:
1364       stack_limit_rtx = gen_rtx_SYMBOL_REF (Pmode, ggc_strdup (arg));
1365       break;
1366
1367     case OPT_fstrength_reduce:
1368       flag_strength_reduce = value;
1369       break;
1370
1371     case OPT_fstrict_aliasing:
1372       flag_strict_aliasing = value;
1373       break;
1374
1375     case OPT_fsyntax_only:
1376       flag_syntax_only = value;
1377       break;
1378
1379     case OPT_ftest_coverage:
1380       flag_test_coverage = value;
1381       break;
1382
1383     case OPT_fthread_jumps:
1384       flag_thread_jumps = value;
1385       break;
1386
1387     case OPT_ftime_report:
1388       time_report = value;
1389       break;
1390
1391     case OPT_ftls_model_:
1392       if (!strcmp (arg, "global-dynamic"))
1393         flag_tls_default = TLS_MODEL_GLOBAL_DYNAMIC;
1394       else if (!strcmp (arg, "local-dynamic"))
1395         flag_tls_default = TLS_MODEL_LOCAL_DYNAMIC;
1396       else if (!strcmp (arg, "initial-exec"))
1397         flag_tls_default = TLS_MODEL_INITIAL_EXEC;
1398       else if (!strcmp (arg, "local-exec"))
1399         flag_tls_default = TLS_MODEL_LOCAL_EXEC;
1400       else
1401         warning ("unknown tls-model \"%s\"", arg);
1402       break;
1403
1404     case OPT_ftracer:
1405       flag_tracer_set = true;
1406       flag_tracer = value;
1407       break;
1408
1409     case OPT_ftrapping_math:
1410       flag_trapping_math = value;
1411       break;
1412
1413     case OPT_ftrapv:
1414       flag_trapv = value;
1415       break;
1416
1417     case OPT_funit_at_a_time:
1418       flag_unit_at_a_time = value;
1419       break;
1420
1421     case OPT_funroll_all_loops:
1422       flag_unroll_all_loops = value;
1423       break;
1424
1425     case OPT_funroll_loops:
1426       flag_unroll_loops_set = true;
1427       flag_unroll_loops = value;
1428       break;
1429
1430     case OPT_funsafe_math_optimizations:
1431       flag_unsafe_math_optimizations = value;
1432       break;
1433
1434     case OPT_funswitch_loops:
1435       flag_unswitch_loops = value;
1436       break;
1437
1438     case OPT_funwind_tables:
1439       flag_unwind_tables = value;
1440       break;
1441
1442     case OPT_fvar_tracking:
1443       flag_var_tracking = value;
1444       break;
1445
1446     case OPT_fverbose_asm:
1447       flag_verbose_asm = value;
1448       break;
1449
1450     case OPT_fweb:
1451       flag_web = value;
1452       break;
1453       
1454     case OPT_fwrapv:
1455       flag_wrapv = value;
1456       break;
1457
1458     case OPT_fwritable_strings:
1459       flag_writable_strings = value;
1460       break;
1461
1462     case OPT_fzero_initialized_in_bss:
1463       flag_zero_initialized_in_bss = value;
1464       break;
1465
1466     case OPT_g:
1467       set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg);
1468       break;
1469
1470     case OPT_gcoff:
1471       set_debug_level (SDB_DEBUG, false, arg);
1472       break;
1473
1474     case OPT_gdwarf_2:
1475       set_debug_level (DWARF2_DEBUG, false, arg);
1476       break;
1477
1478     case OPT_ggdb:
1479       set_debug_level (NO_DEBUG, 2, arg);
1480       break;
1481
1482     case OPT_gstabs:
1483     case OPT_gstabs_:
1484       set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg);
1485       break;
1486
1487     case OPT_gvms:
1488       set_debug_level (VMS_DEBUG, false, arg);
1489       break;
1490
1491     case OPT_gxcoff:
1492     case OPT_gxcoff_:
1493       set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg);
1494       break;
1495
1496     case OPT_m:
1497       set_target_switch (arg);
1498       break;
1499
1500     case OPT_o:
1501       asm_file_name = arg;
1502       break;
1503
1504     case OPT_p:
1505       profile_flag = 1;
1506       break;
1507
1508     case OPT_pedantic:
1509       pedantic = 1;
1510       break;
1511
1512     case OPT_pedantic_errors:
1513       flag_pedantic_errors = pedantic = 1;
1514       break;
1515
1516     case OPT_quiet:
1517       quiet_flag = 1;
1518       break;
1519
1520     case OPT_version:
1521       version_flag = 1;
1522       break;
1523
1524     case OPT_w:
1525       inhibit_warnings = true;
1526       break;      
1527     }
1528
1529   return 1;
1530 }
1531
1532 /* Handle --param NAME=VALUE.  */
1533 static void
1534 handle_param (const char *carg)
1535 {
1536   char *equal, *arg;
1537   int value;
1538
1539   arg = xstrdup (carg);
1540   equal = strchr (arg, '=');
1541   if (!equal)
1542     error ("%s: --param arguments should be of the form NAME=VALUE", arg);
1543   else
1544     {
1545       value = integral_argument (equal + 1);
1546       if (value == -1)
1547         error ("invalid --param value `%s'", equal + 1);
1548       else
1549         {
1550           *equal = '\0';
1551           set_param_value (arg, value);
1552         }
1553     }
1554
1555   free (arg);
1556 }
1557
1558 /* Handle -W and -Wextra.  */
1559 static void
1560 set_Wextra (int setting)
1561 {
1562   extra_warnings = setting;
1563   warn_unused_value = setting;
1564   warn_unused_parameter = (setting && maybe_warn_unused_parameter);
1565
1566   /* We save the value of warn_uninitialized, since if they put
1567      -Wuninitialized on the command line, we need to generate a
1568      warning about not using it without also specifying -O.  */
1569   if (setting == 0)
1570     warn_uninitialized = 0;
1571   else if (warn_uninitialized != 1)
1572     warn_uninitialized = 2;
1573 }
1574
1575 /* Initialize unused warning flags.  */
1576 void
1577 set_Wunused (int setting)
1578 {
1579   warn_unused_function = setting;
1580   warn_unused_label = setting;
1581   /* Unused function parameter warnings are reported when either
1582      ``-Wextra -Wunused'' or ``-Wunused-parameter'' is specified.
1583      Thus, if -Wextra has already been seen, set warn_unused_parameter;
1584      otherwise set maybe_warn_extra_parameter, which will be picked up
1585      by set_Wextra.  */
1586   maybe_warn_unused_parameter = setting;
1587   warn_unused_parameter = (setting && extra_warnings);
1588   warn_unused_variable = setting;
1589   warn_unused_value = setting;
1590 }
1591
1592 /* The following routines are useful in setting all the flags that
1593    -ffast-math and -fno-fast-math imply.  */
1594 void
1595 set_fast_math_flags (int set)
1596 {
1597   flag_trapping_math = !set;
1598   flag_unsafe_math_optimizations = set;
1599   flag_finite_math_only = set;
1600   flag_errno_math = !set;
1601   if (set)
1602     {
1603       flag_signaling_nans = 0;
1604       flag_rounding_math = 0;
1605     }
1606 }
1607
1608 /* Return true iff flags are set as if -ffast-math.  */
1609 bool
1610 fast_math_flags_set_p (void)
1611 {
1612   return (!flag_trapping_math
1613           && flag_unsafe_math_optimizations
1614           && flag_finite_math_only
1615           && !flag_errno_math);
1616 }
1617
1618 /* Handle a debug output -g switch.  EXTENDED is true or false to support
1619    extended output (2 is special and means "-ggdb" was given).  */
1620 static void
1621 set_debug_level (enum debug_info_type type, int extended, const char *arg)
1622 {
1623   static bool type_explicit;
1624
1625   use_gnu_debug_info_extensions = extended;
1626
1627   if (type == NO_DEBUG)
1628     {
1629       if (write_symbols == NO_DEBUG)
1630         {
1631           write_symbols = PREFERRED_DEBUGGING_TYPE;
1632
1633           if (extended == 2)
1634             {
1635 #ifdef DWARF2_DEBUGGING_INFO
1636               write_symbols = DWARF2_DEBUG;
1637 #elif defined DBX_DEBUGGING_INFO
1638               write_symbols = DBX_DEBUG;
1639 #endif
1640             }
1641
1642           if (write_symbols == NO_DEBUG)
1643             warning ("target system does not support debug output");
1644         }
1645     }
1646   else
1647     {
1648       /* Does it conflict with an already selected type?  */
1649       if (type_explicit && write_symbols != NO_DEBUG && type != write_symbols)
1650         error ("debug format \"%s\" conflicts with prior selection",
1651                debug_type_names[type]);
1652       write_symbols = type;
1653       type_explicit = true;
1654     }
1655
1656   /* A debug flag without a level defaults to level 2.  */
1657   if (*arg == '\0')
1658     {
1659       if (!debug_info_level)
1660         debug_info_level = 2;
1661     }
1662   else
1663     {
1664       debug_info_level = integral_argument (arg);
1665       if (debug_info_level == (unsigned int) -1)
1666         error ("unrecognised debug output level \"%s\"", arg);
1667       else if (debug_info_level > 3)
1668         error ("debug output level %s is too high", arg);
1669     }
1670 }
1671
1672 /* Output --help text.  */
1673 static void
1674 print_help (void)
1675 {
1676   size_t i;
1677   const char *p;
1678
1679   GET_ENVIRONMENT (p, "COLUMNS");
1680   if (p)
1681     {
1682       int value = atoi (p);
1683       if (value > 0)
1684         columns = value;
1685     }
1686
1687   puts (_("The following options are language-independent:\n"));
1688
1689   print_filtered_help (CL_COMMON);
1690   print_param_help ();
1691
1692   for (i = 0; lang_names[i]; i++)
1693     {
1694       printf (_("The %s front end recognizes the following options:\n\n"),
1695               lang_names[i]);
1696       print_filtered_help (1U << i);
1697     }
1698
1699   display_target_options ();
1700 }
1701
1702 /* Print the help for --param.  */
1703 static void
1704 print_param_help (void)
1705 {
1706   size_t i;
1707
1708   puts (_("The --param option recognizes the following as parameters:\n"));
1709
1710   for (i = 0; i < LAST_PARAM; i++)
1711     {
1712       const char *help = compiler_params[i].help;
1713       const char *param = compiler_params[i].option;
1714
1715       if (help == NULL || *help == '\0')
1716         help = undocumented_msg;
1717
1718       /* Get the translation.  */
1719       help = _(help);
1720
1721       wrap_help (help, param, strlen (param));
1722     }
1723
1724   putchar ('\n');
1725 }
1726
1727 /* Print help for a specific front-end, etc.  */
1728 static void
1729 print_filtered_help (unsigned int flag)
1730 {
1731   unsigned int i, len, filter, indent = 0;
1732   bool duplicates = false;
1733   const char *help, *opt, *tab;
1734   static char *printed;
1735
1736   if (flag == CL_COMMON)
1737     {
1738       filter = flag;
1739       if (!printed)
1740         printed = xmalloc (cl_options_count);
1741       memset (printed, 0, cl_options_count);
1742     }
1743   else
1744     {
1745       /* Don't print COMMON options twice.  */
1746       filter = flag | CL_COMMON;
1747
1748       for (i = 0; i < cl_options_count; i++)
1749         {
1750           if ((cl_options[i].flags & filter) != flag)
1751             continue;
1752
1753           /* Skip help for internal switches.  */
1754           if (cl_options[i].flags & CL_UNDOCUMENTED)
1755             continue;
1756
1757           /* Skip switches that have already been printed, mark them to be
1758              listed later.  */
1759           if (printed[i])
1760             {
1761               duplicates = true;
1762               indent = print_switch (cl_options[i].opt_text, indent);
1763             }
1764         }
1765
1766       if (duplicates)
1767         {
1768           putchar ('\n');
1769           putchar ('\n');
1770         }
1771     }
1772
1773   for (i = 0; i < cl_options_count; i++)
1774     {
1775       if ((cl_options[i].flags & filter) != flag)
1776         continue;
1777
1778       /* Skip help for internal switches.  */
1779       if (cl_options[i].flags & CL_UNDOCUMENTED)
1780         continue;
1781
1782       /* Skip switches that have already been printed.  */
1783       if (printed[i])
1784         continue;
1785
1786       printed[i] = true;
1787
1788       help = cl_options[i].help;
1789       if (!help)
1790         help = undocumented_msg;
1791
1792       /* Get the translation.  */
1793       help = _(help);
1794
1795       tab = strchr (help, '\t');
1796       if (tab)
1797         {
1798           len = tab - help;
1799           opt = help;
1800           help = tab + 1;
1801         }
1802       else
1803         {
1804           opt = cl_options[i].opt_text;
1805           len = strlen (opt);
1806         }
1807
1808       wrap_help (help, opt, len);
1809     }
1810
1811   putchar ('\n');
1812 }
1813
1814 /* Output ITEM, of length ITEM_WIDTH, in the left column, followed by
1815    word-wrapped HELP in a second column.  */
1816 static unsigned int
1817 print_switch (const char *text, unsigned int indent)
1818 {
1819   unsigned int len = strlen (text) + 1; /* trailing comma */
1820
1821   if (indent)
1822     {
1823       putchar (',');
1824       if (indent + len > columns)
1825         {
1826           putchar ('\n');
1827           putchar (' ');
1828           indent = 1;
1829         }
1830     }
1831   else
1832     putchar (' ');
1833
1834   putchar (' ');
1835   fputs (text, stdout);
1836
1837   return indent + len + 1;
1838 }
1839
1840 /* Output ITEM, of length ITEM_WIDTH, in the left column, followed by
1841    word-wrapped HELP in a second column.  */
1842 static void
1843 wrap_help (const char *help, const char *item, unsigned int item_width)
1844 {
1845   unsigned int col_width = 27;
1846   unsigned int remaining, room, len;
1847
1848   remaining = strlen (help);
1849
1850   do
1851     {
1852       room = columns - 3 - MAX (col_width, item_width);
1853       if (room > columns)
1854         room = 0;
1855       len = remaining;
1856
1857       if (room < len)
1858         {
1859           unsigned int i;
1860
1861           for (i = 0; help[i]; i++)
1862             {
1863               if (i >= room && len != remaining)
1864                 break;
1865               if (help[i] == ' ')
1866                 len = i;
1867               else if ((help[i] == '-' || help[i] == '/')
1868                        && help[i + 1] != ' '
1869                        && i > 0 && ISALPHA (help[i - 1]))
1870                 len = i + 1;
1871             }
1872         }
1873
1874       printf( "  %-*.*s %.*s\n", col_width, item_width, item, len, help);
1875       item_width = 0;
1876       while (help[len] == ' ')
1877         len++;
1878       help += len;
1879       remaining -= len;
1880     }
1881   while (remaining);
1882 }