<div dir="ltr">On Fri, Oct 25, 2013 at 9:06 AM, Arthur O'Dwyer <span dir="ltr"><<a href="mailto:arthur.j.odwyer@gmail.com" target="_blank">arthur.j.odwyer@gmail.com</a>></span> wrote:<br><div class="gmail_extra">
<div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">IMHO, it would be better to remove the command-line option, and just<br>

set the (hard-coded) limit to 2048 or something else of that general<br>
order of magnitude. I can't think of any valid use for deeply nested<br>
operator->s; it's not like recursive template instantiation, where you<br>
might want to use a higher limit to implement a useful behavior.<br></blockquote><div><br></div><div>The "usual" (albeit very rare) use is to get around the recursive template instantiation depth limit.</div><div>
 </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
Therefore, setting the limit to something in the thousands ought to be<br>
good enough until someone legitimately runs into the limit; and in the<br>
meantime, we're not polluting the command-line docs with obscure and<br>
useless options.<br></blockquote><div><br></div><div>I don't see any problem with setting the default to a higher value, like maybe 2048.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">

Also FWIW, I do think a DR ought to be opened to make this an explicit<br>
implementation limit in the Standard... but I'm not volunteering. :)<br>
<br>
my $.02,<br>
–Arthur<br>
<div><div class="h5"><br>
<br>
On Fri, Oct 25, 2013 at 7:45 AM, Rahul Jain <<a href="mailto:1989.rahuljain@gmail.com">1989.rahuljain@gmail.com</a>> wrote:<br>
><br>
> Hi,<br>
><br>
> This is with reference to the below discussion thread:<br>
><br>
> <a href="http://clang-developers.42468.n3.nabble.com/Endless-operator-gt-chain-causing-infinite-loop-td4035258.html" target="_blank">http://clang-developers.42468.n3.nabble.com/Endless-operator-gt-chain-causing-infinite-loop-td4035258.html</a><br>

