Changes imported from Abseil "staging" branch:

- 79d5e27b30551028a35084bf0f314d14339f816b Adds "()" suffix for Minutes() and ToDoubleHours() in com... by Abseil Team <absl-team@google.com>
  - 7d43f4d8f056066bd8e4577e15cde6807f6191ec Change type traits tests to static_asserts; Add trivially... by Alex Strelnikov <strel@google.com>
  - b443886fd36b240df78683c676b7ebae07c9e91a Internal cleanup by Abseil Team <absl-team@google.com>
  - ef226810f398f0980e2158bfa352ab8ac5d97d83 Avoid weak virtual table warnings (-Wweak-vtables) and re... by Jorg Brown <jorg@google.com>
  - 76911667bed455c2c7330f8ee27b959bac032e41 Internal change by Abseil Team <absl-team@google.com>

GitOrigin-RevId: 79d5e27b30551028a35084bf0f314d14339f816b
Change-Id: I752b04c882ff6677af7ee91b1e4f424417a1e4eb
This commit is contained in:
Abseil Team 2017-11-14 13:17:47 -08:00 committed by John Olson
parent 02f833cb81
commit 99b92c8736
5 changed files with 48 additions and 20 deletions

View file

@ -93,6 +93,15 @@ TEST(Uint128, IntrinsicTypeTraitsTest) {
} }
#endif // ABSL_HAVE_INTRINSIC_INT128 #endif // ABSL_HAVE_INTRINSIC_INT128
TEST(Uint128, TrivialTraitsTest) {
static_assert(absl::is_trivially_default_constructible<absl::uint128>::value,
"");
static_assert(absl::is_trivially_copy_constructible<absl::uint128>::value,
"");
static_assert(absl::is_trivially_copy_assignable<absl::uint128>::value, "");
static_assert(std::is_trivially_destructible<absl::uint128>::value, "");
}
TEST(Uint128, AllTests) { TEST(Uint128, AllTests) {
absl::uint128 zero = 0; absl::uint128 zero = 0;
absl::uint128 one = 1; absl::uint128 one = 1;
@ -418,12 +427,6 @@ TEST(Uint128, ConstexprTest) {
EXPECT_EQ(minus_two, absl::MakeUint128(-1, -2)); EXPECT_EQ(minus_two, absl::MakeUint128(-1, -2));
} }
TEST(Uint128, Traits) {
EXPECT_TRUE(absl::is_trivially_copy_constructible<absl::uint128>::value);
EXPECT_TRUE(absl::is_trivially_copy_assignable<absl::uint128>::value);
EXPECT_TRUE(std::is_trivially_destructible<absl::uint128>::value);
}
TEST(Uint128, OStream) { TEST(Uint128, OStream) {
struct { struct {
absl::uint128 val; absl::uint128 val;

View file

@ -82,6 +82,7 @@ cc_library(
cc_library( cc_library(
name = "internal", name = "internal",
srcs = [ srcs = [
"internal/ostringstream.cc",
"internal/utf8.cc", "internal/utf8.cc",
], ],
hdrs = [ hdrs = [

View file

@ -0,0 +1,34 @@
// Copyright 2017 The Abseil Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "absl/strings/internal/ostringstream.h"
namespace absl {
namespace strings_internal {
OStringStream::Buf::int_type OStringStream::overflow(int c) {
assert(s_);
if (!Buf::traits_type::eq_int_type(c, Buf::traits_type::eof()))
s_->push_back(static_cast<char>(c));
return 1;
}
std::streamsize OStringStream::xsputn(const char* s, std::streamsize n) {
assert(s_);
s_->append(s, n);
return n;
}
} // namespace strings_internal
} // namespace absl

View file

@ -75,18 +75,8 @@ class OStringStream : private std::basic_streambuf<char>, public std::ostream {
private: private:
using Buf = std::basic_streambuf<char>; using Buf = std::basic_streambuf<char>;
Buf::int_type overflow(int c) override { Buf::int_type overflow(int c) override;
assert(s_); std::streamsize xsputn(const char* s, std::streamsize n) override;
if (!Buf::traits_type::eq_int_type(c, Buf::traits_type::eof()))
s_->push_back(static_cast<char>(c));
return 1;
}
std::streamsize xsputn(const char* s, std::streamsize n) override {
assert(s_);
s_->append(s, n);
return n;
}
std::string* s_; std::string* s_;
}; };

View file

@ -291,7 +291,7 @@ Duration Ceil(Duration d, Duration unit);
// Microseconds() // Microseconds()
// Milliseconds() // Milliseconds()
// Seconds() // Seconds()
// Minutes // Minutes()
// Hours() // Hours()
// //
// Factory functions for constructing `Duration` values from an integral number // Factory functions for constructing `Duration` values from an integral number
@ -374,7 +374,7 @@ int64_t ToInt64Hours(Duration d);
// ToDoubleMilliseconds() // ToDoubleMilliseconds()
// ToDoubleSeconds() // ToDoubleSeconds()
// ToDoubleMinutes() // ToDoubleMinutes()
// ToDoubleHours // ToDoubleHours()
// //
// Helper functions that convert a Duration to a floating point count of the // Helper functions that convert a Duration to a floating point count of the
// indicated unit. These functions are shorthand for the `FDivDuration()` // indicated unit. These functions are shorthand for the `FDivDuration()`