[clang] Revert "[alpha.webkit.UncountedCallArgsChecker] Ignore methods of WTF String classes." (PR #90701)
via cfe-commits
cfe-commits at lists.llvm.org
Tue Apr 30 21:28:54 PDT 2024
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-clang
Author: Ryosuke Niwa (rniwa)
<details>
<summary>Changes</summary>
Reverts llvm/llvm-project#<!-- -->90180
---
Full diff: https://github.com/llvm/llvm-project/pull/90701.diff
3 Files Affected:
- (modified) clang/lib/StaticAnalyzer/Checkers/WebKit/UncountedCallArgsChecker.cpp (+3-10)
- (modified) clang/test/Analysis/Checkers/WebKit/call-args-wtf-containers.cpp (-118)
- (modified) clang/test/Analysis/Checkers/WebKit/mock-types.h (+1-1)
``````````diff
diff --git a/clang/lib/StaticAnalyzer/Checkers/WebKit/UncountedCallArgsChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/WebKit/UncountedCallArgsChecker.cpp
index 0f40ecc7ba3000..ae494de58da3da 100644
--- a/clang/lib/StaticAnalyzer/Checkers/WebKit/UncountedCallArgsChecker.cpp
+++ b/clang/lib/StaticAnalyzer/Checkers/WebKit/UncountedCallArgsChecker.cpp
@@ -227,17 +227,10 @@ class UncountedCallArgsChecker
return NamespaceName == "WTF" &&
(MethodName == "find" || MethodName == "findIf" ||
MethodName == "reverseFind" || MethodName == "reverseFindIf" ||
- MethodName == "findIgnoringASCIICase" || MethodName == "get" ||
- MethodName == "inlineGet" || MethodName == "contains" ||
- MethodName == "containsIf" ||
- MethodName == "containsIgnoringASCIICase" ||
- MethodName == "startsWith" || MethodName == "endsWith" ||
- MethodName == "startsWithIgnoringASCIICase" ||
- MethodName == "endsWithIgnoringASCIICase" ||
- MethodName == "substring") &&
+ MethodName == "get" || MethodName == "inlineGet" ||
+ MethodName == "contains" || MethodName == "containsIf") &&
(ClsName.ends_with("Vector") || ClsName.ends_with("Set") ||
- ClsName.ends_with("Map") || ClsName == "StringImpl" ||
- ClsName.ends_with("String"));
+ ClsName.ends_with("Map"));
}
void reportBug(const Expr *CallArg, const ParmVarDecl *Param) const {
diff --git a/clang/test/Analysis/Checkers/WebKit/call-args-wtf-containers.cpp b/clang/test/Analysis/Checkers/WebKit/call-args-wtf-containers.cpp
index 17e25d9a627039..0a63a789856127 100644
--- a/clang/test/Analysis/Checkers/WebKit/call-args-wtf-containers.cpp
+++ b/clang/test/Analysis/Checkers/WebKit/call-args-wtf-containers.cpp
@@ -4,92 +4,6 @@
namespace WTF {
- constexpr unsigned long notFound = static_cast<unsigned long>(-1);
-
- class String;
- class StringImpl;
-
- class StringView {
- public:
- StringView(const String&);
- private:
- RefPtr<StringImpl> m_impl;
- };
-
- class StringImpl {
- public:
- void ref() const { ++m_refCount; }
- void deref() const {
- if (!--m_refCount)
- delete this;
- }
-
- static constexpr unsigned s_flagIs8Bit = 1u << 0;
- bool is8Bit() const { return m_hashAndFlags & s_flagIs8Bit; }
- const char* characters8() const { return m_char8; }
- const short* characters16() const { return m_char16; }
- unsigned length() const { return m_length; }
- Ref<StringImpl> substring(unsigned position, unsigned length) const;
-
- unsigned long find(char) const;
- unsigned long find(StringView) const;
- unsigned long contains(StringView) const;
- unsigned long findIgnoringASCIICase(StringView) const;
-
- bool startsWith(StringView) const;
- bool startsWithIgnoringASCIICase(StringView) const;
- bool endsWith(StringView) const;
- bool endsWithIgnoringASCIICase(StringView) const;
-
- private:
- mutable unsigned m_refCount { 0 };
- unsigned m_length { 0 };
- union {
- const char* m_char8;
- const short* m_char16;
- };
- unsigned m_hashAndFlags { 0 };
- };
-
- class String {
- public:
- String() = default;
- String(StringImpl& impl) : m_impl(&impl) { }
- String(StringImpl* impl) : m_impl(impl) { }
- String(Ref<StringImpl>&& impl) : m_impl(impl.get()) { }
- StringImpl* impl() { return m_impl.get(); }
- unsigned length() const { return m_impl ? m_impl->length() : 0; }
- const char* characters8() const { return m_impl ? m_impl->characters8() : nullptr; }
- const short* characters16() const { return m_impl ? m_impl->characters16() : nullptr; }
-
- bool is8Bit() const { return !m_impl || m_impl->is8Bit(); }
-
- unsigned long find(char character) const { return m_impl ? m_impl->find(character) : notFound; }
- unsigned long find(StringView str) const { return m_impl ? m_impl->find(str) : notFound; }
- unsigned long findIgnoringASCIICase(StringView) const;
-
- bool contains(char character) const { return find(character) != notFound; }
- bool contains(StringView) const;
- bool containsIgnoringASCIICase(StringView) const;
-
- bool startsWith(StringView) const;
- bool startsWithIgnoringASCIICase(StringView) const;
- bool endsWith(StringView) const;
- bool endsWithIgnoringASCIICase(StringView) const;
-
- String substring(unsigned position, unsigned length) const
- {
- if (!m_impl)
- return { };
- if (!position && length >= m_impl->length())
- return *this;
- return m_impl->substring(position, length);
- }
-
- private:
- RefPtr<StringImpl> m_impl;
- };
-
template <typename T>
class HashSet {
public:
@@ -175,9 +89,6 @@ namespace WTF {
}
-using WTF::StringView;
-using WTF::StringImpl;
-using WTF::String;
using WTF::HashSet;
using WTF::HashMap;
using WTF::WeakHashSet;
@@ -190,37 +101,8 @@ class RefCounted {
};
RefCounted* object();
-StringImpl* strImpl();
-String* str();
-StringView strView();
void test() {
- strImpl()->is8Bit();
- strImpl()->characters8();
- strImpl()->characters16();
- strImpl()->length();
- strImpl()->substring(2, 4);
- strImpl()->find(strView());
- strImpl()->contains(strView());
- strImpl()->findIgnoringASCIICase(strView());
- strImpl()->startsWith(strView());
- strImpl()->startsWithIgnoringASCIICase(strView());
- strImpl()->endsWith(strView());
- strImpl()->endsWithIgnoringASCIICase(strView());
-
- str()->is8Bit();
- str()->characters8();
- str()->characters16();
- str()->length();
- str()->substring(2, 4);
- str()->find(strView());
- str()->contains(strView());
- str()->findIgnoringASCIICase(strView());
- str()->startsWith(strView());
- str()->startsWithIgnoringASCIICase(strView());
- str()->endsWith(strView());
- str()->endsWithIgnoringASCIICase(strView());
-
HashSet<RefPtr<RefCounted>> set;
set.find(*object());
set.contains(*object());
diff --git a/clang/test/Analysis/Checkers/WebKit/mock-types.h b/clang/test/Analysis/Checkers/WebKit/mock-types.h
index a22c332aeb911d..c27ea9baaf3bf5 100644
--- a/clang/test/Analysis/Checkers/WebKit/mock-types.h
+++ b/clang/test/Analysis/Checkers/WebKit/mock-types.h
@@ -76,7 +76,7 @@ template <typename T> struct RefPtr {
const T *operator->() const { return t; }
T &operator*() { return *t; }
RefPtr &operator=(T *) { return *this; }
- operator bool() const { return t; }
+ operator bool() { return t; }
};
template <typename T> bool operator==(const RefPtr<T> &, const RefPtr<T> &) {
``````````
</details>
https://github.com/llvm/llvm-project/pull/90701
More information about the cfe-commits
mailing list