><br>
> I have tried to implement a command line argument to handle the issue.<br>
><br>
> The patch for the same is below:<br>
><br>
> Index: lib/Driver/Tools.cpp<br>
> ===================================================================<br>
> --- lib/Driver/Tools.cpp    (revision 193400)<br>
> +++ lib/Driver/Tools.cpp    (working copy)<br>
> @@ -2802,6 +2802,12 @@<br>
>      CmdArgs.push_back(A->getValue());<br>
>    }<br>
><br>
> +  if (Arg *A = Args.getLastArg(options::OPT_foperatorarrow_depth_,<br>
> +                               options::OPT_foperatorarrow_depth_EQ)) {<br>
> +    CmdArgs.push_back("-foperatorarrow-depth");<br></div></div></blockquote><div><br></div><div>Please use foperator_arrow_depth and -foperator-arrow-depth.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5">
> +    CmdArgs.push_back(A->getValue());<br>
> +  }<br>
> +<br>
>    if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {<br>
>      CmdArgs.push_back("-fconstexpr-depth");<br>
>      CmdArgs.push_back(A->getValue());<br>
> Index: lib/Frontend/CompilerInvocation.cpp<br>
> ===================================================================<br>
> --- lib/Frontend/CompilerInvocation.cpp    (revision 193400)<br>
> +++ lib/Frontend/CompilerInvocation.cpp    (working copy)<br>
> @@ -1313,6 +1313,8 @@<br>
>    Opts.MathErrno = !Opts.OpenCL && Args.hasArg(OPT_fmath_errno);<br>
>    Opts.InstantiationDepth =<br>
>        getLastArgIntValue(Args, OPT_ftemplate_depth, 256, Diags);<br>
> +  Opts.ArrowDepth =<br>
> +      getLastArgIntValue(Args, OPT_foperatorarrow_depth, 256, Diags);<br>
>    Opts.ConstexprCallDepth =<br>
>        getLastArgIntValue(Args, OPT_fconstexpr_depth, 512, Diags);<br>
>    Opts.ConstexprStepLimit =<br>
> Index: lib/Sema/SemaExprCXX.cpp<br>
> ===================================================================<br>
> --- lib/Sema/SemaExprCXX.cpp    (revision 193400)<br>
> +++ lib/Sema/SemaExprCXX.cpp    (working copy)<br>
> @@ -5188,8 +5188,19 @@<br>
>      llvm::SmallPtrSet<CanQualType,8> CTypes;<br>
>      SmallVector<SourceLocation, 8> Locations;<br>
>      CTypes.insert(Context.getCanonicalType(BaseType));<br>
> +<br>
> +    static unsigned int arrow_instantiation_count = 0;<br></div></div></blockquote><div><br></div><div>This should not be static, and the name should follow the coding convention:</div><div><br></div><div>  <a href="http://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly">http://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly</a></div>
<div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div class="h5">
> +    while (BaseType->isRecordType()) {<br>
> +      arrow_instantiation_count++;<br>
> +      if (arrow_instantiation_count >= getLangOpts().ArrowDepth) {<br>
> +        Diag(OpLoc,diag::err_arrow_instantiation_depth_exceeded)<br></div></div></blockquote><div><br></div><div>Space after comma.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5">
> +        << getLangOpts().ArrowDepth<br>
> +        << Base->getSourceRange();<br>
> +        Diag(OpLoc, diag::note_arrow_instantiation_depth)<br>
> +        << getLangOpts().ArrowDepth;<br>
> +    return ExprError();<br></div></div></blockquote><div><br></div><div>Indentation is strange here.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5">
> +      }<br>
><br>
> -    while (BaseType->isRecordType()) {<br>
>        Result = BuildOverloadedArrowExpr(<br>
>            S, Base, OpLoc,<br>
>            // When in a template specialization and on the first loop<br>
> iteration,<br>
> Index: include/clang/Basic/DiagnosticSemaKinds.td<br>
> ===================================================================<br>
> --- include/clang/Basic/DiagnosticSemaKinds.td    (revision 193400)<br>
> +++ include/clang/Basic/DiagnosticSemaKinds.td    (working copy)<br>
> @@ -2561,6 +2561,11 @@<br>
>  // can handle that case properly.<br>
>  def note_ovl_candidate_non_deduced_mismatch_qualified : Note<<br>
>      "candidate template ignored: could not match %q0 against %q1">;<br>
> +def err_arrow_instantiation_depth_exceeded : Error<<br>
> +  "arrow operator instantiation exceeded maximum depth of %0">,<br>
> +  DefaultFatal, NoSFINAE;<br></div></div></blockquote><div><br></div><div>We don't need this to be fatal.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5">
> +def note_arrow_instantiation_depth : Note<<br>
> +  "use -foperatorarrow-depth=N to increase arrow operator instantiation<br>
> depth">;<br>
><br>
>  // Note that we don't treat templates differently for this diagnostic.<br>
>  def note_ovl_candidate_arity : Note<"candidate "<br>
> Index: include/clang/Basic/LangOptions.def<br>
> ===================================================================<br>
> --- include/clang/Basic/LangOptions.def    (revision 193400)<br>
> +++ include/clang/Basic/LangOptions.def    (working copy)<br>
> @@ -160,6 +160,8 @@<br>
>  ENUM_LANGOPT(SignedOverflowBehavior, SignedOverflowBehaviorTy, 2,<br>
> SOB_Undefined,<br>
>               "signed integer overflow handling")<br>
><br>
> +BENIGN_LANGOPT(ArrowDepth, 32, 256,<br>
> +               "maximum arrow instantiation depth")<br></div></div></blockquote><div><br></div><div>"instantiation" is not correct here. Maybe "maximum number of operator->s to follow"?</div>
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div class="h5">
>  BENIGN_LANGOPT(InstantiationDepth, 32, 256,<br>
>                 "maximum template instantiation depth")<br>
>  BENIGN_LANGOPT(ConstexprCallDepth, 32, 512,<br>
> Index: include/clang/Driver/CC1Options.td<br>
> ===================================================================<br>
> --- include/clang/Driver/CC1Options.td    (revision 193400)<br>
> +++ include/clang/Driver/CC1Options.td    (working copy)<br>
> @@ -442,6 +442,8 @@<br>
>    HelpText<"Default type visibility">;<br>
>  def ftemplate_depth : Separate<["-"], "ftemplate-depth">,<br>
>    HelpText<"Maximum depth of recursive template instantiation">;<br>
> +def foperatorarrow_depth : Separate<["-"], "foperatorarrow-depth">,<br>
> +  HelpText<"Maximum depth of arrow operator instantiation">;<br>
>  def fconstexpr_depth : Separate<["-"], "fconstexpr-depth">,<br>
>    HelpText<"Maximum depth of recursive constexpr function calls">;<br>
>  def fconstexpr_steps : Separate<["-"], "fconstexpr-steps">,<br>
> Index: include/clang/Driver/Options.td<br>
> ===================================================================<br>
> --- include/clang/Driver/Options.td    (revision 193400)<br>
> +++ include/clang/Driver/Options.td    (working copy)<br>
> @@ -775,6 +775,8 @@<br>
>  def ftemplate_depth_ : Joined<["-"], "ftemplate-depth-">, Group<f_Group>;<br>
>  def ftemplate_backtrace_limit_EQ : Joined<["-"],<br>
> "ftemplate-backtrace-limit=">,<br>
>                                     Group<f_Group>;<br>
> +def foperatorarrow_depth_EQ : Joined<["-"], "foperatorarrow-depth=">,<br>
> Group<f_Group>;<br>
> +def foperatorarrow_depth_ : Joined<["-"], "foperatorarrow-depth-">,<br>
> Group<f_Group>;<br></div></div></blockquote><div><br></div><div>Please remove this variant. We only support the - form for -ftemplate-depth for compatibility with an old g++ misstep.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5">
>  def ftest_coverage : Flag<["-"], "ftest-coverage">, Group<f_Group>;<br>
>  def fvectorize : Flag<["-"], "fvectorize">, Group<f_Group>,<br>
>    HelpText<"Enable the loop vectorization passes">;<br>
><br>
><br>
><br>
> Please if someone could help me by reviewing it and suggesting improvements?</div></div></blockquote><div><br></div><div>It looks basically right, other than the tweaks above. Thanks!</div><div><br></div><div>Please also add this flag to the documentation. </div>
</div></div></div>