[libcxx] [llvm] [RFC][libc++][test] Improves C++ Standard filtering. (PR #89499)
Louis Dionne via llvm-commits
llvm-commits at lists.llvm.org
Tue Sep 3 09:07:54 PDT 2024
================
@@ -165,11 +165,28 @@ def getSuitableClangTidy(cfg):
default=lambda cfg: next(
s for s in reversed(_allStandards) if getStdFlag(cfg, s)
),
- actions=lambda std: [
+ actions=lambda std: filter(None, [
AddFeature(std),
+
+ AddFeature("<=c++03") if std <= "c++03" else None,
+ AddFeature("<=c++11") if std <= "c++11" else None,
+ AddFeature("<=c++14") if std <= "c++14" else None,
+ AddFeature("<=c++17") if std <= "c++17" else None,
+ AddFeature("<=c++20") if std <= "c++20" else None,
+ AddFeature("<=c++23") if std <= "c++23" else None,
+ AddFeature("<=c++26") if std <= "c++26" else None,
----------------
ldionne wrote:
One issue I have with this is that it's an invitation for people to write something like `REQUIRES: >c++20`, and that would never be a defined feature. Similarly, people would legitimately expect `>= c++23` (with a space) to work, but it won't.
I wonder if that isn't creating a footgun if we don't "fully" support these relational operators at a more fundamental level.
https://github.com/llvm/llvm-project/pull/89499
More information about the llvm-commits
mailing list