2014-06-01 17:55:23 +00:00
|
|
|
/*
|
2018-09-02 00:57:29 +00:00
|
|
|
* This file is part of the DXX-Rebirth project <https://www.dxx-rebirth.com/>.
|
2014-06-01 17:55:23 +00:00
|
|
|
* It is copyright by its individual contributors, as recorded in the
|
|
|
|
* project's Git history. See COPYING.txt at the top level for license
|
|
|
|
* terms and a link to the Git history.
|
|
|
|
*/
|
2013-12-04 22:38:04 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
#include <algorithm>
|
|
|
|
#include "dxxsconf.h"
|
2020-05-02 21:18:42 +00:00
|
|
|
#include <array>
|
2013-12-04 22:38:04 +00:00
|
|
|
|
|
|
|
template <std::size_t N>
|
|
|
|
class cstring_tie
|
|
|
|
{
|
|
|
|
public:
|
2014-07-14 02:12:39 +00:00
|
|
|
static const std::size_t maximum_arity = N;
|
2020-05-02 21:18:42 +00:00
|
|
|
using array_t = std::array<const char *, maximum_arity>;
|
2013-12-04 22:38:04 +00:00
|
|
|
template <typename... Args>
|
2014-07-14 02:12:39 +00:00
|
|
|
cstring_tie(Args&&... args) : p(array_t{{args...}}), m_count(sizeof...(Args))
|
2013-12-04 22:38:04 +00:00
|
|
|
{
|
|
|
|
static_assert(sizeof...(Args) <= maximum_arity, "too many arguments to cstring_tie");
|
|
|
|
}
|
|
|
|
unsigned count() const { return m_count; }
|
|
|
|
const char *string(std::size_t i) const { return p[i]; }
|
2020-09-11 03:08:02 +00:00
|
|
|
typename array_t::const_iterator begin() const
|
|
|
|
{
|
|
|
|
return p.begin();
|
|
|
|
}
|
2013-12-04 22:38:04 +00:00
|
|
|
private:
|
2014-07-14 02:12:39 +00:00
|
|
|
array_t p;
|
2013-12-04 22:38:04 +00:00
|
|
|
unsigned m_count;
|
|
|
|
};
|