[clang-tools-extra] [llvm] [clangd] Add CodeAction to swap operands to binary operators (PR #78999)
Julian Schmidt via cfe-commits
cfe-commits at lists.llvm.org
Fri Sep 13 13:47:39 PDT 2024
================
@@ -0,0 +1,38 @@
+//===-- SwapBinaryOperandsTests.cpp -----------------------------*- C++ -*-===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "TweakTesting.h"
+#include "gmock/gmock-matchers.h"
+#include "gmock/gmock.h"
+#include "gtest/gtest.h"
+
+namespace clang {
+namespace clangd {
+namespace {
+
+TWEAK_TEST(SwapBinaryOperands);
+
+TEST_F(SwapBinaryOperandsTest, Test) {
+ Context = Function;
+ EXPECT_EQ(apply("int *p = nullptr; bool c = ^p == nullptr;"),
+ "int *p = nullptr; bool c = nullptr == p;");
+ EXPECT_EQ(apply("int *p = nullptr; bool c = p ^== nullptr;"),
+ "int *p = nullptr; bool c = nullptr == p;");
+ EXPECT_EQ(apply("int x = 3; bool c = ^x >= 5;"),
+ "int x = 3; bool c = 5 <= x;");
+ EXPECT_EQ(apply("int x = 3; bool c = x >^= 5;"),
+ "int x = 3; bool c = 5 <= x;");
+ EXPECT_EQ(apply("int x = 3; bool c = x >=^ 5;"),
+ "int x = 3; bool c = 5 <= x;");
+ EXPECT_EQ(apply("int x = 3; bool c = x >=^ 5;"),
+ "int x = 3; bool c = 5 <= x;");
+}
----------------
5chmidti wrote:
Here are some additional test with macros and `<=>`:
```suggestion
EXPECT_EQ(apply("int f(); int x = 3; bool c = x >=^ f();"),
"int f(); int x = 3; bool c = f() <= x;");
EXPECT_EQ(apply(R"cpp(
int f();
#define F f
int x = 3; bool c = x >=^ F();
)cpp"),
R"cpp(
int f();
#define F f
int x = 3; bool c = F() <= x;
)cpp");
EXPECT_EQ(apply(R"cpp(
int f();
#define F f()
int x = 3; bool c = x >=^ F;
)cpp"),
R"cpp(
int f();
#define F f()
int x = 3; bool c = F <= x;
)cpp");
EXPECT_EQ(apply(R"cpp(
int f(bool);
#define F(v) f(v)
int x = 0;
bool c = F(x^ < 5);
)cpp"),
R"cpp(
int f(bool);
#define F(v) f(v)
int x = 0;
bool c = F(5 > x);
)cpp");
ExtraArgs = {"-std=c++20"};
Context = CodeContext::File;
EXPECT_UNAVAILABLE(R"cpp(
namespace std {
struct strong_ordering {
int val;
static const strong_ordering less;
static const strong_ordering equivalent;
static const strong_ordering equal;
static const strong_ordering greater;
};
inline constexpr strong_ordering strong_ordering::less {-1};
inline constexpr strong_ordering strong_ordering::equivalent {0};
inline constexpr strong_ordering strong_ordering::equal {0};
inline constexpr strong_ordering strong_ordering::greater {1};
};
#define F(v) v
int x = 0;
auto c = F(5^ <=> x);
)cpp");
}
```
https://github.com/llvm/llvm-project/pull/78999
More information about the cfe-commits
mailing list