20#ifndef RIPPLE_PROTOCOL_FEATURE_H_INCLUDED
21#define RIPPLE_PROTOCOL_FEATURE_H_INCLUDED
23#include <xrpl/basics/base_uint.h>
25#include <boost/container/flat_map.hpp>
85#pragma push_macro("XRPL_FEATURE")
87#pragma push_macro("XRPL_FIX")
89#pragma push_macro("XRPL_RETIRE")
92#define XRPL_FEATURE(name, supported, vote) +1
93#define XRPL_FIX(name, supported, vote) +1
94#define XRPL_RETIRE(name) +1
102#include <xrpl/protocol/detail/features.macro>
106#pragma pop_macro("XRPL_RETIRE")
108#pragma pop_macro("XRPL_FIX")
110#pragma pop_macro("XRPL_FEATURE")
150 template <
class... Fs>
155 if constexpr (
sizeof...(fs) > 0)
161 using base::operator==;
172 using base::operator[];
183 "ripple::FeatureBitset::FeatureBitset(base) : count match");
186 template <
class... Fs>
191 count() == (
sizeof...(fs) + 1),
192 "ripple::FeatureBitset::FeatureBitset(uint256) : count and "
193 "sizeof... do match");
199 for (
auto const& f : fs)
202 fs.size() ==
count(),
203 "ripple::FeatureBitset::FeatureBitset(Container auto) : count and "
264 static_cast<base const&
>(lhs) &
static_cast<base const&
>(rhs)};
283 static_cast<base const&
>(lhs) |
static_cast<base const&
>(rhs)};
302 static_cast<base const&
>(lhs) ^
static_cast<base const&
>(rhs)};
341 for (
size_t i = 0; i < bs.
size(); ++i)
346#pragma push_macro("XRPL_FEATURE")
348#pragma push_macro("XRPL_FIX")
350#pragma push_macro("XRPL_RETIRE")
353#define XRPL_FEATURE(name, supported, vote) extern uint256 const feature##name;
354#define XRPL_FIX(name, supported, vote) extern uint256 const fix##name;
355#define XRPL_RETIRE(name)
357#include <xrpl/protocol/detail/features.macro>
360#pragma pop_macro("XRPL_RETIRE")
362#pragma pop_macro("XRPL_FIX")
364#pragma pop_macro("XRPL_FEATURE")
friend FeatureBitset operator|(FeatureBitset const &lhs, FeatureBitset const &rhs)
friend FeatureBitset operator&(FeatureBitset const &lhs, uint256 const &rhs)
friend FeatureBitset operator-(FeatureBitset const &lhs, uint256 const &rhs)
friend FeatureBitset operator|(uint256 const &lhs, FeatureBitset const &rhs)
FeatureBitset & operator|=(FeatureBitset const &rhs)
friend FeatureBitset operator^(FeatureBitset const &lhs, uint256 const &rhs)
auto operator[](uint256 const &f)
void initFromFeatures(uint256 const &f, Fs &&... fs)
friend FeatureBitset operator|(FeatureBitset const &lhs, uint256 const &rhs)
friend FeatureBitset operator&(uint256 const &lhs, FeatureBitset const &rhs)
friend FeatureBitset operator^(FeatureBitset const &lhs, FeatureBitset const &rhs)
FeatureBitset(uint256 const &f, Fs &&... fs)
FeatureBitset operator~() const
friend FeatureBitset operator^(uint256 const &lhs, FeatureBitset const &rhs)
friend FeatureBitset operator&(FeatureBitset const &lhs, FeatureBitset const &rhs)
friend FeatureBitset operator-(uint256 const &lhs, FeatureBitset const &rhs)
FeatureBitset & flip(uint256 const &f)
FeatureBitset(Col const &fs)
FeatureBitset & set(uint256 const &f, bool value=true)
friend FeatureBitset operator-(FeatureBitset const &lhs, FeatureBitset const &rhs)
FeatureBitset(base const &b)
FeatureBitset & operator&=(FeatureBitset const &rhs)
FeatureBitset & reset(uint256 const &f)
auto operator[](uint256 const &f) const
static constexpr std::size_t numFeatures
std::size_t numUpVotedAmendments()
Amendments that this server will vote for by default.
std::size_t numDownVotedAmendments()
Amendments that this server won't vote for by default.
std::map< std::string, VoteBehavior > const & supportedAmendments()
Amendments that this server supports and the default voting behavior.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
uint256 bitsetIndexToFeature(size_t i)
size_t featureToBitsetIndex(uint256 const &f)
std::map< std::string, AmendmentSupport > const & allAmendments()
All amendments libxrpl knows about.
std::string featureToName(uint256 const &f)
std::optional< uint256 > getRegisteredFeature(std::string const &name)
void foreachFeature(FeatureBitset bs, F &&f)