diff options
author | Peter Klausler <pklausler@nvidia.com> | 2023-05-09 14:01:18 -0700 |
---|---|---|
committer | Peter Klausler <pklausler@nvidia.com> | 2023-05-16 13:56:24 -0700 |
commit | 191d48723f8b853a6ad65532c173c67155cbe606 (patch) | |
tree | 16b7753babd981a86901c5edf7dd1cc4f00c2218 /flang/lib/Semantics/pointer-assignment.h | |
parent | 9d877369b7527785f3fea202fea7525e328780f0 (diff) | |
download | llvm-191d48723f8b853a6ad65532c173c67155cbe606.zip llvm-191d48723f8b853a6ad65532c173c67155cbe606.tar.gz llvm-191d48723f8b853a6ad65532c173c67155cbe606.tar.bz2 |
[flang] Finer control over warnings
Establish a set of optional usage warnings, and enable some
only in "-pedantic" mode that, in our subjective experience
with application codes, seem to issue frequently without
indicating usage that really needs to be corrected. By default,
with this patch the compiler should appear to be somewhat less
persnickety but not less informative.
Differential Revision: https://reviews.llvm.org/D150710
Diffstat (limited to 'flang/lib/Semantics/pointer-assignment.h')
-rw-r--r-- | flang/lib/Semantics/pointer-assignment.h | 19 |
1 files changed, 8 insertions, 11 deletions
diff --git a/flang/lib/Semantics/pointer-assignment.h b/flang/lib/Semantics/pointer-assignment.h index 95ed67d..c6f89c4 100644 --- a/flang/lib/Semantics/pointer-assignment.h +++ b/flang/lib/Semantics/pointer-assignment.h @@ -18,28 +18,25 @@ namespace Fortran::evaluate::characteristics { struct DummyDataObject; } -namespace Fortran::evaluate { -class FoldingContext; -} - namespace Fortran::semantics { +class SemanticsContext; class Symbol; bool CheckPointerAssignment( - evaluate::FoldingContext &, const evaluate::Assignment &, const Scope &); -bool CheckPointerAssignment(evaluate::FoldingContext &, const SomeExpr &lhs, + SemanticsContext &, const evaluate::Assignment &, const Scope &); +bool CheckPointerAssignment(SemanticsContext &, const SomeExpr &lhs, const SomeExpr &rhs, const Scope &, bool isBoundsRemapping = false); -bool CheckStructConstructorPointerComponent(evaluate::FoldingContext &, - const Symbol &lhs, const SomeExpr &rhs, const Scope &); -bool CheckPointerAssignment(evaluate::FoldingContext &, - parser::CharBlock source, const std::string &description, +bool CheckStructConstructorPointerComponent( + SemanticsContext &, const Symbol &lhs, const SomeExpr &rhs, const Scope &); +bool CheckPointerAssignment(SemanticsContext &, parser::CharBlock source, + const std::string &description, const evaluate::characteristics::DummyDataObject &, const SomeExpr &rhs, const Scope &); // Checks whether an expression is a valid static initializer for a // particular pointer designator. -bool CheckInitialTarget(evaluate::FoldingContext &, const SomeExpr &pointer, +bool CheckInitialTarget(SemanticsContext &, const SomeExpr &pointer, const SomeExpr &init, const Scope &); } // namespace Fortran::semantics |