-- 77c85460dc3c46593b231c5161ac55273bb0c7ef by Abseil Team <absl-team@google.com>: Support int128 in SimpleAtoi. PiperOrigin-RevId: 337946262 -- 0be53049ccf8309650e4e22f23b290e5f75ee828 by Gennadiy Rozental <rogeeff@google.com>: Update build scripts to use --mount instead of --volume to mount the host data into a container. This is somewhat more verbose, but more readable and flexible. More importantly this is what docker documentation is recomending to use now. PiperOrigin-RevId: 337898761 -- 3bc877f1679fdf61ecbf4365287a0403cfc9b53e by Samuel Benzaquen <sbenza@google.com>: Add Cord constructor for constinit instances. PiperOrigin-RevId: 337871148 -- 8b87701892b9c325e78ad4e8e4f16b785a744622 by Chris Kennelly <ckennelly@google.com>: Use the address of kSeed, rather than its value. We initialize kSeed with &kSeed, so these are equivalent, but kSeed requires a load from memory while &kSeed can be formed as a RIP-relative lea. PiperOrigin-RevId: 337868415 GitOrigin-RevId: 77c85460dc3c46593b231c5161ac55273bb0c7ef Change-Id: I3d06c18a123f1be29dad5801e8625952dc41cd95pull/827/head
parent
8f1c34a77a
commit
4b915e7092
22 changed files with 567 additions and 36 deletions
@ -0,0 +1,70 @@ |
||||
// Copyright 2020 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_STRINGS_INTERNAL_STRING_CONSTANT_H_ |
||||
#define ABSL_STRINGS_INTERNAL_STRING_CONSTANT_H_ |
||||
|
||||
#include "absl/meta/type_traits.h" |
||||
#include "absl/strings/string_view.h" |
||||
|
||||
namespace absl { |
||||
ABSL_NAMESPACE_BEGIN |
||||
namespace strings_internal { |
||||
|
||||
// StringConstant<T> represents a compile time string constant.
|
||||
// It can be accessed via its `absl::string_view value` static member.
|
||||
// It is guaranteed that the `string_view` returned has constant `.data()`,
|
||||
// constant `.size()` and constant `value[i]` for all `0 <= i < .size()`
|
||||
//
|
||||
// The `T` is an opaque type. It is guaranteed that different string constants
|
||||
// will have different values of `T`. This allows users to associate the string
|
||||
// constant with other static state at compile time.
|
||||
//
|
||||
// Instances should be made using the `MakeStringConstant()` factory function
|
||||
// below.
|
||||
template <typename T> |
||||
struct StringConstant { |
||||
private: |
||||
// Returns true if `view` points to constant data.
|
||||
// Otherwise, it can't be constant evaluated.
|
||||
static constexpr bool ValidateConstant(absl::string_view view) { |
||||
return view.empty() || 2 * view[0] != 1; |
||||
} |
||||
|
||||
public: |
||||
static constexpr absl::string_view value = T{}(); |
||||
constexpr absl::string_view operator()() const { return value; } |
||||
|
||||
static_assert(ValidateConstant(value), |
||||
"The input string_view must point to constant data."); |
||||
}; |
||||
|
||||
template <typename T> |
||||
constexpr absl::string_view StringConstant<T>::value; // NOLINT
|
||||
|
||||
// Factory function for `StringConstant` instances.
|
||||
// It supports callables that have a constexpr default constructor and a
|
||||
// constexpr operator().
|
||||
// It must return an `absl::string_view` or `const char*` pointing to constant
|
||||
// data. This is validated at compile time.
|
||||
template <typename T> |
||||
constexpr StringConstant<T> MakeStringConstant(T) { |
||||
return {}; |
||||
} |
||||
|
||||
} // namespace strings_internal
|
||||
ABSL_NAMESPACE_END |
||||
} // namespace absl
|
||||
|
||||
#endif // ABSL_STRINGS_INTERNAL_STRING_CONSTANT_H_
|
@ -0,0 +1,60 @@ |
||||
// Copyright 2020 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/strings/internal/string_constant.h" |
||||
|
||||
#include "absl/meta/type_traits.h" |
||||
#include "gmock/gmock.h" |
||||
#include "gtest/gtest.h" |
||||
|
||||
namespace { |
||||
|
||||
using absl::strings_internal::MakeStringConstant; |
||||
|
||||
struct Callable { |
||||
constexpr absl::string_view operator()() const { |
||||
return absl::string_view("Callable", 8); |
||||
} |
||||
}; |
||||
|
||||
TEST(StringConstant, Traits) { |
||||
constexpr auto str = MakeStringConstant(Callable{}); |
||||
using T = decltype(str); |
||||
|
||||
EXPECT_TRUE(std::is_empty<T>::value); |
||||
EXPECT_TRUE(std::is_trivial<T>::value); |
||||
EXPECT_TRUE(absl::is_trivially_default_constructible<T>::value); |
||||
EXPECT_TRUE(absl::is_trivially_copy_constructible<T>::value); |
||||
EXPECT_TRUE(absl::is_trivially_move_constructible<T>::value); |
||||
EXPECT_TRUE(absl::is_trivially_destructible<T>::value); |
||||
} |
||||
|
||||
TEST(StringConstant, MakeFromCallable) { |
||||
constexpr auto str = MakeStringConstant(Callable{}); |
||||
using T = decltype(str); |
||||
EXPECT_EQ(Callable{}(), T::value); |
||||
EXPECT_EQ(Callable{}(), str()); |
||||
} |
||||
|
||||
TEST(StringConstant, MakeFromStringConstant) { |
||||
// We want to make sure the StringConstant itself is a valid input to the
|
||||
// factory function.
|
||||
constexpr auto str = MakeStringConstant(Callable{}); |
||||
constexpr auto str2 = MakeStringConstant(str); |
||||
using T = decltype(str2); |
||||
EXPECT_EQ(Callable{}(), T::value); |
||||
EXPECT_EQ(Callable{}(), str2()); |
||||
} |
||||
|
||||
} // namespace
|
Loading…
Reference in new issue