LCOV - code coverage report
Current view: top level - gcc/fortran - options.cc (source / functions) Coverage Total Hit
Test: gcc.info Lines: 89.1 % 459 409
Test Date: 2024-12-28 13:16:48 Functions: 85.7 % 14 12
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: - 0 0

             Branch data     Line data    Source code
       1                 :             : /* Parse and display command line options.
       2                 :             :    Copyright (C) 2000-2024 Free Software Foundation, Inc.
       3                 :             :    Contributed by Andy Vaught
       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 3, 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 COPYING3.  If not see
      19                 :             : <http://www.gnu.org/licenses/>.  */
      20                 :             : 
      21                 :             : #include "config.h"
      22                 :             : #include "system.h"
      23                 :             : #include "coretypes.h"
      24                 :             : #include "target.h"
      25                 :             : #include "tree.h"
      26                 :             : #include "gfortran.h"
      27                 :             : #include "diagnostic.h"       /* For global_dc.  */
      28                 :             : #include "opts.h"
      29                 :             : #include "toplev.h"  /* For save_decoded_options.  */
      30                 :             : #include "cpp.h"
      31                 :             : #include "langhooks.h"
      32                 :             : 
      33                 :             : gfc_option_t gfc_option;
      34                 :             : 
      35                 :             : #define SET_FLAG(flag, condition, on_value, off_value) \
      36                 :             :   do \
      37                 :             :     { \
      38                 :             :       if (condition) \
      39                 :             :         flag = (on_value); \
      40                 :             :       else \
      41                 :             :         flag = (off_value); \
      42                 :             :     } while (0)
      43                 :             : 
      44                 :             : #define SET_BITFLAG2(m) m
      45                 :             : 
      46                 :             : #define SET_BITFLAG(flag, condition, value) \
      47                 :             :   SET_BITFLAG2 (SET_FLAG (flag, condition, (flag | (value)), (flag & ~(value))))
      48                 :             : 
      49                 :             : 
      50                 :             : /* Set flags that control warnings and errors for different
      51                 :             :    Fortran standards to their default values.  Keep in sync with
      52                 :             :    libgfortran/runtime/compile_options.c (init_compile_options).  */
      53                 :             : 
      54                 :             : static void
      55                 :       31642 : set_default_std_flags (void)
      56                 :             : {
      57                 :       31642 :   gfc_option.allow_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
      58                 :             :     | GFC_STD_F2003 | GFC_STD_F2008 | GFC_STD_F95 | GFC_STD_F77
      59                 :             :     | GFC_STD_F2008_OBS | GFC_STD_GNU | GFC_STD_LEGACY
      60                 :             :     | GFC_STD_F2018 | GFC_STD_F2018_DEL | GFC_STD_F2018_OBS | GFC_STD_F2023
      61                 :             :     | GFC_STD_F2023_DEL;
      62                 :       31642 :   gfc_option.warn_std = GFC_STD_F2018_DEL | GFC_STD_F95_DEL | GFC_STD_LEGACY
      63                 :             :     | GFC_STD_F2023_DEL;
      64                 :         385 : }
      65                 :             : 
      66                 :             : /* Set (or unset) the DEC extension flags.  */
      67                 :             : 
      68                 :             : static void
      69                 :       30672 : set_dec_flags (int value)
      70                 :             : {
      71                 :             :   /* Set (or unset) other DEC compatibility extensions.  */
      72                 :       30672 :   SET_BITFLAG (flag_dollar_ok, value, value);
      73                 :       30672 :   SET_BITFLAG (flag_cray_pointer, value, value);
      74                 :       30672 :   SET_BITFLAG (flag_dec_structure, value, value);
      75                 :       30672 :   SET_BITFLAG (flag_dec_intrinsic_ints, value, value);
      76                 :       30672 :   SET_BITFLAG (flag_dec_static, value, value);
      77                 :       30672 :   SET_BITFLAG (flag_dec_math, value, value);
      78                 :       30672 :   SET_BITFLAG (flag_dec_include, value, value);
      79                 :       30672 :   SET_BITFLAG (flag_dec_format_defaults, value, value);
      80                 :       30672 :   SET_BITFLAG (flag_dec_blank_format_item, value, value);
      81                 :       30672 :   SET_BITFLAG (flag_dec_char_conversions, value, value);
      82                 :       30672 : }
      83                 :             : 
      84                 :             : /* Finalize DEC flags.  */
      85                 :             : 
      86                 :             : static void
      87                 :       30461 : post_dec_flags (int value)
      88                 :             : {
      89                 :             :   /* Don't warn for legacy code if -fdec is given; however, setting -fno-dec
      90                 :             :      does not force these warnings.  We make one final determination on this
      91                 :             :      at the end because -std= is always set first; thus, we can avoid
      92                 :             :      clobbering the user's desired standard settings in gfc_handle_option
      93                 :             :      e.g. when -fdec and -fno-dec are both given.  */
      94                 :           0 :   if (value)
      95                 :             :     {
      96                 :         199 :       gfc_option.allow_std |= GFC_STD_F95_OBS | GFC_STD_F95_DEL
      97                 :             :         | GFC_STD_GNU | GFC_STD_LEGACY;
      98                 :         199 :       gfc_option.warn_std &= ~(GFC_STD_LEGACY | GFC_STD_F95_DEL);
      99                 :             :     }
     100                 :           0 : }
     101                 :             : 
     102                 :             : /* Enable (or disable) -finit-local-zero.  */
     103                 :             : 
     104                 :             : static void
     105                 :       30515 : set_init_local_zero (int value)
     106                 :             : {
     107                 :       30515 :   gfc_option.flag_init_integer_value = 0;
     108                 :       30515 :   gfc_option.flag_init_character_value = (char)0;
     109                 :             : 
     110                 :          53 :   SET_FLAG (gfc_option.flag_init_integer, value, GFC_INIT_INTEGER_ON,
     111                 :             :             GFC_INIT_INTEGER_OFF);
     112                 :       30515 :   SET_FLAG (gfc_option.flag_init_logical, value, GFC_INIT_LOGICAL_FALSE,
     113                 :             :             GFC_INIT_LOGICAL_OFF);
     114                 :       30515 :   SET_FLAG (gfc_option.flag_init_character, value, GFC_INIT_CHARACTER_ON,
     115                 :             :             GFC_INIT_CHARACTER_OFF);
     116                 :          53 :   SET_FLAG (flag_init_real, value, GFC_INIT_REAL_ZERO, GFC_INIT_REAL_OFF);
     117                 :          53 : }
     118                 :             : 
     119                 :             : /* Return language mask for Fortran options.  */
     120                 :             : 
     121                 :             : unsigned int
     122                 :      337111 : gfc_option_lang_mask (void)
     123                 :             : {
     124                 :      337111 :   return CL_Fortran;
     125                 :             : }
     126                 :             : 
     127                 :             : /* Initialize options structure OPTS.  */
     128                 :             : 
     129                 :             : void
     130                 :       30716 : gfc_init_options_struct (struct gcc_options *opts)
     131                 :             : {
     132                 :       30716 :   opts->x_flag_errno_math = 0;
     133                 :       30716 :   opts->frontend_set_flag_errno_math = true;
     134                 :       30716 :   opts->x_flag_associative_math = -1;
     135                 :       30716 :   opts->frontend_set_flag_associative_math = true;
     136                 :       30716 : }
     137                 :             : 
     138                 :             : /* Get ready for options handling. Keep in sync with
     139                 :             :    libgfortran/runtime/compile_options.c (init_compile_options).  */
     140                 :             : 
     141                 :             : void
     142                 :       30462 : gfc_init_options (unsigned int decoded_options_count,
     143                 :             :                   struct cl_decoded_option *decoded_options)
     144                 :             : {
     145                 :       30462 :   gfc_source_file = NULL;
     146                 :       30462 :   gfc_option.module_dir = NULL;
     147                 :       30462 :   gfc_option.source_form = FORM_UNKNOWN;
     148                 :             :   /* The following is not quite right as Fortran since 2023 has: "A statement
     149                 :             :       shall not have more than one million characters."  This can already be
     150                 :             :       reached by 'just' 100 lines with 10,000 characters each.  */
     151                 :       30462 :   gfc_option.max_continue_fixed = 1000000;
     152                 :       30462 :   gfc_option.max_continue_free = 1000000;
     153                 :       30462 :   gfc_option.max_identifier_length = GFC_MAX_SYMBOL_LEN;
     154                 :       30462 :   gfc_option.max_errors = 25;
     155                 :             : 
     156                 :       30462 :   gfc_option.flag_preprocessed = 0;
     157                 :       30462 :   gfc_option.flag_d_lines = -1;
     158                 :       30462 :   set_init_local_zero (0);
     159                 :             : 
     160                 :       30462 :   gfc_option.fpe = 0;
     161                 :             :   /* All except GFC_FPE_INEXACT.  */
     162                 :       30462 :   gfc_option.fpe_summary = GFC_FPE_INVALID | GFC_FPE_DENORMAL
     163                 :             :                            | GFC_FPE_ZERO | GFC_FPE_OVERFLOW
     164                 :             :                            | GFC_FPE_UNDERFLOW;
     165                 :       30462 :   gfc_option.rtcheck = 0;
     166                 :             : 
     167                 :       30462 :   set_dec_flags (0);
     168                 :       30462 :   set_default_std_flags ();
     169                 :             : 
     170                 :             :   /* Initialize cpp-related options.  */
     171                 :       30462 :   gfc_cpp_init_options (decoded_options_count, decoded_options);
     172                 :       30462 :   gfc_diagnostics_init ();
     173                 :       30462 : }
     174                 :             : 
     175                 :             : 
     176                 :             : /* Determine the source form from the filename extension.  We assume
     177                 :             :    case insensitivity.  */
     178                 :             : 
     179                 :             : static gfc_source_form
     180                 :       28657 : form_from_filename (const char *filename)
     181                 :             : {
     182                 :       28657 :   static const struct
     183                 :             :   {
     184                 :             :     const char *extension;
     185                 :             :     gfc_source_form form;
     186                 :             :   }
     187                 :             :   exttype[] =
     188                 :             :   {
     189                 :             :     {
     190                 :             :     ".f90", FORM_FREE}
     191                 :             :     ,
     192                 :             :     {
     193                 :             :     ".f95", FORM_FREE}
     194                 :             :     ,
     195                 :             :     {
     196                 :             :     ".f03", FORM_FREE}
     197                 :             :     ,
     198                 :             :     {
     199                 :             :     ".f08", FORM_FREE}
     200                 :             :     ,
     201                 :             :     {
     202                 :             :     ".fii", FORM_FREE}
     203                 :             :     ,
     204                 :             :     {
     205                 :             :     ".fi", FORM_FIXED}
     206                 :             :     ,
     207                 :             :     {
     208                 :             :     ".f", FORM_FIXED}
     209                 :             :     ,
     210                 :             :     {
     211                 :             :     ".for", FORM_FIXED}
     212                 :             :     ,
     213                 :             :     {
     214                 :             :     ".ftn", FORM_FIXED}
     215                 :             :     ,
     216                 :             :     {
     217                 :             :     "", FORM_UNKNOWN}
     218                 :             :   };            /* sentinel value */
     219                 :             : 
     220                 :       28657 :   gfc_source_form f_form;
     221                 :       28657 :   const char *fileext;
     222                 :       28657 :   int i;
     223                 :             : 
     224                 :             :   /* Find end of file name.  Note, filename is either a NULL pointer or
     225                 :             :      a NUL terminated string.  */
     226                 :       28657 :   i = 0;
     227                 :     2561647 :   while (filename[i] != '\0')
     228                 :     2532990 :     i++;
     229                 :             : 
     230                 :             :   /* Find last period.  */
     231                 :      143285 :   while (i >= 0 && (filename[i] != '.'))
     232                 :      114628 :     i--;
     233                 :             : 
     234                 :             :   /* Did we see a file extension?  */
     235                 :       28657 :   if (i < 0)
     236                 :             :     return FORM_UNKNOWN; /* Nope  */
     237                 :             : 
     238                 :             :   /* Get file extension and compare it to others.  */
     239                 :       28657 :   fileext = &(filename[i]);
     240                 :             : 
     241                 :       28657 :   i = -1;
     242                 :       28657 :   f_form = FORM_UNKNOWN;
     243                 :       34145 :   do
     244                 :             :     {
     245                 :       34145 :       i++;
     246                 :       34145 :       if (strcasecmp (fileext, exttype[i].extension) == 0)
     247                 :             :         {
     248                 :       28657 :           f_form = exttype[i].form;
     249                 :       28657 :           break;
     250                 :             :         }
     251                 :             :     }
     252                 :        5488 :   while (exttype[i].form != FORM_UNKNOWN);
     253                 :             : 
     254                 :             :   return f_form;
     255                 :             : }
     256                 :             : 
     257                 :             : 
     258                 :             : /* Finalize commandline options.  */
     259                 :             : 
     260                 :             : bool
     261                 :       30462 : gfc_post_options (const char **pfilename)
     262                 :             : {
     263                 :       30462 :   const char *filename = *pfilename, *canon_source_file = NULL;
     264                 :       30462 :   char *source_path;
     265                 :       30462 :   bool verbose_missing_dir_warn;
     266                 :       30462 :   int i;
     267                 :             : 
     268                 :             :   /* This needs to be after the commandline has been processed.
     269                 :             :      In Fortran, the options is by default enabled, in C/C++
     270                 :             :      by default disabled.
     271                 :             :      If not enabled explicitly by the user, only warn for -I
     272                 :             :      and -J, otherwise warn for all include paths.  */
     273                 :       30462 :   verbose_missing_dir_warn
     274                 :       60924 :     = (OPTION_SET_P (cpp_warn_missing_include_dirs)
     275                 :       30462 :        && global_options.x_cpp_warn_missing_include_dirs);
     276                 :       30462 :   SET_OPTION_IF_UNSET (&global_options, &global_options_set,
     277                 :             :                        cpp_warn_missing_include_dirs, 1);
     278                 :       30462 :   gfc_check_include_dirs (verbose_missing_dir_warn);
     279                 :             : 
     280                 :       31158 :   SET_OPTION_IF_UNSET (&global_options, &global_options_set,
     281                 :             :                        flag_free_line_length,
     282                 :             :                        (gfc_option.allow_std & GFC_STD_F2023) ? 10000 : 132);
     283                 :             : 
     284                 :             :   /* Finalize DEC flags.  */
     285                 :       30461 :   post_dec_flags (flag_dec);
     286                 :             : 
     287                 :             :   /* Excess precision other than "fast" requires front-end
     288                 :             :      support.  */
     289                 :       30461 :   if (flag_excess_precision == EXCESS_PRECISION_STANDARD)
     290                 :           0 :     sorry ("%<-fexcess-precision=standard%> for Fortran");
     291                 :       30461 :   else if (flag_excess_precision == EXCESS_PRECISION_FLOAT16)
     292                 :           0 :     sorry ("%<-fexcess-precision=16%> for Fortran");
     293                 :             : 
     294                 :       30461 :   flag_excess_precision = EXCESS_PRECISION_FAST;
     295                 :             : 
     296                 :             :   /* Fortran allows associative math - but we cannot reassociate if
     297                 :             :      we want traps or signed zeros. Cf. also flag_protect_parens.  */
     298                 :       30461 :   if (flag_associative_math == -1)
     299                 :       60750 :     flag_associative_math = (!flag_trapping_math && !flag_signed_zeros);
     300                 :             : 
     301                 :       30461 :   if (flag_protect_parens == -1)
     302                 :       30460 :     flag_protect_parens = !optimize_fast;
     303                 :             : 
     304                 :             :   /* -Ofast sets implies -fstack-arrays unless an explicit size is set for
     305                 :             :      stack arrays.  */
     306                 :       30461 :   if (flag_stack_arrays == -1 && flag_max_stack_var_size == -2)
     307                 :       30441 :     flag_stack_arrays = optimize_fast;
     308                 :             : 
     309                 :             :   /* By default, disable (re)allocation during assignment for -std=f95,
     310                 :             :      and enable it for F2003/F2008/GNU/Legacy.  */
     311                 :       30461 :   if (flag_realloc_lhs == -1)
     312                 :             :     {
     313                 :       30403 :       if (gfc_option.allow_std & GFC_STD_F2003)
     314                 :       30261 :         flag_realloc_lhs = 1;
     315                 :             :       else
     316                 :         142 :         flag_realloc_lhs = 0;
     317                 :             :     }
     318                 :             : 
     319                 :             :   /* -fbounds-check is equivalent to -fcheck=bounds */
     320                 :       30461 :   if (flag_bounds_check)
     321                 :        1028 :     gfc_option.rtcheck |= GFC_RTCHECK_BOUNDS;
     322                 :             : 
     323                 :       30461 :   if (flag_compare_debug)
     324                 :           9 :     flag_dump_fortran_original = 0;
     325                 :             : 
     326                 :             :   /* Make -fmax-errors visible to gfortran's diagnostic machinery.  */
     327                 :       30461 :   if (OPTION_SET_P (flag_max_errors))
     328                 :          34 :     gfc_option.max_errors = flag_max_errors;
     329                 :             : 
     330                 :             :   /* Verify the input file name.  */
     331                 :       30461 :   if (!filename || strcmp (filename, "-") == 0)
     332                 :             :     {
     333                 :           0 :       filename = "";
     334                 :             :     }
     335                 :             : 
     336                 :       30461 :   if (gfc_option.flag_preprocessed)
     337                 :             :     {
     338                 :             :       /* For preprocessed files, if the first tokens are of the form # NUM.
     339                 :             :          handle the directives so we know the original file name.  */
     340                 :           3 :       gfc_source_file = gfc_read_orig_filename (filename, &canon_source_file);
     341                 :           3 :       if (gfc_source_file == NULL)
     342                 :           0 :         gfc_source_file = filename;
     343                 :             :       else
     344                 :           3 :         *pfilename = gfc_source_file;
     345                 :             :     }
     346                 :             :   else
     347                 :       30458 :     gfc_source_file = filename;
     348                 :             : 
     349                 :       30461 :   if (canon_source_file == NULL)
     350                 :       30459 :     canon_source_file = gfc_source_file;
     351                 :             : 
     352                 :             :   /* Adds the path where the source file is to the list of include files.  */
     353                 :             : 
     354                 :       30461 :   i = strlen (canon_source_file);
     355                 :      572412 :   while (i > 0 && !IS_DIR_SEPARATOR (canon_source_file[i]))
     356                 :      541951 :     i--;
     357                 :             : 
     358                 :       30461 :   if (i != 0)
     359                 :             :     {
     360                 :       30293 :       source_path = (char *) alloca (i + 1);
     361                 :       30293 :       memcpy (source_path, canon_source_file, i);
     362                 :       30293 :       source_path[i] = 0;
     363                 :             :       /* Only warn if the directory is different from the input file as
     364                 :             :          if that one is not found, already an error is shown.  */
     365                 :       30293 :       bool warn = gfc_option.flag_preprocessed && gfc_source_file != filename;
     366                 :       30293 :       gfc_add_include_path (source_path, true, true, warn, false);
     367                 :             :     }
     368                 :             :   else
     369                 :         168 :     gfc_add_include_path (".", true, true, false, false);
     370                 :             : 
     371                 :       30461 :   if (canon_source_file != gfc_source_file)
     372                 :           2 :     free (CONST_CAST (char *, canon_source_file));
     373                 :             : 
     374                 :             :   /* Decide which form the file will be read in as.  */
     375                 :             : 
     376                 :       30461 :   if (gfc_option.source_form != FORM_UNKNOWN)
     377                 :        1804 :     gfc_current_form = gfc_option.source_form;
     378                 :             :   else
     379                 :             :     {
     380                 :       28657 :       gfc_current_form = form_from_filename (filename);
     381                 :             : 
     382                 :       28657 :       if (gfc_current_form == FORM_UNKNOWN)
     383                 :             :         {
     384                 :           0 :           gfc_current_form = FORM_FREE;
     385                 :           0 :           main_input_filename = filename;
     386                 :           0 :           gfc_warning_now (0, "Reading file %qs as free form",
     387                 :           0 :                            (filename[0] == '\0') ? "<stdin>" : filename);
     388                 :             :         }
     389                 :             :     }
     390                 :             : 
     391                 :             :   /* If the user specified -fd-lines-as-{code|comments} verify that we're
     392                 :             :      in fixed form.  */
     393                 :       30461 :   if (gfc_current_form == FORM_FREE)
     394                 :             :     {
     395                 :       28672 :       if (gfc_option.flag_d_lines == 0)
     396                 :           0 :         gfc_warning_now (0, "%<-fd-lines-as-comments%> has no effect "
     397                 :             :                            "in free form");
     398                 :       28672 :       else if (gfc_option.flag_d_lines == 1)
     399                 :           0 :         gfc_warning_now (0, "%<-fd-lines-as-code%> has no effect in free form");
     400                 :             : 
     401                 :       28672 :       if (warn_line_truncation == -1)
     402                 :       27769 :           warn_line_truncation = 1;
     403                 :             : 
     404                 :             :       /* Enable -Werror=line-truncation when -Werror and -Wno-error have
     405                 :             :          not been set.  */
     406                 :       28664 :       if (warn_line_truncation && !OPTION_SET_P (warnings_are_errors)
     407                 :       57336 :           && option_unspecified_p (OPT_Wline_truncation))
     408                 :       27310 :         diagnostic_classify_diagnostic (global_dc, OPT_Wline_truncation,
     409                 :             :                                         DK_ERROR, UNKNOWN_LOCATION);
     410                 :             :     }
     411                 :             :   else
     412                 :             :     {
     413                 :             :       /* With -fdec, set -fd-lines-as-comments by default in fixed form.  */
     414                 :        1789 :       if (flag_dec && gfc_option.flag_d_lines == -1)
     415                 :           9 :         gfc_option.flag_d_lines = 0;
     416                 :             : 
     417                 :        1789 :       if (warn_line_truncation == -1)
     418                 :        1783 :         warn_line_truncation = 0;
     419                 :             :     }
     420                 :             : 
     421                 :             :   /* If -pedantic, warn about the use of GNU extensions.  */
     422                 :       30461 :   if (pedantic && (gfc_option.allow_std & GFC_STD_GNU) != 0)
     423                 :       15012 :     gfc_option.warn_std |= GFC_STD_GNU;
     424                 :             :   /* -std=legacy -pedantic is effectively -std=gnu.  */
     425                 :       30461 :   if (pedantic && (gfc_option.allow_std & GFC_STD_LEGACY) != 0)
     426                 :       15012 :     gfc_option.warn_std |= GFC_STD_F95_OBS | GFC_STD_F95_DEL | GFC_STD_LEGACY;
     427                 :             : 
     428                 :             :   /* If the user didn't explicitly specify -f(no)-second-underscore we
     429                 :             :      use it if we're trying to be compatible with f2c, and not
     430                 :             :      otherwise.  */
     431                 :       30461 :   if (flag_second_underscore == -1)
     432                 :       30450 :     flag_second_underscore = flag_f2c;
     433                 :             : 
     434                 :       30461 :   if (!flag_automatic && flag_max_stack_var_size != -2
     435                 :           0 :       && flag_max_stack_var_size != 0)
     436                 :           0 :     gfc_warning_now (0, "Flag %<-fno-automatic%> overwrites %<-fmax-stack-var-size=%d%>",
     437                 :             :                      flag_max_stack_var_size);
     438                 :       30461 :   else if (!flag_automatic && flag_recursive)
     439                 :           8 :     gfc_warning_now (OPT_Woverwrite_recursive, "Flag %<-fno-automatic%> "
     440                 :             :                      "overwrites %<-frecursive%>");
     441                 :       30453 :   else if (!flag_automatic && (flag_openmp || flag_openacc))
     442                 :           0 :     gfc_warning_now (0, "Flag %<-fno-automatic%> overwrites %<-frecursive%> "
     443                 :             :                      "implied by %qs", flag_openmp ? "-fopenmp" : "-fopenacc");
     444                 :       30453 :   else if (flag_max_stack_var_size != -2 && flag_recursive)
     445                 :           0 :     gfc_warning_now (0, "Flag %<-frecursive%> overwrites %<-fmax-stack-var-size=%d%>",
     446                 :             :                      flag_max_stack_var_size);
     447                 :       30453 :   else if (flag_max_stack_var_size != -2 && (flag_openmp || flag_openacc))
     448                 :           0 :     gfc_warning_now (0, "Flag %<-fmax-stack-var-size=%d%> overwrites "
     449                 :             :                      "%<-frecursive%> implied by %qs", flag_max_stack_var_size,
     450                 :             :                      flag_openmp ? "-fopenmp" : "-fopenacc");
     451                 :             : 
     452                 :             :   /* Implement -frecursive as -fmax-stack-var-size=-1.  */
     453                 :       30461 :   if (flag_recursive)
     454                 :          21 :     flag_max_stack_var_size = -1;
     455                 :             : 
     456                 :             :   /* Implied -frecursive; implemented as -fmax-stack-var-size=-1.  */
     457                 :       30461 :   if (flag_max_stack_var_size == -2 && flag_automatic
     458                 :       30368 :       && (flag_openmp || flag_openacc))
     459                 :             :     {
     460                 :        4252 :       flag_recursive = 1;
     461                 :        4252 :       flag_max_stack_var_size = -1;
     462                 :             :     }
     463                 :             : 
     464                 :             :   /* Set flag_stack_arrays correctly.  */
     465                 :       30461 :   if (flag_stack_arrays == -1)
     466                 :          15 :     flag_stack_arrays = 0;
     467                 :             : 
     468                 :             :   /* Set default.  */
     469                 :       30461 :   if (flag_max_stack_var_size == -2)
     470                 :       26173 :     flag_max_stack_var_size = 65536;
     471                 :             : 
     472                 :             :   /* Implement -fno-automatic as -fmax-stack-var-size=0.  */
     473                 :       30461 :   if (!flag_automatic)
     474                 :          65 :     flag_max_stack_var_size = 0;
     475                 :             : 
     476                 :             :   /* Decide inlining preference depending on optimization if nothing was
     477                 :             :      specified on the command line.  */
     478                 :       30461 :   if ((flag_inline_intrinsics & GFC_FLAG_INLINE_INTRINSIC_MAXLOC)
     479                 :             :       == GFC_FLAG_INLINE_INTRINSIC_MAXLOC_UNSET)
     480                 :             :     {
     481                 :       30459 :       if (optimize == 0 || optimize_size != 0)
     482                 :        7889 :         flag_inline_intrinsics &= ~GFC_FLAG_INLINE_INTRINSIC_MAXLOC;
     483                 :             :       else
     484                 :       22570 :         flag_inline_intrinsics |= GFC_FLAG_INLINE_INTRINSIC_MAXLOC;
     485                 :             :     }
     486                 :       30461 :   if ((flag_inline_intrinsics & GFC_FLAG_INLINE_INTRINSIC_MINLOC)
     487                 :             :       == GFC_FLAG_INLINE_INTRINSIC_MINLOC_UNSET)
     488                 :             :     {
     489                 :       30460 :       if (optimize == 0 || optimize_size != 0)
     490                 :        7890 :         flag_inline_intrinsics &= ~GFC_FLAG_INLINE_INTRINSIC_MINLOC;
     491                 :             :       else
     492                 :       22570 :         flag_inline_intrinsics |= GFC_FLAG_INLINE_INTRINSIC_MINLOC;
     493                 :             :     }
     494                 :             : 
     495                 :             :   /* If the user did not specify an inline matmul limit, inline up to the BLAS
     496                 :             :      limit or up to 30 if no external BLAS is specified.  */
     497                 :             : 
     498                 :       30461 :   if (flag_inline_matmul_limit < 0)
     499                 :             :     {
     500                 :       30414 :       if (flag_external_blas)
     501                 :           9 :         flag_inline_matmul_limit = flag_blas_matmul_limit;
     502                 :             :       else
     503                 :       30405 :         flag_inline_matmul_limit = 30;
     504                 :             :     }
     505                 :             : 
     506                 :             :   /* Optimization implies front end optimization, unless the user
     507                 :             :      specified it directly.  */
     508                 :             : 
     509                 :       30461 :   if (flag_frontend_optimize == -1)
     510                 :       34374 :     flag_frontend_optimize = optimize && !optimize_debug;
     511                 :             : 
     512                 :             :   /* Same for front end loop interchange.  */
     513                 :             : 
     514                 :       30461 :   if (flag_frontend_loop_interchange == -1)
     515                 :       30457 :     flag_frontend_loop_interchange = optimize;
     516                 :             : 
     517                 :             :   /* Do inline packing by default if optimizing, but not if
     518                 :             :      optimizing for size.  */
     519                 :       30461 :   if (flag_inline_arg_packing == -1)
     520                 :       38350 :     flag_inline_arg_packing = optimize && !optimize_size;
     521                 :             : 
     522                 :       30461 :   if (flag_max_array_constructor < 65535)
     523                 :           0 :     flag_max_array_constructor = 65535;
     524                 :             : 
     525                 :       30461 :   if (flag_fixed_line_length != 0 && flag_fixed_line_length < 7)
     526                 :           0 :     gfc_fatal_error ("Fixed line length must be at least seven");
     527                 :             : 
     528                 :       30461 :   if (flag_free_line_length != 0 && flag_free_line_length < 4)
     529                 :           0 :     gfc_fatal_error ("Free line length must be at least three");
     530                 :             : 
     531                 :       30461 :   if (flag_max_subrecord_length > MAX_SUBRECORD_LENGTH)
     532                 :           0 :     gfc_fatal_error ("Maximum subrecord length cannot exceed %d",
     533                 :             :                      MAX_SUBRECORD_LENGTH);
     534                 :             : 
     535                 :       30461 :   gfc_cpp_post_options (verbose_missing_dir_warn);
     536                 :             : 
     537                 :       30461 :   if (gfc_option.allow_std & GFC_STD_F2008)
     538                 :       30067 :     lang_hooks.name = "GNU Fortran2008";
     539                 :         394 :   else if (gfc_option.allow_std & GFC_STD_F2003)
     540                 :         252 :     lang_hooks.name = "GNU Fortran2003";
     541                 :             : 
     542                 :             :   /* Set the unsigned "standard".  */
     543                 :       30461 :   if (flag_unsigned)
     544                 :         200 :     gfc_option.allow_std |= GFC_STD_UNSIGNED;
     545                 :             : 
     546                 :       30461 :   return gfc_cpp_preprocess_only ();
     547                 :             : }
     548                 :             : 
     549                 :             : 
     550                 :             : static void
     551                 :           8 : gfc_handle_module_path_options (const char *arg)
     552                 :             : {
     553                 :             : 
     554                 :           8 :   if (gfc_option.module_dir != NULL)
     555                 :           0 :     gfc_fatal_error ("gfortran: Only one %<-J%> option allowed");
     556                 :             : 
     557                 :           8 :   gfc_option.module_dir = XCNEWVEC (char, strlen (arg) + 2);
     558                 :           8 :   strcpy (gfc_option.module_dir, arg);
     559                 :             : 
     560                 :           8 :   gfc_add_include_path (gfc_option.module_dir, true, false, true, true);
     561                 :             : 
     562                 :           8 :   strcat (gfc_option.module_dir, "/");
     563                 :           8 : }
     564                 :             : 
     565                 :             : 
     566                 :             : /* Handle options -ffpe-trap= and -ffpe-summary=.  */
     567                 :             : 
     568                 :             : static void
     569                 :           6 : gfc_handle_fpe_option (const char *arg, bool trap)
     570                 :             : {
     571                 :           6 :   int result, pos = 0, n;
     572                 :             :   /* precision is a backwards compatibility alias for inexact.  */
     573                 :           6 :   static const char * const exception[] = { "invalid", "denormal", "zero",
     574                 :             :                                             "overflow", "underflow",
     575                 :             :                                             "inexact", "precision", NULL };
     576                 :           6 :   static const int opt_exception[] = { GFC_FPE_INVALID, GFC_FPE_DENORMAL,
     577                 :             :                                        GFC_FPE_ZERO, GFC_FPE_OVERFLOW,
     578                 :             :                                        GFC_FPE_UNDERFLOW, GFC_FPE_INEXACT,
     579                 :             :                                        GFC_FPE_INEXACT,
     580                 :             :                                        0 };
     581                 :             : 
     582                 :             :   /* As the default for -ffpe-summary= is nonzero, set it to 0.  */
     583                 :           6 :   if (!trap)
     584                 :           0 :     gfc_option.fpe_summary = 0;
     585                 :             : 
     586                 :          18 :   while (*arg)
     587                 :             :     {
     588                 :          18 :       while (*arg == ',')
     589                 :           6 :         arg++;
     590                 :             : 
     591                 :         102 :       while (arg[pos] && arg[pos] != ',')
     592                 :          90 :         pos++;
     593                 :             : 
     594                 :          12 :       result = 0;
     595                 :          12 :       if (strncmp ("none", arg, pos) == 0)
     596                 :             :         {
     597                 :           0 :           if (trap)
     598                 :           0 :             gfc_option.fpe = 0;
     599                 :             :           else
     600                 :           0 :             gfc_option.fpe_summary = 0;
     601                 :           0 :           arg += pos;
     602                 :           0 :           pos = 0;
     603                 :           0 :           continue;
     604                 :             :         }
     605                 :          12 :       else if (!trap && strncmp ("all", arg, pos) == 0)
     606                 :             :         {
     607                 :           0 :           gfc_option.fpe_summary = GFC_FPE_INVALID | GFC_FPE_DENORMAL
     608                 :             :                                    | GFC_FPE_ZERO | GFC_FPE_OVERFLOW
     609                 :             :                                    | GFC_FPE_UNDERFLOW | GFC_FPE_INEXACT;
     610                 :           0 :           arg += pos;
     611                 :           0 :           pos = 0;
     612                 :           0 :           continue;
     613                 :             :         }
     614                 :             :       else
     615                 :          30 :         for (n = 0; exception[n] != NULL; n++)
     616                 :             :           {
     617                 :          30 :           if (exception[n] && strncmp (exception[n], arg, pos) == 0)
     618                 :             :             {
     619                 :          12 :               if (trap)
     620                 :          12 :                 gfc_option.fpe |= opt_exception[n];
     621                 :             :               else
     622                 :           0 :                 gfc_option.fpe_summary |= opt_exception[n];
     623                 :             :               arg += pos;
     624                 :             :               pos = 0;
     625                 :             :               result = 1;
     626                 :             :               break;
     627                 :             :             }
     628                 :             :           }
     629                 :          12 :       if (!result && trap)
     630                 :           0 :         gfc_fatal_error ("Argument to %<-ffpe-trap%> is not valid: %s", arg);
     631                 :          12 :       else if (!result)
     632                 :           0 :         gfc_fatal_error ("Argument to %<-ffpe-summary%> is not valid: %s", arg);
     633                 :             : 
     634                 :             :     }
     635                 :           6 : }
     636                 :             : 
     637                 :             : 
     638                 :             : static void
     639                 :         382 : gfc_handle_runtime_check_option (const char *arg)
     640                 :             : {
     641                 :         382 :   int result, pos = 0, n;
     642                 :         382 :   static const char * const optname[] = { "all", "bounds", "array-temps",
     643                 :             :                                           "recursion", "do", "pointer",
     644                 :             :                                           "mem", "bits", NULL };
     645                 :         382 :   static const int optmask[] = { GFC_RTCHECK_ALL, GFC_RTCHECK_BOUNDS,
     646                 :             :                                  GFC_RTCHECK_ARRAY_TEMPS,
     647                 :             :                                  GFC_RTCHECK_RECURSION, GFC_RTCHECK_DO,
     648                 :             :                                  GFC_RTCHECK_POINTER, GFC_RTCHECK_MEM,
     649                 :             :                                  GFC_RTCHECK_BITS, 0 };
     650                 :             : 
     651                 :         764 :   while (*arg)
     652                 :             :     {
     653                 :         382 :       while (*arg == ',')
     654                 :           0 :         arg++;
     655                 :             : 
     656                 :        2238 :       while (arg[pos] && arg[pos] != ',')
     657                 :        1856 :         pos++;
     658                 :             : 
     659                 :        1280 :       result = 0;
     660                 :        1280 :       for (n = 0; optname[n] != NULL; n++)
     661                 :             :         {
     662                 :        1280 :           if (optname[n] && strncmp (optname[n], arg, pos) == 0)
     663                 :             :             {
     664                 :         376 :               gfc_option.rtcheck |= optmask[n];
     665                 :         376 :               arg += pos;
     666                 :         376 :               pos = 0;
     667                 :         376 :               result = 1;
     668                 :         376 :               break;
     669                 :             :             }
     670                 :         904 :           else if (optname[n] && pos > 3 && startswith (arg, "no-")
     671                 :          12 :                    && strncmp (optname[n], arg+3, pos-3) == 0)
     672                 :             :             {
     673                 :           6 :               gfc_option.rtcheck &= ~optmask[n];
     674                 :           6 :               arg += pos;
     675                 :           6 :               pos = 0;
     676                 :           6 :               result = 1;
     677                 :           6 :               break;
     678                 :             :             }
     679                 :             :         }
     680                 :         382 :       if (!result)
     681                 :           0 :         gfc_fatal_error ("Argument to %<-fcheck%> is not valid: %s", arg);
     682                 :             :     }
     683                 :         382 : }
     684                 :             : 
     685                 :             : 
     686                 :             : /* Handle command-line options.  Returns 0 if unrecognized, 1 if
     687                 :             :    recognized and handled.  */
     688                 :             : 
     689                 :             : bool
     690                 :      202720 : gfc_handle_option (size_t scode, const char *arg, HOST_WIDE_INT value,
     691                 :             :                    int kind ATTRIBUTE_UNUSED, location_t loc ATTRIBUTE_UNUSED,
     692                 :             :                    const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED)
     693                 :             : {
     694                 :      202720 :   bool result = true;
     695                 :      202720 :   enum opt_code code = (enum opt_code) scode;
     696                 :             : 
     697                 :      202720 :   if (gfc_cpp_handle_option (scode, arg, value) == 1)
     698                 :             :     return true;
     699                 :             : 
     700                 :      163607 :   switch (code)
     701                 :             :     {
     702                 :      107151 :     default:
     703                 :      107151 :       if (cl_options[code].flags & gfc_option_lang_mask ())
     704                 :             :         break;
     705                 :      163607 :       result = false;
     706                 :             :       break;
     707                 :             : 
     708                 :          12 :     case OPT_fcheck_array_temporaries:
     709                 :          12 :       SET_BITFLAG (gfc_option.rtcheck, value, GFC_RTCHECK_ARRAY_TEMPS);
     710                 :             :       break;
     711                 :             : 
     712                 :           4 :     case OPT_fd_lines_as_code:
     713                 :           4 :       gfc_option.flag_d_lines = 1;
     714                 :           4 :       break;
     715                 :             : 
     716                 :           1 :     case OPT_fd_lines_as_comments:
     717                 :           1 :       gfc_option.flag_d_lines = 0;
     718                 :           1 :       break;
     719                 :             : 
     720                 :        1803 :     case OPT_ffixed_form:
     721                 :        1803 :       gfc_option.source_form = FORM_FIXED;
     722                 :        1803 :       break;
     723                 :             : 
     724                 :          15 :     case OPT_ffree_form:
     725                 :          15 :       gfc_option.source_form = FORM_FREE;
     726                 :          15 :       break;
     727                 :             : 
     728                 :       34090 :     case OPT_fintrinsic_modules_path:
     729                 :       34090 :     case OPT_fintrinsic_modules_path_:
     730                 :             : 
     731                 :             :       /* This is needed because omp_lib.h is in a directory together
     732                 :             :          with intrinsic modules.  Do no warn because during testing
     733                 :             :          without an installed compiler, we would get lots of bogus
     734                 :             :          warnings for a missing include directory.  */
     735                 :       34090 :       gfc_add_include_path (arg, false, false, false, true);
     736                 :             : 
     737                 :       34090 :       gfc_add_intrinsic_modules_path (arg);
     738                 :       34090 :       break;
     739                 :             : 
     740                 :           3 :     case OPT_fpreprocessed:
     741                 :           3 :       gfc_option.flag_preprocessed = value;
     742                 :           3 :       break;
     743                 :             : 
     744                 :           0 :     case OPT_fmax_identifier_length_:
     745                 :           0 :       if (value > GFC_MAX_SYMBOL_LEN)
     746                 :           0 :         gfc_fatal_error ("Maximum supported identifier length is %d",
     747                 :             :                          GFC_MAX_SYMBOL_LEN);
     748                 :           0 :       gfc_option.max_identifier_length = value;
     749                 :           0 :       break;
     750                 :             : 
     751                 :          53 :     case OPT_finit_local_zero:
     752                 :          53 :       set_init_local_zero (value);
     753                 :          53 :       break;
     754                 :             : 
     755                 :          19 :     case OPT_finit_logical_:
     756                 :          19 :       if (!strcasecmp (arg, "false"))
     757                 :           6 :         gfc_option.flag_init_logical = GFC_INIT_LOGICAL_FALSE;
     758                 :          13 :       else if (!strcasecmp (arg, "true"))
     759                 :          13 :         gfc_option.flag_init_logical = GFC_INIT_LOGICAL_TRUE;
     760                 :             :       else
     761                 :           0 :         gfc_fatal_error ("Unrecognized option to %<-finit-logical%>: %s",
     762                 :             :                          arg);
     763                 :             :       break;
     764                 :             : 
     765                 :          38 :     case OPT_finit_integer_:
     766                 :          38 :       gfc_option.flag_init_integer = GFC_INIT_INTEGER_ON;
     767                 :          38 :       gfc_option.flag_init_integer_value = strtol (arg, NULL, 10);
     768                 :          38 :       break;
     769                 :             : 
     770                 :          19 :     case OPT_finit_character_:
     771                 :          19 :       if (value >= 0 && value <= 127)
     772                 :             :         {
     773                 :          19 :           gfc_option.flag_init_character = GFC_INIT_CHARACTER_ON;
     774                 :          19 :           gfc_option.flag_init_character_value = (char)value;
     775                 :             :         }
     776                 :             :       else
     777                 :           0 :         gfc_fatal_error ("The value of n in %<-finit-character=n%> must be "
     778                 :             :                          "between 0 and 127");
     779                 :          19 :       break;
     780                 :             : 
     781                 :       17855 :     case OPT_I:
     782                 :       17855 :       gfc_add_include_path (arg, true, false, true, true);
     783                 :       17855 :       break;
     784                 :             : 
     785                 :           8 :     case OPT_J:
     786                 :           8 :       gfc_handle_module_path_options (arg);
     787                 :           8 :       break;
     788                 :             : 
     789                 :           6 :     case OPT_ffpe_trap_:
     790                 :           6 :       gfc_handle_fpe_option (arg, true);
     791                 :           6 :       break;
     792                 :             : 
     793                 :           0 :     case OPT_ffpe_summary_:
     794                 :           0 :       gfc_handle_fpe_option (arg, false);
     795                 :           0 :       break;
     796                 :             : 
     797                 :         142 :     case OPT_std_f95:
     798                 :         142 :       gfc_option.allow_std = GFC_STD_OPT_F95;
     799                 :         142 :       gfc_option.warn_std = GFC_STD_F95_OBS;
     800                 :         142 :       gfc_option.max_continue_fixed = 19;
     801                 :         142 :       gfc_option.max_continue_free = 39;
     802                 :         142 :       gfc_option.max_identifier_length = 31;
     803                 :         142 :       warn_ampersand = 1;
     804                 :         142 :       warn_tabs = 1;
     805                 :         142 :       break;
     806                 :             : 
     807                 :         252 :     case OPT_std_f2003:
     808                 :         252 :       gfc_option.allow_std = GFC_STD_OPT_F03;
     809                 :         252 :       gfc_option.warn_std = GFC_STD_F95_OBS;
     810                 :         252 :       gfc_option.max_continue_fixed = 255;
     811                 :         252 :       gfc_option.max_continue_free = 255;
     812                 :         252 :       gfc_option.max_identifier_length = 63;
     813                 :         252 :       warn_ampersand = 1;
     814                 :         252 :       warn_tabs = 1;
     815                 :         252 :       break;
     816                 :             : 
     817                 :         244 :     case OPT_std_f2008:
     818                 :         244 :       gfc_option.allow_std = GFC_STD_OPT_F08;
     819                 :         244 :       gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F2008_OBS;
     820                 :         244 :       gfc_option.max_continue_free = 255;
     821                 :         244 :       gfc_option.max_continue_fixed = 255;
     822                 :         244 :       gfc_option.max_identifier_length = 63;
     823                 :         244 :       warn_ampersand = 1;
     824                 :         244 :       warn_tabs = 1;
     825                 :         244 :       break;
     826                 :             : 
     827                 :          60 :     case OPT_std_f2008ts:
     828                 :          60 :     case OPT_std_f2018:
     829                 :          60 :       gfc_option.allow_std = GFC_STD_OPT_F18;
     830                 :          60 :       gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F2008_OBS
     831                 :             :         | GFC_STD_F2018_OBS;
     832                 :          60 :       gfc_option.max_continue_free = 255;
     833                 :          60 :       gfc_option.max_continue_fixed = 255;
     834                 :          60 :       gfc_option.max_identifier_length = 63;
     835                 :          60 :       warn_ampersand = 1;
     836                 :          60 :       warn_tabs = 1;
     837                 :          60 :       break;
     838                 :             : 
     839                 :          10 :     case OPT_std_f2023:
     840                 :          10 :       gfc_option.allow_std = GFC_STD_OPT_F23;
     841                 :          10 :       gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F2008_OBS
     842                 :             :         | GFC_STD_F2018_OBS;
     843                 :          10 :       gfc_option.max_identifier_length = 63;
     844                 :          10 :       warn_ampersand = 1;
     845                 :          10 :       warn_tabs = 1;
     846                 :          10 :       break;
     847                 :             : 
     848                 :          19 :     case OPT_std_f202y:
     849                 :          19 :       gfc_option.allow_std = GFC_STD_OPT_F23 | GFC_STD_F202Y;
     850                 :          19 :       gfc_option.warn_std = GFC_STD_F95_OBS | GFC_STD_F2008_OBS
     851                 :             :         | GFC_STD_F2018_OBS;
     852                 :          19 :       gfc_option.max_identifier_length = 63;
     853                 :          19 :       warn_ampersand = 1;
     854                 :          19 :       warn_tabs = 1;
     855                 :          19 :       break;
     856                 :             : 
     857                 :         385 :     case OPT_std_gnu:
     858                 :         385 :       set_default_std_flags ();
     859                 :         385 :       break;
     860                 :             : 
     861                 :         795 :     case OPT_std_legacy:
     862                 :         795 :       set_default_std_flags ();
     863                 :         795 :       gfc_option.warn_std = 0;
     864                 :         795 :       break;
     865                 :             : 
     866                 :             :     case OPT_fshort_enums:
     867                 :             :       /* Handled in language-independent code.  */
     868                 :             :       break;
     869                 :             : 
     870                 :         382 :     case OPT_fcheck_:
     871                 :         382 :       gfc_handle_runtime_check_option (arg);
     872                 :         382 :       break;
     873                 :             : 
     874                 :         210 :     case OPT_fdec:
     875                 :             :       /* Set (or unset) the DEC extension flags.  */
     876                 :         210 :       set_dec_flags (value);
     877                 :         210 :       break;
     878                 :             : 
     879                 :          19 :     case OPT_fbuiltin_:
     880                 :             :       /* We only handle -fno-builtin-omp_is_initial_device
     881                 :             :          and -fno-builtin-acc_on_device.  */
     882                 :          19 :       if (value)
     883                 :             :         return false;  /* Not supported. */
     884                 :          19 :       if (!strcmp ("omp_is_initial_device", arg))
     885                 :           1 :         gfc_option.disable_omp_is_initial_device = true;
     886                 :          18 :       else if (!strcmp ("acc_on_device", arg))
     887                 :          18 :         gfc_option.disable_acc_on_device = true;
     888                 :             :       else
     889                 :           0 :         warning (0, "command-line option %<-fno-builtin-%s%> is not valid for "
     890                 :             :                  "Fortran", arg);
     891                 :             :       break;
     892                 :             : 
     893                 :             :     }
     894                 :             : 
     895                 :      163607 :   Fortran_handle_option_auto (&global_options, &global_options_set,
     896                 :             :                               scode, arg, value,
     897                 :             :                               gfc_option_lang_mask (), kind,
     898                 :             :                               loc, handlers, global_dc);
     899                 :      163607 :   return result;
     900                 :             : }
     901                 :             : 
     902                 :             : 
     903                 :             : /* Return a string with the options passed to the compiler; used for
     904                 :             :    Fortran's compiler_options() intrinsic.  */
     905                 :             : 
     906                 :             : char *
     907                 :           8 : gfc_get_option_string (void)
     908                 :             : {
     909                 :           8 :   unsigned j;
     910                 :           8 :   size_t len, pos;
     911                 :           8 :   char *result;
     912                 :             : 
     913                 :             :   /* Allocate and return a one-character string with '\0'.  */
     914                 :           8 :   if (!save_decoded_options_count)
     915                 :           0 :     return XCNEWVEC (char, 1);
     916                 :             : 
     917                 :             :   /* Determine required string length.  */
     918                 :             : 
     919                 :             :   len = 0;
     920                 :         180 :   for (j = 1; j < save_decoded_options_count; j++)
     921                 :             :     {
     922                 :         172 :       switch (save_decoded_options[j].opt_index)
     923                 :             :         {
     924                 :             :         case OPT_o:
     925                 :             :         case OPT_d:
     926                 :             :         case OPT_dumpbase:
     927                 :             :         case OPT_dumpbase_ext:
     928                 :             :         case OPT_dumpdir:
     929                 :             :         case OPT_quiet:
     930                 :             :         case OPT_version:
     931                 :             :         case OPT_fintrinsic_modules_path:
     932                 :             :         case OPT_fintrinsic_modules_path_:
     933                 :             :           /* Ignore these.  */
     934                 :             :           break;
     935                 :         126 :         default:
     936                 :             :           /* Ignore file names.  */
     937                 :         126 :           if (save_decoded_options[j].orig_option_with_args_text[0] == '-')
     938                 :         118 :             len += 1
     939                 :         118 :                  + strlen (save_decoded_options[j].orig_option_with_args_text);
     940                 :             :         }
     941                 :             :     }
     942                 :             : 
     943                 :           8 :   result = XCNEWVEC (char, len);
     944                 :             : 
     945                 :           8 :   pos = 0;
     946                 :         188 :   for (j = 1; j < save_decoded_options_count; j++)
     947                 :             :     {
     948                 :         172 :       switch (save_decoded_options[j].opt_index)
     949                 :             :         {
     950                 :          46 :         case OPT_o:
     951                 :          46 :         case OPT_d:
     952                 :          46 :         case OPT_dumpbase:
     953                 :          46 :         case OPT_dumpbase_ext:
     954                 :          46 :         case OPT_dumpdir:
     955                 :          46 :         case OPT_quiet:
     956                 :          46 :         case OPT_version:
     957                 :          46 :         case OPT_fintrinsic_modules_path:
     958                 :          46 :         case OPT_fintrinsic_modules_path_:
     959                 :             :           /* Ignore these.  */
     960                 :          46 :           continue;
     961                 :             : 
     962                 :             :         case OPT_cpp_:
     963                 :             :           /* Use "-cpp" rather than "-cpp=<temporary file>".  */
     964                 :             :           len = 4;
     965                 :             :           break;
     966                 :             : 
     967                 :         126 :         default:
     968                 :             :           /* Ignore file names.  */
     969                 :         126 :           if (save_decoded_options[j].orig_option_with_args_text[0] != '-')
     970                 :           8 :             continue;
     971                 :             : 
     972                 :         118 :           len = strlen (save_decoded_options[j].orig_option_with_args_text);
     973                 :             :         }
     974                 :             : 
     975                 :         118 :       memcpy (&result[pos], save_decoded_options[j].orig_option_with_args_text, len);
     976                 :         118 :       pos += len;
     977                 :         118 :       result[pos++] = ' ';
     978                 :             :     }
     979                 :             : 
     980                 :           8 :   result[--pos] = '\0';
     981                 :           8 :   return result;
     982                 :             : }
     983                 :             : 
     984                 :             : #undef SET_BITFLAG
     985                 :             : #undef SET_BITFLAG2
     986                 :             : #undef SET_FLAG
        

Generated by: LCOV version 2.1-beta

LCOV profile is generated on x86_64 machine using following configure options: configure --disable-bootstrap --enable-coverage=opt --enable-languages=c,c++,fortran,go,jit,lto,rust,m2 --enable-host-shared. GCC test suite is run with the built compiler.