forked from OSchip/llvm-project
Add ConstString::IsNull() to tell between null vs. empty strings and fix usage in Mangled::GetDemangledName()
Summary: `IsEmpty()` and `operator bool() == false` have equal semantics. Usage in Mangled::GetDemangledName() was incorrect. What it actually wants is a check for null-string. Split this off of D50071 and added a test to clarify usage. Reviewers: labath, jingham Subscribers: erik.pilkington, lldb-commits Differential Revision: https://reviews.llvm.org/D50327 llvm-svn: 339014
This commit is contained in:
parent
e023706471
commit
4af5a83a48
|
@ -345,6 +345,15 @@ public:
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
bool IsEmpty() const { return m_string == nullptr || m_string[0] == '\0'; }
|
bool IsEmpty() const { return m_string == nullptr || m_string[0] == '\0'; }
|
||||||
|
|
||||||
|
//------------------------------------------------------------------
|
||||||
|
/// Test for null string.
|
||||||
|
///
|
||||||
|
/// @return
|
||||||
|
/// @li \b true if there is no string associated with this instance.
|
||||||
|
/// @li \b false if there is a string associated with this instance.
|
||||||
|
//------------------------------------------------------------------
|
||||||
|
bool IsNull() const { return m_string == nullptr; }
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
/// Set the C string value.
|
/// Set the C string value.
|
||||||
///
|
///
|
||||||
|
|
|
@ -242,7 +242,7 @@ const ConstString &
|
||||||
Mangled::GetDemangledName(lldb::LanguageType language) const {
|
Mangled::GetDemangledName(lldb::LanguageType language) const {
|
||||||
// Check to make sure we have a valid mangled name and that we haven't
|
// Check to make sure we have a valid mangled name and that we haven't
|
||||||
// already decoded our mangled name.
|
// already decoded our mangled name.
|
||||||
if (m_mangled && !m_demangled) {
|
if (m_mangled && m_demangled.IsNull()) {
|
||||||
// We need to generate and cache the demangled name.
|
// We need to generate and cache the demangled name.
|
||||||
static Timer::Category func_cat(LLVM_PRETTY_FUNCTION);
|
static Timer::Category func_cat(LLVM_PRETTY_FUNCTION);
|
||||||
Timer scoped_timer(func_cat, "Mangled::GetDemangledName (m_mangled = %s)",
|
Timer scoped_timer(func_cat, "Mangled::GetDemangledName (m_mangled = %s)",
|
||||||
|
@ -312,7 +312,7 @@ Mangled::GetDemangledName(lldb::LanguageType language) const {
|
||||||
free(demangled_name);
|
free(demangled_name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!m_demangled) {
|
if (m_demangled.IsNull()) {
|
||||||
// Set the demangled string to the empty string to indicate we tried to
|
// Set the demangled string to the empty string to indicate we tried to
|
||||||
// parse it once and failed.
|
// parse it once and failed.
|
||||||
m_demangled.SetCString("");
|
m_demangled.SetCString("");
|
||||||
|
|
|
@ -33,3 +33,20 @@ TEST(ConstStringTest, MangledCounterpart) {
|
||||||
EXPECT_TRUE(foo.GetMangledCounterpart(counterpart));
|
EXPECT_TRUE(foo.GetMangledCounterpart(counterpart));
|
||||||
EXPECT_EQ("bar", counterpart.GetStringRef());
|
EXPECT_EQ("bar", counterpart.GetStringRef());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(ConstStringTest, NullAndEmptyStates) {
|
||||||
|
ConstString foo("foo");
|
||||||
|
EXPECT_FALSE(!foo);
|
||||||
|
EXPECT_FALSE(foo.IsEmpty());
|
||||||
|
EXPECT_FALSE(foo.IsNull());
|
||||||
|
|
||||||
|
ConstString empty("");
|
||||||
|
EXPECT_TRUE(!empty);
|
||||||
|
EXPECT_TRUE(empty.IsEmpty());
|
||||||
|
EXPECT_FALSE(empty.IsNull());
|
||||||
|
|
||||||
|
ConstString null;
|
||||||
|
EXPECT_TRUE(!null);
|
||||||
|
EXPECT_TRUE(null.IsEmpty());
|
||||||
|
EXPECT_TRUE(null.IsNull());
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue