================
@@ -2997,6 +2997,7 @@ static void RenderFloatingPointOptions(const ToolChain 
&TC, const Driver &D,
   LangOptions::ComplexRangeKind Range = LangOptions::ComplexRangeKind::CX_None;
   std::string ComplexRangeStr = "";
   std::string GccRangeComplexOption = "";
+  std::string LastComplexRangeOption = "";
----------------
s-watanabe314 wrote:

Thank you for your feedback!
>  If you just set GccRangeComplexOption to empty for -ffast-math and 
> -fno-fast-math, would that give us reasonable diagnostics?

I think it's difficult. I believe diagnostics should be emitted when `Range` 
specified with options other than `-ffast-math` is overridden by 
`-fno-fast-math`. To distinguish between these cases, I think we need a 
variable that determines what options, including Clang-specific options, were 
specified before `-fno-fast-math`. Even if we empty `GccRangeComplexOption` 
when `-ffast-math` is spcified, it's impossible to distinguish whether the 
preceding option before `-fno-fast-math` was `-ffast-math` or 
`-fcomplex-arithmetic=basic`. If it's acceptable to assign "-ffp-model" or 
"-fcomplex-arithmetic" to `GccRangeComplexOption`, then a new variable might 
not be necessary.

https://github.com/llvm/llvm-project/pull/132680
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to