Google OR-Tools
v9.14
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
array_internal.h
Go to the documentation of this file.
1
// Copyright 2010-2025 Google LLC
2
// Licensed under the Apache License, Version 2.0 (the "License");
3
// you may not use this file except in compliance with the License.
4
// You may obtain a copy of the License at
5
//
6
// http://www.apache.org/licenses/LICENSE-2.0
7
//
8
// Unless required by applicable law or agreed to in writing, software
9
// distributed under the License is distributed on an "AS IS" BASIS,
10
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
// See the License for the specific language governing permissions and
12
// limitations under the License.
13
14
#ifndef OR_TOOLS_BASE_ARRAY_INTERNAL_H_
15
#define OR_TOOLS_BASE_ARRAY_INTERNAL_H_
16
17
#include <array>
18
#include <cstddef>
19
#include <type_traits>
20
#include <utility>
21
22
#include "absl/utility/utility.h"
23
24
namespace
gtl::internal_array
{
25
26
template
<
typename
T, std::size_t N, std::size_t... Idx>
27
constexpr
std::array<std::remove_cv_t<T>, N>
to_array_internal
(
28
T (&ts)[N], absl::index_sequence<Idx...>) {
29
return
{{ts[Idx]...}};
30
}
31
32
template
<
typename
T, std::size_t N, std::size_t... Idx>
33
constexpr
std::array<std::remove_cv_t<T>, N>
to_array_internal
(
34
T (&&ts)[N], absl::index_sequence<Idx...>) {
35
return
{{std::move(ts[Idx])...}};
36
}
37
38
}
// namespace gtl::internal_array
39
40
#endif
// OR_TOOLS_BASE_ARRAY_INTERNAL_H_
gtl::internal_array
Definition
array_internal.h:24
gtl::internal_array::to_array_internal
constexpr std::array< std::remove_cv_t< T >, N > to_array_internal(T(&ts)[N], absl::index_sequence< Idx... >)
Definition
array_internal.h:27
ortools
base
array_internal.h
Generated by
1.14.0