mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-04-10 15:47:17 +02:00
util: Add SettingTo<Int>() and GetArg<Int>()
Redirect: * SettingToInt to SettingTo<int64_t>, and * GetIntArg to GetArg<int64_t>
This commit is contained in:
@@ -483,29 +483,33 @@ std::string SettingToString(const common::SettingsValue& value, const std::strin
|
||||
return SettingToString(value).value_or(strDefault);
|
||||
}
|
||||
|
||||
int64_t ArgsManager::GetIntArg(const std::string& strArg, int64_t nDefault) const
|
||||
template <std::integral Int>
|
||||
Int ArgsManager::GetArg(const std::string& strArg, Int nDefault) const
|
||||
{
|
||||
return GetIntArg(strArg).value_or(nDefault);
|
||||
return GetArg<Int>(strArg).value_or(nDefault);
|
||||
}
|
||||
|
||||
std::optional<int64_t> ArgsManager::GetIntArg(const std::string& strArg) const
|
||||
template <std::integral Int>
|
||||
std::optional<Int> ArgsManager::GetArg(const std::string& strArg) const
|
||||
{
|
||||
const common::SettingsValue value = GetSetting(strArg);
|
||||
return SettingToInt(value);
|
||||
return SettingTo<Int>(value);
|
||||
}
|
||||
|
||||
std::optional<int64_t> SettingToInt(const common::SettingsValue& value)
|
||||
template <std::integral Int>
|
||||
std::optional<Int> SettingTo(const common::SettingsValue& value)
|
||||
{
|
||||
if (value.isNull()) return std::nullopt;
|
||||
if (value.isFalse()) return 0;
|
||||
if (value.isTrue()) return 1;
|
||||
if (value.isNum()) return value.getInt<int64_t>();
|
||||
return LocaleIndependentAtoi<int64_t>(value.get_str());
|
||||
if (value.isNum()) return value.getInt<Int>();
|
||||
return LocaleIndependentAtoi<Int>(value.get_str());
|
||||
}
|
||||
|
||||
int64_t SettingToInt(const common::SettingsValue& value, int64_t nDefault)
|
||||
template <std::integral Int>
|
||||
Int SettingTo(const common::SettingsValue& value, Int nDefault)
|
||||
{
|
||||
return SettingToInt(value).value_or(nDefault);
|
||||
return SettingTo<Int>(value).value_or(nDefault);
|
||||
}
|
||||
|
||||
bool ArgsManager::GetBoolArg(const std::string& strArg, bool fDefault) const
|
||||
@@ -531,6 +535,23 @@ bool SettingToBool(const common::SettingsValue& value, bool fDefault)
|
||||
return SettingToBool(value).value_or(fDefault);
|
||||
}
|
||||
|
||||
#define INSTANTIATE_INT_TYPE(Type) \
|
||||
template Type ArgsManager::GetArg<Type>(const std::string&, Type) const; \
|
||||
template std::optional<Type> ArgsManager::GetArg<Type>(const std::string&) const; \
|
||||
template Type SettingTo<Type>(const common::SettingsValue&, Type); \
|
||||
template std::optional<Type> SettingTo<Type>(const common::SettingsValue&)
|
||||
|
||||
INSTANTIATE_INT_TYPE(int8_t);
|
||||
INSTANTIATE_INT_TYPE(uint8_t);
|
||||
INSTANTIATE_INT_TYPE(int16_t);
|
||||
INSTANTIATE_INT_TYPE(uint16_t);
|
||||
INSTANTIATE_INT_TYPE(int32_t);
|
||||
INSTANTIATE_INT_TYPE(uint32_t);
|
||||
INSTANTIATE_INT_TYPE(int64_t);
|
||||
INSTANTIATE_INT_TYPE(uint64_t);
|
||||
|
||||
#undef INSTANTIATE_INT_TYPE
|
||||
|
||||
bool ArgsManager::SoftSetArg(const std::string& strArg, const std::string& strValue)
|
||||
{
|
||||
LOCK(cs_args);
|
||||
|
||||
@@ -11,6 +11,7 @@
|
||||
#include <util/chaintype.h>
|
||||
#include <util/fs.h>
|
||||
|
||||
#include <concepts>
|
||||
#include <cstdint>
|
||||
#include <iosfwd>
|
||||
#include <list>
|
||||
@@ -89,8 +90,14 @@ struct SectionInfo {
|
||||
std::string SettingToString(const common::SettingsValue&, const std::string&);
|
||||
std::optional<std::string> SettingToString(const common::SettingsValue&);
|
||||
|
||||
int64_t SettingToInt(const common::SettingsValue&, int64_t);
|
||||
std::optional<int64_t> SettingToInt(const common::SettingsValue&);
|
||||
template <std::integral Int>
|
||||
Int SettingTo(const common::SettingsValue&, Int);
|
||||
|
||||
template <std::integral Int>
|
||||
std::optional<Int> SettingTo(const common::SettingsValue&);
|
||||
|
||||
inline int64_t SettingToInt(const common::SettingsValue& value, int64_t nDefault) { return SettingTo<int64_t>(value, nDefault); }
|
||||
inline std::optional<int64_t> SettingToInt(const common::SettingsValue& value) { return SettingTo<int64_t>(value); }
|
||||
|
||||
bool SettingToBool(const common::SettingsValue&, bool);
|
||||
std::optional<bool> SettingToBool(const common::SettingsValue&);
|
||||
@@ -293,8 +300,14 @@ protected:
|
||||
* @param nDefault (e.g. 1)
|
||||
* @return command-line argument (0 if invalid number) or default value
|
||||
*/
|
||||
int64_t GetIntArg(const std::string& strArg, int64_t nDefault) const;
|
||||
std::optional<int64_t> GetIntArg(const std::string& strArg) const;
|
||||
template <std::integral Int>
|
||||
Int GetArg(const std::string& strArg, Int nDefault) const;
|
||||
|
||||
template <std::integral Int>
|
||||
std::optional<Int> GetArg(const std::string& strArg) const;
|
||||
|
||||
int64_t GetIntArg(const std::string& strArg, int64_t nDefault) const { return GetArg<int64_t>(strArg, nDefault); }
|
||||
std::optional<int64_t> GetIntArg(const std::string& strArg) const { return GetArg<int64_t>(strArg); }
|
||||
|
||||
/**
|
||||
* Return boolean argument or default value
|
||||
|
||||
Reference in New Issue
Block a user