https://gcc.gnu.org/bugzilla/show_bug.cgi?id=82063

--- Comment #2 from jim.wilson at linaro dot org ---
On Thu, Aug 31, 2017 at 1:32 PM, manu at gcc dot gnu.org
<gcc-bugzi...@gcc.gnu.org> wrote:
> This is already possible:
> https://gcc.gnu.org/onlinedocs/gccint/Option-properties.html
>
> LangEnabledBy(language, opt)
> LangEnabledBy(language, opt, posarg, negarg)
> ...
>
> See examples in c.opt.

I did already look at examples, and read the docs, and step through
code in the debugger.  Posarg and negarg are integers, which are
ignored for options that take a string as an argument.  So no, this
doesn't work.

Note in optc-gen.awk, where the handle_generated_option call is
generated, the fourth argument is always NULL. This is "const char
*arg" which is the argument for options that take string arguments.
The fifth argument, int value, is where the posarg/negarg value gets
passed.  Also, note, in the file opts-common.c, in the function
set_options, in the case CLVC_STRING, it uses only arg, it does not
use value.  Since the posarg/negarg values end up in value here, they
are ignored, and are useless.

I would rather ask why the -Walloc-size-larger-than= option is
(unsuccessfully) being enabled by -Wall.  It seems an odd one to try
to enable by default.

Another weirdness I just noticed, the docs say that a size suffix is
optional, but in the function alloc_max_size in calls.c, if no suffix
is specified, it does
  unit = 0;
 ...
  w *= unit;
which means the argument always gets ignored unless there is a size
suffix.  I think that should be
  unit = 1;
instead.

Reply via email to