--
990253454819ce26ff1dda9ab4bbc145b61d01e4 by Xiaoyi Zhang <zhangxy@google.com>:
Import github PR https://github.com/abseil/abseil-cpp/pull/645
PiperOrigin-RevId: 303119797
--
5ac845cb7929b7d1eaf59a309afd811db5001175 by Abseil Team <absl-team@google.com>:
Fix internal exception spec compatibility error
PiperOrigin-RevId: 303104081
--
3290595dd866eecab3c7044e2e3ca0adb74f1bf5 by Gennadiy Rozental <rogeeff@google.com>:
Use FlagValue<T> to represent the value of a flag. Place it directly after
FlagImpl and use a computed offset refer to it.
The offset is computed based on the assumption that the `value_` data member
is placed directly after the impl_ data member in Flag<T>.
This change will allow us to migrate to `T`-specific storage in the generic case.
This change decreases the overhead for int flags by 32 bytes.
PiperOrigin-RevId: 303038099
--
f2b37722cd7a6d3a60ef9713f0d2bbff56f3ddbf by Derek Mauro <dmauro@google.com>:
Minor correctness fix for an ABSL_HAVE_BUILTIN conditional
PiperOrigin-RevId: 302980666
--
39c079a6141ae1c5728af8bf33a39c8aff9deb9f by Abseil Team <absl-team@google.com>:
Use ABSL_HARDENING_ASSERT in b-tree and SwissTable iterators.
PiperOrigin-RevId: 302970075
--
9668a044e080c789df32bcaa1ffb5100831cd9fa by Benjamin Barenblat <bbaren@google.com>:
Correct `add_subdirectory` line in CMake googletest support
Commit bcefbdcdf6
added support for building with CMake against a local googletest checkout, but I missed a line when constructing the diff. Change the `add_subdirectory` line to reference the correct directories.
PiperOrigin-RevId: 302947488
--
0a3c10fabf80a43ca69ab8b1570030e55f2be741 by Andy Soffer <asoffer@google.com>:
Remove unused distribution format traits.
PiperOrigin-RevId: 302896176
--
0478f2f6270e5ed64c0e28ec09556ca90b2d46a9 by Samuel Benzaquen <sbenza@google.com>:
Fix for CWG:2310.
PiperOrigin-RevId: 302734089
--
3cb978dda5cae5905affdc0914dcc2d27671ed11 by Samuel Benzaquen <sbenza@google.com>:
Fix the Allocate/Deallocate functions to use the same underlying allocator type.
PiperOrigin-RevId: 302721804
--
ae38d3984fb68b4e3ddc165fa8d5c24d5936be52 by Matthew Brown <matthewbr@google.com>:
Internal Change
PiperOrigin-RevId: 302717314
--
7357cf7abd03cc60b6e82b5f28a8e34935c3b4dc by Andy Getzendanner <durandal@google.com>:
Fix typo: s/ABSL_HARDENED_ASSERT/ABSL_HARDENING_ASSERT/
PiperOrigin-RevId: 302532164
GitOrigin-RevId: 990253454819ce26ff1dda9ab4bbc145b61d01e4
Change-Id: Ie595a221c16e1e7e1255ad42e029b646c5f3e11d
pull/653/head
parent
132d791b40
commit
79e0dc1151
29 changed files with 387 additions and 607 deletions
@ -1,278 +0,0 @@ |
||||
//
|
||||
// Copyright 2018 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
|
||||
//
|
||||
// https://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.
|
||||
//
|
||||
#ifndef ABSL_RANDOM_DISTRIBUTION_FORMAT_TRAITS_H_ |
||||
#define ABSL_RANDOM_DISTRIBUTION_FORMAT_TRAITS_H_ |
||||
|
||||
#include <string> |
||||
#include <tuple> |
||||
#include <typeinfo> |
||||
|
||||
#include "absl/meta/type_traits.h" |
||||
#include "absl/random/bernoulli_distribution.h" |
||||
#include "absl/random/beta_distribution.h" |
||||
#include "absl/random/exponential_distribution.h" |
||||
#include "absl/random/gaussian_distribution.h" |
||||
#include "absl/random/log_uniform_int_distribution.h" |
||||
#include "absl/random/poisson_distribution.h" |
||||
#include "absl/random/uniform_int_distribution.h" |
||||
#include "absl/random/uniform_real_distribution.h" |
||||
#include "absl/random/zipf_distribution.h" |
||||
#include "absl/strings/str_cat.h" |
||||
#include "absl/strings/str_join.h" |
||||
#include "absl/strings/string_view.h" |
||||
#include "absl/types/span.h" |
||||
|
||||
namespace absl { |
||||
ABSL_NAMESPACE_BEGIN |
||||
|
||||
struct IntervalClosedClosedTag; |
||||
struct IntervalClosedOpenTag; |
||||
struct IntervalOpenClosedTag; |
||||
struct IntervalOpenOpenTag; |
||||
|
||||
namespace random_internal { |
||||
|
||||
// ScalarTypeName defines a preferred hierarchy of preferred type names for
|
||||
// scalars, and is evaluated at compile time for the specific type
|
||||
// specialization.
|
||||
template <typename T> |
||||
constexpr const char* ScalarTypeName() { |
||||
static_assert(std::is_integral<T>() || std::is_floating_point<T>(), ""); |
||||
// clang-format off
|
||||
return |
||||
std::is_same<T, float>::value ? "float" : |
||||
std::is_same<T, double>::value ? "double" : |
||||
std::is_same<T, long double>::value ? "long double" : |
||||
std::is_same<T, bool>::value ? "bool" : |
||||
std::is_signed<T>::value && sizeof(T) == 1 ? "int8_t" : |
||||
std::is_signed<T>::value && sizeof(T) == 2 ? "int16_t" : |
||||
std::is_signed<T>::value && sizeof(T) == 4 ? "int32_t" : |
||||
std::is_signed<T>::value && sizeof(T) == 8 ? "int64_t" : |
||||
std::is_unsigned<T>::value && sizeof(T) == 1 ? "uint8_t" : |
||||
std::is_unsigned<T>::value && sizeof(T) == 2 ? "uint16_t" : |
||||
std::is_unsigned<T>::value && sizeof(T) == 4 ? "uint32_t" : |
||||
std::is_unsigned<T>::value && sizeof(T) == 8 ? "uint64_t" : |
||||
"undefined"; |
||||
// clang-format on
|
||||
|
||||
// NOTE: It would be nice to use typeid(T).name(), but that's an
|
||||
// implementation-defined attribute which does not necessarily
|
||||
// correspond to a name. We could potentially demangle it
|
||||
// using, e.g. abi::__cxa_demangle.
|
||||
} |
||||
|
||||
// Distribution traits used by DistributionCaller and internal implementation
|
||||
// details of the mocking framework.
|
||||
/*
|
||||
struct DistributionFormatTraits { |
||||
// Returns the parameterized name of the distribution function.
|
||||
static constexpr const char* FunctionName() |
||||
// Format DistrT parameters.
|
||||
static std::string FormatArgs(DistrT& dist); |
||||
// Format DistrT::result_type results.
|
||||
static std::string FormatResults(DistrT& dist); |
||||
}; |
||||
*/ |
||||
template <typename DistrT> |
||||
struct DistributionFormatTraits; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::uniform_int_distribution<R>> { |
||||
using distribution_t = absl::uniform_int_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Uniform"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat("absl::IntervalClosedClosed, ", (d.min)(), ", ", |
||||
(d.max)()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::uniform_real_distribution<R>> { |
||||
using distribution_t = absl::uniform_real_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Uniform"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat((d.min)(), ", ", (d.max)()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::exponential_distribution<R>> { |
||||
using distribution_t = absl::exponential_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Exponential"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat(d.lambda()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::poisson_distribution<R>> { |
||||
using distribution_t = absl::poisson_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Poisson"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat(d.mean()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <> |
||||
struct DistributionFormatTraits<absl::bernoulli_distribution> { |
||||
using distribution_t = absl::bernoulli_distribution; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Bernoulli"; } |
||||
|
||||
static constexpr const char* FunctionName() { return Name(); } |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat(d.p()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::beta_distribution<R>> { |
||||
using distribution_t = absl::beta_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Beta"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat(d.alpha(), ", ", d.beta()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::zipf_distribution<R>> { |
||||
using distribution_t = absl::zipf_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Zipf"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat(d.k(), ", ", d.v(), ", ", d.q()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::gaussian_distribution<R>> { |
||||
using distribution_t = absl::gaussian_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "Gaussian"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrJoin(std::make_tuple(d.mean(), d.stddev()), ", "); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename R> |
||||
struct DistributionFormatTraits<absl::log_uniform_int_distribution<R>> { |
||||
using distribution_t = absl::log_uniform_int_distribution<R>; |
||||
using result_t = typename distribution_t::result_type; |
||||
|
||||
static constexpr const char* Name() { return "LogUniform"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<R>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrJoin(std::make_tuple((d.min)(), (d.max)(), d.base()), ", "); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
template <typename NumType> |
||||
struct UniformDistributionWrapper; |
||||
|
||||
template <typename NumType> |
||||
struct DistributionFormatTraits<UniformDistributionWrapper<NumType>> { |
||||
using distribution_t = UniformDistributionWrapper<NumType>; |
||||
using result_t = NumType; |
||||
|
||||
static constexpr const char* Name() { return "Uniform"; } |
||||
|
||||
static std::string FunctionName() { |
||||
return absl::StrCat(Name(), "<", ScalarTypeName<NumType>(), ">"); |
||||
} |
||||
static std::string FormatArgs(const distribution_t& d) { |
||||
return absl::StrCat((d.min)(), ", ", (d.max)()); |
||||
} |
||||
static std::string FormatResults(absl::Span<const result_t> results) { |
||||
return absl::StrJoin(results, ", "); |
||||
} |
||||
}; |
||||
|
||||
} // namespace random_internal
|
||||
ABSL_NAMESPACE_END |
||||
} // namespace absl
|
||||
|
||||
#endif // ABSL_RANDOM_DISTRIBUTION_FORMAT_TRAITS_H_
|
@ -1,30 +0,0 @@ |
||||
//
|
||||
// Copyright 2018 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
|
||||
//
|
||||
// https://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/random/mocking_bit_gen.h" |
||||
|
||||
#include <string> |
||||
|
||||
namespace absl { |
||||
ABSL_NAMESPACE_BEGIN |
||||
MockingBitGen::~MockingBitGen() { |
||||
|
||||
for (const auto& del : deleters_) { |
||||
del(); |
||||
} |
||||
} |
||||
|
||||
ABSL_NAMESPACE_END |
||||
} // namespace absl
|
Loading…
Reference in new issue