/* Copyright 2015, 2016, Michele Santullo * This file is part of "dindexer". * * "dindexer" is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * "dindexer" is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with "dindexer". If not, see . */ #ifndef id942A6B5AB2AF443C82D4321775BFC9E8 #define id942A6B5AB2AF443C82D4321775BFC9E8 #include "compatibility.h" #include "helpers/sequence_bt.hpp" #include #include #include #include #include #include #include #include #include #include #include namespace dinhelp { namespace customize { template struct index_array_to_string; template struct char_to_int; } //namespace customize namespace implem { template inline constexpr std::size_t max_digits() { return static_cast(::log(std::numeric_limits::max())); } template struct power { enum { value = Base * power::value }; }; template struct power { enum { value = 1 }; }; constexpr std::size_t count_digits_10_compiletime (std::size_t parNum) { return (parNum == 0 ? 0 : static_cast(::log10(parNum))) + 1; } template struct maxdigits { enum { value = count_digits_10_compiletime(static_cast(::pow(2.0, static_cast(N)))) }; }; template