Export of internal Abseil changes.
-- f9f068aa8a260dc576398e47b8e4540902e41358 by Derek Mauro <dmauro@google.com>: Fix test string with embedded NUL. Currently parses as octal. PiperOrigin-RevId: 237088193 -- d271ffdd3f450f817f6d30e98ff39d439aaf3a98 by Abseil Team <absl-team@google.com>: Make symbolizer examine any mapping with read+exec permission regardless of 'w' bit. PiperOrigin-RevId: 237056461 -- af315f8306d36a7367a452fd0b58cafdbf20719d by Abseil Team <absl-team@google.com>: Switch comments referencing base:: CondVar and Mutex to absl::. PiperOrigin-RevId: 236917884 -- c624d5d1c0bdb917bff5e651ba40599472f84e0e by Gennadiy Rozental <rogeeff@google.com>: Internal change PiperOrigin-RevId: 236898300 -- 3cdc82429af964846d1152f49148abc61d196a4b by Samuel Benzaquen <sbenza@google.com>: Make the `long double` overload if AbslHashValue a template to avoid invalid conversions with implicit operators. This overload was never meant to capture anything other than `long double` and any current caller to it that wasn't a `long double` is potentially a bug. In particular, any type with an implicit `bool` conversion is calling this overload instead of trying to find a hash<> specialization, thus causing pretty bad hash behavior. PiperOrigin-RevId: 236877073 GitOrigin-RevId: f9f068aa8a260dc576398e47b8e4540902e41358 Change-Id: If9cc008dd814f0ca06ed881f612c06575f1f7137
This commit is contained in:
parent
9fdf5e5b80
commit
febc5ee6a9
70 changed files with 483 additions and 410 deletions
|
|
@ -40,8 +40,8 @@ using ::testing::UnorderedElementsAre;
|
|||
TEST(Split, TraitsTest) {
|
||||
static_assert(!absl::strings_internal::SplitterIsConvertibleTo<int>::value,
|
||||
"");
|
||||
static_assert(!absl::strings_internal::SplitterIsConvertibleTo<std::string>::value,
|
||||
"");
|
||||
static_assert(
|
||||
!absl::strings_internal::SplitterIsConvertibleTo<std::string>::value, "");
|
||||
static_assert(absl::strings_internal::SplitterIsConvertibleTo<
|
||||
std::vector<std::string>>::value,
|
||||
"");
|
||||
|
|
@ -182,7 +182,8 @@ TEST(Split, APIExamples) {
|
|||
{
|
||||
// Uses the SkipWhitespace predicate.
|
||||
using absl::SkipWhitespace;
|
||||
std::vector<std::string> v = absl::StrSplit(" a , ,,b,", ',', SkipWhitespace());
|
||||
std::vector<std::string> v =
|
||||
absl::StrSplit(" a , ,,b,", ',', SkipWhitespace());
|
||||
EXPECT_THAT(v, ElementsAre(" a ", "b"));
|
||||
}
|
||||
|
||||
|
|
@ -215,7 +216,8 @@ TEST(Split, APIExamples) {
|
|||
|
||||
{
|
||||
// Results stored in a std::multimap.
|
||||
std::multimap<std::string, std::string> m = absl::StrSplit("a,1,b,2,a,3", ',');
|
||||
std::multimap<std::string, std::string> m =
|
||||
absl::StrSplit("a,1,b,2,a,3", ',');
|
||||
EXPECT_EQ(3, m.size());
|
||||
auto it = m.find("a");
|
||||
EXPECT_EQ("1", it->second);
|
||||
|
|
@ -271,7 +273,8 @@ TEST(SplitIterator, Basics) {
|
|||
EXPECT_EQ("a", *it); // tests dereference
|
||||
++it; // tests preincrement
|
||||
EXPECT_NE(it, end);
|
||||
EXPECT_EQ("b", std::string(it->data(), it->size())); // tests dereference as ptr
|
||||
EXPECT_EQ("b",
|
||||
std::string(it->data(), it->size())); // tests dereference as ptr
|
||||
it++; // tests postincrement
|
||||
EXPECT_EQ(it, end);
|
||||
}
|
||||
|
|
@ -295,7 +298,8 @@ TEST(SplitIterator, Predicate) {
|
|||
EXPECT_EQ("a", *it); // tests dereference
|
||||
++it; // tests preincrement -- "b" should be skipped here.
|
||||
EXPECT_NE(it, end);
|
||||
EXPECT_EQ("c", std::string(it->data(), it->size())); // tests dereference as ptr
|
||||
EXPECT_EQ("c",
|
||||
std::string(it->data(), it->size())); // tests dereference as ptr
|
||||
it++; // tests postincrement
|
||||
EXPECT_EQ(it, end);
|
||||
}
|
||||
|
|
@ -421,10 +425,13 @@ TEST(Splitter, ConversionOperator) {
|
|||
TestMapConversionOperator<std::map<std::string, std::string>>(splitter);
|
||||
TestMapConversionOperator<
|
||||
std::multimap<absl::string_view, absl::string_view>>(splitter);
|
||||
TestMapConversionOperator<std::multimap<absl::string_view, std::string>>(splitter);
|
||||
TestMapConversionOperator<std::multimap<std::string, absl::string_view>>(splitter);
|
||||
TestMapConversionOperator<std::multimap<absl::string_view, std::string>>(
|
||||
splitter);
|
||||
TestMapConversionOperator<std::multimap<std::string, absl::string_view>>(
|
||||
splitter);
|
||||
TestMapConversionOperator<std::multimap<std::string, std::string>>(splitter);
|
||||
TestMapConversionOperator<std::unordered_map<std::string, std::string>>(splitter);
|
||||
TestMapConversionOperator<std::unordered_map<std::string, std::string>>(
|
||||
splitter);
|
||||
|
||||
// Tests conversion to std::pair
|
||||
|
||||
|
|
@ -568,10 +575,9 @@ TEST(Split, AcceptsCertainTemporaries) {
|
|||
}
|
||||
|
||||
TEST(Split, Temporary) {
|
||||
// Use a std::string longer than the small-std::string-optimization length, so that when
|
||||
// the temporary is destroyed, if the splitter keeps a reference to the
|
||||
// std::string's contents, it'll reference freed memory instead of just dead
|
||||
// on-stack memory.
|
||||
// Use a std::string longer than the SSO length, so that when the temporary is
|
||||
// destroyed, if the splitter keeps a reference to the std::string's contents,
|
||||
// it'll reference freed memory instead of just dead on-stack memory.
|
||||
const char input[] = "a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u";
|
||||
EXPECT_LT(sizeof(std::string), ABSL_ARRAYSIZE(input))
|
||||
<< "Input should be larger than fits on the stack.";
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue