Sync changes with proxy.
This commit is contained in:
parent
3d60b3cc62
commit
a76243a65e
9 changed files with 402 additions and 97 deletions
|
@ -17,6 +17,7 @@ include (cmake/cpu.cmake)
|
||||||
set(HEADERS
|
set(HEADERS
|
||||||
src/api/NetworkState.h
|
src/api/NetworkState.h
|
||||||
src/App.h
|
src/App.h
|
||||||
|
src/base/tools/String.h
|
||||||
src/common/config/CommonConfig.h
|
src/common/config/CommonConfig.h
|
||||||
src/common/config/ConfigLoader.h
|
src/common/config/ConfigLoader.h
|
||||||
src/common/config/ConfigWatcher.h
|
src/common/config/ConfigWatcher.h
|
||||||
|
@ -93,6 +94,7 @@ endif()
|
||||||
set(SOURCES
|
set(SOURCES
|
||||||
src/api/NetworkState.cpp
|
src/api/NetworkState.cpp
|
||||||
src/App.cpp
|
src/App.cpp
|
||||||
|
src/base/tools/String.cpp
|
||||||
src/common/config/CommonConfig.cpp
|
src/common/config/CommonConfig.cpp
|
||||||
src/common/config/ConfigLoader.cpp
|
src/common/config/ConfigLoader.cpp
|
||||||
src/common/config/ConfigWatcher.cpp
|
src/common/config/ConfigWatcher.cpp
|
||||||
|
|
225
src/base/tools/String.cpp
Normal file
225
src/base/tools/String.cpp
Normal file
|
@ -0,0 +1,225 @@
|
||||||
|
/* XMRig
|
||||||
|
* Copyright 2010 Jeff Garzik <jgarzik@pobox.com>
|
||||||
|
* Copyright 2012-2014 pooler <pooler@litecoinpool.org>
|
||||||
|
* Copyright 2014 Lucas Jones <https://github.com/lucasjones>
|
||||||
|
* Copyright 2014-2016 Wolf9466 <https://github.com/OhGodAPet>
|
||||||
|
* Copyright 2016 Jay D Dee <jayddee246@gmail.com>
|
||||||
|
* Copyright 2017-2018 XMR-Stak <https://github.com/fireice-uk>, <https://github.com/psychocrypt>
|
||||||
|
* Copyright 2016-2018 XMRig <https://github.com/xmrig>, <support@xmrig.com>
|
||||||
|
*
|
||||||
|
* This program 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.
|
||||||
|
*
|
||||||
|
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include "base/tools/String.h"
|
||||||
|
#include "rapidjson/document.h"
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::String::String(const char *str) :
|
||||||
|
m_data(nullptr),
|
||||||
|
m_size(str == nullptr ? 0 : strlen(str))
|
||||||
|
{
|
||||||
|
if (m_size == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_data = new char[m_size + 1];
|
||||||
|
memcpy(m_data, str, m_size + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::String::String(const char *str, size_t size) :
|
||||||
|
m_data(nullptr),
|
||||||
|
m_size(size)
|
||||||
|
{
|
||||||
|
if (str == nullptr) {
|
||||||
|
m_size = 0;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_data = new char[m_size + 1];
|
||||||
|
memcpy(m_data, str, m_size);
|
||||||
|
m_data[m_size] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::String::String(const String &other) :
|
||||||
|
m_data(nullptr),
|
||||||
|
m_size(other.m_size)
|
||||||
|
{
|
||||||
|
if (other.m_data == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_data = new char[m_size + 1];
|
||||||
|
memcpy(m_data, other.m_data, m_size + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool xmrig::String::isEqual(const char *str) const
|
||||||
|
{
|
||||||
|
return (m_data != nullptr && str != nullptr && strcmp(m_data, str) == 0) || (m_data == nullptr && str == nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool xmrig::String::isEqual(const String &other) const
|
||||||
|
{
|
||||||
|
if (m_size != other.m_size) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (m_data != nullptr && other.m_data != nullptr && memcmp(m_data, other.m_data, m_size) == 0) || (m_data == nullptr && other.m_data == nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
rapidjson::Value xmrig::String::toJSON() const
|
||||||
|
{
|
||||||
|
using namespace rapidjson;
|
||||||
|
|
||||||
|
return isNull() ? Value(kNullType) : Value(StringRef(m_data));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
rapidjson::Value xmrig::String::toJSON(rapidjson::Document &doc) const
|
||||||
|
{
|
||||||
|
using namespace rapidjson;
|
||||||
|
|
||||||
|
return isNull() ? Value(kNullType) : Value(m_data, doc.GetAllocator());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::vector<xmrig::String> xmrig::String::split(char sep) const
|
||||||
|
{
|
||||||
|
std::vector<xmrig::String> out;
|
||||||
|
if (m_size == 0) {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t start = 0;
|
||||||
|
size_t pos = 0;
|
||||||
|
|
||||||
|
for (pos = 0; pos < m_size; ++pos) {
|
||||||
|
if (m_data[pos] == sep) {
|
||||||
|
if ((pos - start) > 0) {
|
||||||
|
out.push_back(std::move(String(m_data + start, pos - start)));
|
||||||
|
}
|
||||||
|
|
||||||
|
start = pos + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((pos - start) > 0) {
|
||||||
|
out.push_back(std::move(String(m_data + start, pos - start)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::String xmrig::String::join(const std::vector<xmrig::String> &vec, char sep)
|
||||||
|
{
|
||||||
|
if (vec.empty()) {
|
||||||
|
return String();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t size = vec.size();
|
||||||
|
for (const String &str : vec) {
|
||||||
|
size += str.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t offset = 0;
|
||||||
|
char *buf = new char[size];
|
||||||
|
|
||||||
|
for (const String &str : vec) {
|
||||||
|
memcpy(buf + offset, str.data(), str.size());
|
||||||
|
|
||||||
|
offset += str.size() + 1;
|
||||||
|
|
||||||
|
if (offset < size) {
|
||||||
|
buf[offset - 1] = sep;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[size - 1] = '\0';
|
||||||
|
|
||||||
|
return String(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void xmrig::String::copy(const char *str)
|
||||||
|
{
|
||||||
|
delete [] m_data;
|
||||||
|
|
||||||
|
if (str == nullptr) {
|
||||||
|
m_size = 0;
|
||||||
|
m_data = nullptr;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_size = strlen(str);
|
||||||
|
m_data = new char[m_size + 1];
|
||||||
|
|
||||||
|
memcpy(m_data, str, m_size + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void xmrig::String::copy(const String &other)
|
||||||
|
{
|
||||||
|
if (m_size > 0) {
|
||||||
|
if (m_size == other.m_size) {
|
||||||
|
memcpy(m_data, other.m_data, m_size + 1);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
delete [] m_data;
|
||||||
|
}
|
||||||
|
|
||||||
|
delete [] m_data;
|
||||||
|
|
||||||
|
if (other.m_data == nullptr) {
|
||||||
|
m_size = 0;
|
||||||
|
m_data = nullptr;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_size = other.m_size;
|
||||||
|
m_data = new char[m_size + 1];
|
||||||
|
|
||||||
|
memcpy(m_data, other.m_data, m_size + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void xmrig::String::move(char *str)
|
||||||
|
{
|
||||||
|
delete [] m_data;
|
||||||
|
|
||||||
|
m_size = str == nullptr ? 0 : strlen(str);
|
||||||
|
m_data = str;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void xmrig::String::move(String &&other)
|
||||||
|
{
|
||||||
|
delete [] m_data;
|
||||||
|
|
||||||
|
m_data = other.m_data;
|
||||||
|
m_size = other.m_size;
|
||||||
|
|
||||||
|
other.m_data = nullptr;
|
||||||
|
other.m_size = 0;
|
||||||
|
}
|
103
src/base/tools/String.h
Normal file
103
src/base/tools/String.h
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
/* XMRig
|
||||||
|
* Copyright 2010 Jeff Garzik <jgarzik@pobox.com>
|
||||||
|
* Copyright 2012-2014 pooler <pooler@litecoinpool.org>
|
||||||
|
* Copyright 2014 Lucas Jones <https://github.com/lucasjones>
|
||||||
|
* Copyright 2014-2016 Wolf9466 <https://github.com/OhGodAPet>
|
||||||
|
* Copyright 2016 Jay D Dee <jayddee246@gmail.com>
|
||||||
|
* Copyright 2017-2018 XMR-Stak <https://github.com/fireice-uk>, <https://github.com/psychocrypt>
|
||||||
|
* Copyright 2016-2018 XMRig <https://github.com/xmrig>, <support@xmrig.com>
|
||||||
|
*
|
||||||
|
* This program 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.
|
||||||
|
*
|
||||||
|
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef XMRIG_STRING_H
|
||||||
|
#define XMRIG_STRING_H
|
||||||
|
|
||||||
|
|
||||||
|
#include <utility>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
|
||||||
|
#include "rapidjson/fwd.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace xmrig {
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Simple C string wrapper.
|
||||||
|
*
|
||||||
|
* 1. I know about std:string.
|
||||||
|
* 2. For some reason I prefer don't use std:string in miner, eg because of file size of MSYS2 builds.
|
||||||
|
* 3. nullptr and JSON conversion supported.
|
||||||
|
*/
|
||||||
|
class String
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
inline String() : m_data(nullptr), m_size(0) {}
|
||||||
|
inline String(char *str) : m_data(str), m_size(str == nullptr ? 0 : strlen(str)) {}
|
||||||
|
inline String(String &&other) : m_data(other.m_data), m_size(other.m_size) { other.m_data = nullptr; other.m_size = 0; }
|
||||||
|
|
||||||
|
String(const char *str);
|
||||||
|
String(const char *str, size_t size);
|
||||||
|
String(const String &other);
|
||||||
|
|
||||||
|
inline ~String() { delete [] m_data; }
|
||||||
|
|
||||||
|
|
||||||
|
bool isEqual(const char *str) const;
|
||||||
|
bool isEqual(const String &other) const;
|
||||||
|
|
||||||
|
|
||||||
|
inline bool contains(const char *str) const { return strstr(m_data, str) != nullptr; }
|
||||||
|
|
||||||
|
|
||||||
|
inline bool isEmpty() const { return size() == 0; }
|
||||||
|
inline bool isNull() const { return m_data == nullptr; }
|
||||||
|
inline char *data() { return m_data; }
|
||||||
|
inline const char *data() const { return m_data; }
|
||||||
|
inline size_t size() const { return m_size; }
|
||||||
|
|
||||||
|
|
||||||
|
inline bool operator!=(const char *str) const { return !isEqual(str); }
|
||||||
|
inline bool operator!=(const String &other) const { return !isEqual(other); }
|
||||||
|
inline bool operator<(const String &str) const { return strcmp(data(), str.data()) < 0; }
|
||||||
|
inline bool operator==(const char *str) const { return isEqual(str); }
|
||||||
|
inline bool operator==(const String &other) const { return isEqual(other); }
|
||||||
|
inline String &operator=(char *str) { move(str); return *this; }
|
||||||
|
inline String &operator=(const char *str) { copy(str); return *this; }
|
||||||
|
inline String &operator=(const String &str) { copy(str); return *this; }
|
||||||
|
inline String &operator=(String &&other) { move(std::move(other)); return *this; }
|
||||||
|
|
||||||
|
rapidjson::Value toJSON() const;
|
||||||
|
rapidjson::Value toJSON(rapidjson::Document &doc) const;
|
||||||
|
std::vector<xmrig::String> split(char sep) const;
|
||||||
|
|
||||||
|
static String join(const std::vector<xmrig::String> &vec, char sep);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void copy(const char *str);
|
||||||
|
void copy(const String &other);
|
||||||
|
void move(char *str);
|
||||||
|
void move(String &&other);
|
||||||
|
|
||||||
|
char *m_data;
|
||||||
|
size_t m_size;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
} /* namespace xmrig */
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* XMRIG_STRING_H */
|
|
@ -280,16 +280,16 @@ bool xmrig::CommonConfig::parseBoolean(int key, bool enable)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KeepAliveKey: /* --keepalive */
|
case KeepAliveKey: /* --keepalive */
|
||||||
m_pools.back().setKeepAlive(enable ? Pool::kKeepAliveTimeout : 0);
|
currentPool().setKeepAlive(enable ? Pool::kKeepAliveTimeout : 0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TlsKey: /* --tls */
|
case TlsKey: /* --tls */
|
||||||
m_pools.back().setTLS(enable);
|
currentPool().setTLS(enable);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
# ifndef XMRIG_PROXY_PROJECT
|
# ifndef XMRIG_PROXY_PROJECT
|
||||||
case NicehashKey: /* --nicehash */
|
case NicehashKey: /* --nicehash */
|
||||||
m_pools.back().setNicehash(enable);
|
currentPool().setNicehash(enable);
|
||||||
break;
|
break;
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
@ -333,13 +333,15 @@ bool xmrig::CommonConfig::parseString(int key, const char *arg)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UserpassKey: /* --userpass */
|
case UserpassKey: /* --userpass */
|
||||||
if (!m_pools.back().setUserpass(arg)) {
|
if (!currentPool().setUserpass(arg)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UrlKey: /* --url */
|
case UrlKey: /* --url */
|
||||||
|
fixup();
|
||||||
|
|
||||||
if (m_pools.size() > 1 || m_pools[0].isValid()) {
|
if (m_pools.size() > 1 || m_pools[0].isValid()) {
|
||||||
Pool pool(arg);
|
Pool pool(arg);
|
||||||
|
|
||||||
|
@ -358,23 +360,23 @@ bool xmrig::CommonConfig::parseString(int key, const char *arg)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UserKey: /* --user */
|
case UserKey: /* --user */
|
||||||
m_pools.back().setUser(arg);
|
currentPool().setUser(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PasswordKey: /* --pass */
|
case PasswordKey: /* --pass */
|
||||||
m_pools.back().setPassword(arg);
|
currentPool().setPassword(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RigIdKey: /* --rig-id */
|
case RigIdKey: /* --rig-id */
|
||||||
m_pools.back().setRigId(arg);
|
currentPool().setRigId(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FingerprintKey: /* --tls-fingerprint */
|
case FingerprintKey: /* --tls-fingerprint */
|
||||||
m_pools.back().setFingerprint(arg);
|
currentPool().setFingerprint(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VariantKey: /* --variant */
|
case VariantKey: /* --variant */
|
||||||
m_pools.back().algorithm().parseVariant(arg);
|
currentPool().algorithm().parseVariant(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LogFileKey: /* --log-file */
|
case LogFileKey: /* --log-file */
|
||||||
|
@ -462,11 +464,11 @@ bool xmrig::CommonConfig::parseInt(int key, int arg)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KeepAliveKey: /* --keepalive */
|
case KeepAliveKey: /* --keepalive */
|
||||||
m_pools.back().setKeepAlive(arg);
|
currentPool().setKeepAlive(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VariantKey: /* --variant */
|
case VariantKey: /* --variant */
|
||||||
m_pools.back().algorithm().parseVariant(arg);
|
currentPool().algorithm().parseVariant(arg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DonateLevelKey: /* --donate-level */
|
case DonateLevelKey: /* --donate-level */
|
||||||
|
@ -493,3 +495,30 @@ bool xmrig::CommonConfig::parseInt(int key, int arg)
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Pool &xmrig::CommonConfig::currentPool()
|
||||||
|
{
|
||||||
|
fixup();
|
||||||
|
|
||||||
|
return m_pools.back();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void xmrig::CommonConfig::fixup()
|
||||||
|
{
|
||||||
|
if (m_state == NoneState) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_pools.empty()) {
|
||||||
|
if (!m_activePools.empty()) {
|
||||||
|
std::swap(m_pools, m_activePools);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
m_pools.push_back(Pool());
|
||||||
|
}
|
||||||
|
|
||||||
|
m_state = NoneState;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -112,9 +112,11 @@ protected:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool parseInt(int key, int arg);
|
bool parseInt(int key, int arg);
|
||||||
|
Pool ¤tPool();
|
||||||
|
void fixup();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
} /* namespace xmrig */
|
} /* namespace xmrig */
|
||||||
|
|
||||||
#endif /* __COMMONCONFIG_H__ */
|
#endif /* XMRIG_COMMONCONFIG_H */
|
||||||
|
|
|
@ -97,16 +97,23 @@ public:
|
||||||
OclCompModeKey = 1410,
|
OclCompModeKey = 1410,
|
||||||
|
|
||||||
// xmrig-proxy
|
// xmrig-proxy
|
||||||
AccessLogFileKey = 'A',
|
AccessLogFileKey = 'A',
|
||||||
BindKey = 'b',
|
BindKey = 'b',
|
||||||
CoinKey = 1104,
|
CoinKey = 1104,
|
||||||
CustomDiffKey = 1102,
|
CustomDiffKey = 1102,
|
||||||
DebugKey = 1101,
|
DebugKey = 1101,
|
||||||
ModeKey = 'm',
|
ModeKey = 'm',
|
||||||
PoolCoinKey = 'C',
|
PoolCoinKey = 'C',
|
||||||
ReuseTimeoutKey = 1106,
|
ReuseTimeoutKey = 1106,
|
||||||
WorkersKey = 1103,
|
WorkersKey = 1103,
|
||||||
WorkersAdvKey = 1107,
|
WorkersAdvKey = 1107,
|
||||||
|
TlsBindKey = 1108,
|
||||||
|
TlsCertKey = 1109,
|
||||||
|
TlsCertKeyKey = 1110,
|
||||||
|
TlsDHparamKey = 1111,
|
||||||
|
TlsCiphersKey = 1112,
|
||||||
|
TlsCipherSuitesKey = 1113,
|
||||||
|
TlsProtocolsKey = 1114,
|
||||||
|
|
||||||
// xmrig nvidia
|
// xmrig nvidia
|
||||||
CudaMaxThreadsKey = 1200,
|
CudaMaxThreadsKey = 1200,
|
||||||
|
|
|
@ -21,8 +21,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __LOG_H__
|
#ifndef XMRIG_LOG_H
|
||||||
#define __LOG_H__
|
#define XMRIG_LOG_H
|
||||||
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
@ -39,7 +39,7 @@ public:
|
||||||
static inline Log* i() { if (!m_self) { defaultInit(); } return m_self; }
|
static inline Log* i() { if (!m_self) { defaultInit(); } return m_self; }
|
||||||
static inline void add(ILogBackend *backend) { i()->m_backends.push_back(backend); }
|
static inline void add(ILogBackend *backend) { i()->m_backends.push_back(backend); }
|
||||||
static inline void init() { if (!m_self) { new Log(); } }
|
static inline void init() { if (!m_self) { new Log(); } }
|
||||||
static inline void release() { assert(m_self != nullptr); delete m_self; }
|
static inline void release() { delete m_self; }
|
||||||
|
|
||||||
void message(ILogBackend::Level level, const char* fmt, ...);
|
void message(ILogBackend::Level level, const char* fmt, ...);
|
||||||
void text(const char* fmt, ...);
|
void text(const char* fmt, ...);
|
||||||
|
@ -98,4 +98,4 @@ private:
|
||||||
# define LOG_DEBUG_WARN(x, ...)
|
# define LOG_DEBUG_WARN(x, ...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* __LOG_H__ */
|
#endif /* XMRIG_LOG_H */
|
||||||
|
|
|
@ -21,8 +21,8 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef XMRIG_TLS_H
|
#ifndef XMRIG_CLIENT_TLS_H
|
||||||
#define XMRIG_TLS_H
|
#define XMRIG_CLIENT_TLS_H
|
||||||
|
|
||||||
|
|
||||||
#include <openssl/ssl.h>
|
#include <openssl/ssl.h>
|
||||||
|
@ -59,4 +59,4 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif /* XMRIG_TLS_H */
|
#endif /* XMRIG_CLIENT_TLS_H */
|
||||||
|
|
|
@ -21,82 +21,19 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __C_STR_H__
|
#ifndef XMRIG_C_STR_H
|
||||||
#define __C_STR_H__
|
#define XMRIG_C_STR_H
|
||||||
|
|
||||||
|
|
||||||
#include <string.h>
|
#include "base/tools/String.h"
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
|
|
||||||
namespace xmrig {
|
namespace xmrig {
|
||||||
|
|
||||||
|
|
||||||
/**
|
typedef String c_str;
|
||||||
* @brief Simple C string wrapper.
|
|
||||||
*
|
|
||||||
* 1. I know about std:string.
|
|
||||||
* 2. For some reason I prefer don't use std:string in miner, eg because of file size of MSYS2 builds.
|
|
||||||
*/
|
|
||||||
class c_str
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
inline c_str() : m_data(nullptr) {}
|
|
||||||
inline c_str(c_str &&other) { m_data = other.m_data; other.m_data = nullptr; }
|
|
||||||
inline c_str(const c_str &other) : m_data(nullptr) { set(other.data()); }
|
|
||||||
inline c_str(const char *str) : m_data(nullptr) { set(str); }
|
|
||||||
inline ~c_str() { free(m_data); }
|
|
||||||
|
|
||||||
|
|
||||||
inline void set(const char *str)
|
|
||||||
{
|
|
||||||
free(m_data);
|
|
||||||
|
|
||||||
m_data = str != nullptr ? strdup(str) : nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void set(char *str)
|
|
||||||
{
|
|
||||||
free(m_data);
|
|
||||||
|
|
||||||
m_data = str;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline bool isEqual(const char *str) const
|
|
||||||
{
|
|
||||||
return (m_data != nullptr && str != nullptr && strcmp(m_data, str) == 0) || (m_data == nullptr && m_data == nullptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline bool contains(const char *str) const
|
|
||||||
{
|
|
||||||
return strstr(m_data, str) != nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline bool isNull() const { return m_data == nullptr; }
|
|
||||||
inline const char *data() const { return m_data; }
|
|
||||||
inline size_t size() const { return m_data == nullptr ? 0 : strlen(m_data); }
|
|
||||||
|
|
||||||
|
|
||||||
inline bool operator!=(const c_str &str) const { return !isEqual(str.data()); }
|
|
||||||
inline bool operator!=(const char *str) const { return !isEqual(str); }
|
|
||||||
inline bool operator==(const c_str &str) const { return isEqual(str.data()); }
|
|
||||||
inline bool operator==(const char *str) const { return isEqual(str); }
|
|
||||||
inline c_str &operator=(char *str) { set(str); return *this; }
|
|
||||||
inline c_str &operator=(const c_str &str) { set(str.data()); return *this; }
|
|
||||||
inline c_str &operator=(const char *str) { set(str); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
private:
|
|
||||||
char *m_data;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
} /* namespace xmrig */
|
} /* namespace xmrig */
|
||||||
|
|
||||||
#endif /* __C_STR_H__ */
|
#endif /* XMRIG_C_STR_H */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue