mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-11 05:14:40 +00:00
Fix algorithms order.
This commit is contained in:
parent
4f6ffb67c1
commit
602e3a7587
2 changed files with 31 additions and 21 deletions
|
@ -106,7 +106,12 @@ const char *Algorithm::kKAWPOW_RVN = "kawpow";
|
||||||
#define ALGO_ALIAS_AUTO(ALGO) { Algorithm::k##ALGO, Algorithm::ALGO }
|
#define ALGO_ALIAS_AUTO(ALGO) { Algorithm::k##ALGO, Algorithm::ALGO }
|
||||||
|
|
||||||
|
|
||||||
static const std::map<Algorithm::Id, const char *> kAlgorithmNames = {
|
#ifdef _MSC_VER
|
||||||
|
# define strcasecmp _stricmp
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
static const std::map<uint32_t, const char *> kAlgorithmNames = {
|
||||||
ALGO_NAME(CN_0),
|
ALGO_NAME(CN_0),
|
||||||
ALGO_NAME(CN_1),
|
ALGO_NAME(CN_1),
|
||||||
ALGO_NAME(CN_2),
|
ALGO_NAME(CN_2),
|
||||||
|
@ -166,7 +171,7 @@ static const std::map<Algorithm::Id, const char *> kAlgorithmNames = {
|
||||||
|
|
||||||
struct aliasCompare
|
struct aliasCompare
|
||||||
{
|
{
|
||||||
inline bool operator()(const char *a, const char *b) const { return std::strcmp(a, b) < 0; }
|
inline bool operator()(const char *a, const char *b) const { return strcasecmp(a, b) < 0; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -286,6 +291,12 @@ xmrig::Algorithm::Algorithm(const rapidjson::Value &value) :
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::Algorithm::Algorithm(uint32_t id) :
|
||||||
|
m_id(kAlgorithmNames.count(id) ? static_cast<Id>(id) : INVALID)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
const char *xmrig::Algorithm::name() const
|
const char *xmrig::Algorithm::name() const
|
||||||
{
|
{
|
||||||
if (!isValid()) {
|
if (!isValid()) {
|
||||||
|
@ -319,7 +330,7 @@ xmrig::Algorithm::Id xmrig::Algorithm::parse(const char *name)
|
||||||
return INVALID;
|
return INVALID;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto it = kAlgorithmAliases.find(String(name).toLower());
|
const auto it = kAlgorithmAliases.find(name);
|
||||||
|
|
||||||
return it != kAlgorithmAliases.end() ? it->second : INVALID;
|
return it != kAlgorithmAliases.end() ? it->second : INVALID;
|
||||||
}
|
}
|
||||||
|
@ -331,27 +342,26 @@ size_t xmrig::Algorithm::count()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::vector<xmrig::Algorithm> xmrig::Algorithm::all()
|
|
||||||
{
|
|
||||||
Algorithms out;
|
|
||||||
out.reserve(count());
|
|
||||||
|
|
||||||
for (const auto &kv : kAlgorithmNames) {
|
|
||||||
out.emplace_back(kv.first);
|
|
||||||
}
|
|
||||||
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
std::vector<xmrig::Algorithm> xmrig::Algorithm::all(const std::function<bool(const Algorithm &algo)> &filter)
|
std::vector<xmrig::Algorithm> xmrig::Algorithm::all(const std::function<bool(const Algorithm &algo)> &filter)
|
||||||
{
|
{
|
||||||
|
static const std::vector<Id> order = {
|
||||||
|
CN_0, CN_1, CN_2, CN_R, CN_FAST, CN_HALF, CN_XAO, CN_RTO, CN_RWZ, CN_ZLS, CN_DOUBLE, CN_CCX,
|
||||||
|
CN_LITE_0, CN_LITE_1,
|
||||||
|
CN_HEAVY_0, CN_HEAVY_TUBE, CN_HEAVY_XHV,
|
||||||
|
CN_PICO_0, CN_PICO_TLO,
|
||||||
|
CN_UPX2,
|
||||||
|
RX_0, RX_WOW, RX_ARQ, RX_SFX, RX_KEVA,
|
||||||
|
AR2_CHUKWA, AR2_CHUKWA_V2, AR2_WRKZ,
|
||||||
|
ASTROBWT_DERO,
|
||||||
|
KAWPOW_RVN
|
||||||
|
};
|
||||||
|
|
||||||
Algorithms out;
|
Algorithms out;
|
||||||
out.reserve(count());
|
out.reserve(count());
|
||||||
|
|
||||||
for (const auto &kv : kAlgorithmNames) {
|
for (const Id algo : order) {
|
||||||
if (filter(kv.first)) {
|
if (kAlgorithmNames.count(algo) && (!filter || filter(algo))) {
|
||||||
out.emplace_back(kv.first);
|
out.emplace_back(algo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -159,6 +159,7 @@ public:
|
||||||
inline Algorithm(const char *algo) : m_id(parse(algo)) {}
|
inline Algorithm(const char *algo) : m_id(parse(algo)) {}
|
||||||
inline Algorithm(Id id) : m_id(id) {}
|
inline Algorithm(Id id) : m_id(id) {}
|
||||||
Algorithm(const rapidjson::Value &value);
|
Algorithm(const rapidjson::Value &value);
|
||||||
|
Algorithm(uint32_t id);
|
||||||
|
|
||||||
static inline constexpr bool isCN(Id id) { return (id & 0xff000000) == CN_ANY; }
|
static inline constexpr bool isCN(Id id) { return (id & 0xff000000) == CN_ANY; }
|
||||||
static inline constexpr Id base(Id id) { return isCN(id) ? static_cast<Id>(CN_0 | (id & 0xff00)) : INVALID; }
|
static inline constexpr Id base(Id id) { return isCN(id) ? static_cast<Id>(CN_0 | (id & 0xff00)) : INVALID; }
|
||||||
|
@ -196,8 +197,7 @@ public:
|
||||||
|
|
||||||
static Id parse(const char *name);
|
static Id parse(const char *name);
|
||||||
static size_t count();
|
static size_t count();
|
||||||
static std::vector<Algorithm> all();
|
static std::vector<Algorithm> all(const std::function<bool(const Algorithm &algo)> &filter = nullptr);
|
||||||
static std::vector<Algorithm> all(const std::function<bool(const Algorithm &algo)> &filter);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Id m_id = INVALID;
|
Id m_id = INVALID;
|
||||||
|
|
Loading…
Reference in a new issue