// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you 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. template #pragma once #include #include "arrow/util/string.h" using arrow::internal::ToChars; namespace arrow { namespace internal { namespace detail { template struct TuplePrinter { static void Print(OStream* os, const Tuple& t) { TuplePrinter::Print(os, t); *os << std::get(t); } }; template struct TuplePrinter { static void Print(OStream* os, const Tuple& t) {} }; } // namespace detail // Print elements from a tuple to a stream, in order. // Typical use is to pack a bunch of existing values with std::forward_as_tuple() // before passing it to this function. template void PrintTuple(OStream* os, const std::tuple& tup) { detail::TuplePrinter, sizeof...(Args)>::Print(os, tup); } template struct PrintVector { const Range& range_; const Separator& separator_; template // template to dodge inclusion of friend Os& operator<<(Os& os, PrintVector l) { bool first = true; os << "["; for (const auto& element : l.range_) { if (first) { first = false; } else { os << l.separator_; } os << ToChars(element); // use ToChars to avoid locale dependence } os << "]"; return os; } }; template PrintVector(const Range&, const Separator&) -> PrintVector; } // namespace internal } // namespace arrow