mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-15 23:20:06 +02:00
Net Windows automatic (un)initialize
automatic network (un)initialization on windows NumericString 64-bit compile/warning fixes
This commit is contained in:
@@ -221,7 +221,7 @@ namespace Impl {
|
|||||||
/// Class ensures increment/decrement remain within boundaries.
|
/// Class ensures increment/decrement remain within boundaries.
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Ptr(char* ptr, unsigned offset): _beg(ptr), _cur(ptr), _end(ptr + offset)
|
Ptr(char* ptr, std::size_t offset): _beg(ptr), _cur(ptr), _end(ptr + offset)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -268,7 +268,7 @@ namespace Impl {
|
|||||||
return _cur;
|
return _cur;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned span() const
|
std::size_t span() const
|
||||||
{
|
{
|
||||||
return _end - _beg;
|
return _end - _beg;
|
||||||
}
|
}
|
||||||
@@ -291,7 +291,7 @@ template <typename T>
|
|||||||
bool intToStr(T value,
|
bool intToStr(T value,
|
||||||
unsigned short base,
|
unsigned short base,
|
||||||
char* result,
|
char* result,
|
||||||
unsigned& size,
|
std::size_t& size,
|
||||||
bool prefix = false,
|
bool prefix = false,
|
||||||
int width = -1,
|
int width = -1,
|
||||||
char fill = ' ',
|
char fill = ' ',
|
||||||
@@ -369,7 +369,7 @@ template <typename T>
|
|||||||
bool uIntToStr(T value,
|
bool uIntToStr(T value,
|
||||||
unsigned short base,
|
unsigned short base,
|
||||||
char* result,
|
char* result,
|
||||||
unsigned& size,
|
std::size_t& size,
|
||||||
bool prefix = false,
|
bool prefix = false,
|
||||||
int width = -1,
|
int width = -1,
|
||||||
char fill = ' ',
|
char fill = ' ',
|
||||||
@@ -446,7 +446,7 @@ bool intToStr (T number, unsigned short base, std::string& result, bool prefix =
|
|||||||
/// bool intToStr(T, unsigned short, char*, int, int, char, char) implementation.
|
/// bool intToStr(T, unsigned short, char*, int, int, char, char) implementation.
|
||||||
{
|
{
|
||||||
char res[POCO_MAX_INT_STRING_LEN] = {0};
|
char res[POCO_MAX_INT_STRING_LEN] = {0};
|
||||||
unsigned size = POCO_MAX_INT_STRING_LEN;
|
std::size_t size = POCO_MAX_INT_STRING_LEN;
|
||||||
bool ret = intToStr(number, base, res, size, prefix, width, fill, thSep);
|
bool ret = intToStr(number, base, res, size, prefix, width, fill, thSep);
|
||||||
result.assign(res, size);
|
result.assign(res, size);
|
||||||
return ret;
|
return ret;
|
||||||
@@ -459,7 +459,7 @@ bool uIntToStr (T number, unsigned short base, std::string& result, bool prefix
|
|||||||
/// bool uIntToStr(T, unsigned short, char*, int, int, char, char) implementation.
|
/// bool uIntToStr(T, unsigned short, char*, int, int, char, char) implementation.
|
||||||
{
|
{
|
||||||
char res[POCO_MAX_INT_STRING_LEN] = {0};
|
char res[POCO_MAX_INT_STRING_LEN] = {0};
|
||||||
unsigned size = POCO_MAX_INT_STRING_LEN;
|
std::size_t size = POCO_MAX_INT_STRING_LEN;
|
||||||
bool ret = uIntToStr(number, base, res, size, prefix, width, fill, thSep);
|
bool ret = uIntToStr(number, base, res, size, prefix, width, fill, thSep);
|
||||||
result.assign(res, size);
|
result.assign(res, size);
|
||||||
return ret;
|
return ret;
|
||||||
|
@@ -79,7 +79,7 @@ std::string NumberFormatter::format(bool value, BoolFormat format)
|
|||||||
void NumberFormatter::append(std::string& str, int value)
|
void NumberFormatter::append(std::string& str, int value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz);
|
intToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -88,7 +88,7 @@ void NumberFormatter::append(std::string& str, int value)
|
|||||||
void NumberFormatter::append(std::string& str, int value, int width)
|
void NumberFormatter::append(std::string& str, int value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width);
|
intToStr(value, 10, result, sz, false, width);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -97,7 +97,7 @@ void NumberFormatter::append(std::string& str, int value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, int value, int width)
|
void NumberFormatter::append0(std::string& str, int value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width, '0');
|
intToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -106,7 +106,7 @@ void NumberFormatter::append0(std::string& str, int value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, int value)
|
void NumberFormatter::appendHex(std::string& str, int value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<unsigned int>(value), 0x10, result, sz);
|
uIntToStr(static_cast<unsigned int>(value), 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -115,7 +115,7 @@ void NumberFormatter::appendHex(std::string& str, int value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, int value, int width)
|
void NumberFormatter::appendHex(std::string& str, int value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<unsigned int>(value), 0x10, result, sz, false, width, '0');
|
uIntToStr(static_cast<unsigned int>(value), 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -124,7 +124,7 @@ void NumberFormatter::appendHex(std::string& str, int value, int width)
|
|||||||
void NumberFormatter::append(std::string& str, unsigned value)
|
void NumberFormatter::append(std::string& str, unsigned value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz);
|
uIntToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -133,7 +133,7 @@ void NumberFormatter::append(std::string& str, unsigned value)
|
|||||||
void NumberFormatter::append(std::string& str, unsigned value, int width)
|
void NumberFormatter::append(std::string& str, unsigned value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width);
|
uIntToStr(value, 10, result, sz, false, width);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -142,7 +142,7 @@ void NumberFormatter::append(std::string& str, unsigned value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, unsigned int value, int width)
|
void NumberFormatter::append0(std::string& str, unsigned int value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width, '0');
|
uIntToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -151,7 +151,7 @@ void NumberFormatter::append0(std::string& str, unsigned int value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, unsigned value)
|
void NumberFormatter::appendHex(std::string& str, unsigned value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz);
|
uIntToStr(value, 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -160,7 +160,7 @@ void NumberFormatter::appendHex(std::string& str, unsigned value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, unsigned value, int width)
|
void NumberFormatter::appendHex(std::string& str, unsigned value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -169,7 +169,7 @@ void NumberFormatter::appendHex(std::string& str, unsigned value, int width)
|
|||||||
void NumberFormatter::append(std::string& str, long value)
|
void NumberFormatter::append(std::string& str, long value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz);
|
intToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -178,7 +178,7 @@ void NumberFormatter::append(std::string& str, long value)
|
|||||||
void NumberFormatter::append(std::string& str, long value, int width)
|
void NumberFormatter::append(std::string& str, long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width);
|
intToStr(value, 10, result, sz, false, width);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -187,7 +187,7 @@ void NumberFormatter::append(std::string& str, long value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, long value, int width)
|
void NumberFormatter::append0(std::string& str, long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width, '0');
|
intToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -196,7 +196,7 @@ void NumberFormatter::append0(std::string& str, long value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, long value)
|
void NumberFormatter::appendHex(std::string& str, long value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<unsigned long>(value), 0x10, result, sz);
|
uIntToStr(static_cast<unsigned long>(value), 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -205,7 +205,7 @@ void NumberFormatter::appendHex(std::string& str, long value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, long value, int width)
|
void NumberFormatter::appendHex(std::string& str, long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<unsigned long>(value), 0x10, result, sz, false, width, '0');
|
uIntToStr(static_cast<unsigned long>(value), 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -214,7 +214,7 @@ void NumberFormatter::appendHex(std::string& str, long value, int width)
|
|||||||
void NumberFormatter::append(std::string& str, unsigned long value)
|
void NumberFormatter::append(std::string& str, unsigned long value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz);
|
uIntToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -223,7 +223,7 @@ void NumberFormatter::append(std::string& str, unsigned long value)
|
|||||||
void NumberFormatter::append(std::string& str, unsigned long value, int width)
|
void NumberFormatter::append(std::string& str, unsigned long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width, '0');
|
uIntToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -232,7 +232,7 @@ void NumberFormatter::append(std::string& str, unsigned long value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, unsigned long value, int width)
|
void NumberFormatter::append0(std::string& str, unsigned long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width, '0');
|
uIntToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -241,7 +241,7 @@ void NumberFormatter::append0(std::string& str, unsigned long value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, unsigned long value)
|
void NumberFormatter::appendHex(std::string& str, unsigned long value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz);
|
uIntToStr(value, 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -250,7 +250,7 @@ void NumberFormatter::appendHex(std::string& str, unsigned long value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, unsigned long value, int width)
|
void NumberFormatter::appendHex(std::string& str, unsigned long value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -262,7 +262,7 @@ void NumberFormatter::appendHex(std::string& str, unsigned long value, int width
|
|||||||
void NumberFormatter::append(std::string& str, Int64 value)
|
void NumberFormatter::append(std::string& str, Int64 value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz);
|
intToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -271,7 +271,7 @@ void NumberFormatter::append(std::string& str, Int64 value)
|
|||||||
void NumberFormatter::append(std::string& str, Int64 value, int width)
|
void NumberFormatter::append(std::string& str, Int64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width, '0');
|
intToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -280,7 +280,7 @@ void NumberFormatter::append(std::string& str, Int64 value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, Int64 value, int width)
|
void NumberFormatter::append0(std::string& str, Int64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
intToStr(value, 10, result, sz, false, width, '0');
|
intToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -289,7 +289,7 @@ void NumberFormatter::append0(std::string& str, Int64 value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, Int64 value)
|
void NumberFormatter::appendHex(std::string& str, Int64 value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<UInt64>(value), 0x10, result, sz);
|
uIntToStr(static_cast<UInt64>(value), 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -298,7 +298,7 @@ void NumberFormatter::appendHex(std::string& str, Int64 value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, Int64 value, int width)
|
void NumberFormatter::appendHex(std::string& str, Int64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(static_cast<UInt64>(value), 0x10, result, sz, false, width, '0');
|
uIntToStr(static_cast<UInt64>(value), 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -307,7 +307,7 @@ void NumberFormatter::appendHex(std::string& str, Int64 value, int width)
|
|||||||
void NumberFormatter::append(std::string& str, UInt64 value)
|
void NumberFormatter::append(std::string& str, UInt64 value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz);
|
uIntToStr(value, 10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -316,7 +316,7 @@ void NumberFormatter::append(std::string& str, UInt64 value)
|
|||||||
void NumberFormatter::append(std::string& str, UInt64 value, int width)
|
void NumberFormatter::append(std::string& str, UInt64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width, '0');
|
uIntToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -325,7 +325,7 @@ void NumberFormatter::append(std::string& str, UInt64 value, int width)
|
|||||||
void NumberFormatter::append0(std::string& str, UInt64 value, int width)
|
void NumberFormatter::append0(std::string& str, UInt64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 10, result, sz, false, width, '0');
|
uIntToStr(value, 10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -334,7 +334,7 @@ void NumberFormatter::append0(std::string& str, UInt64 value, int width)
|
|||||||
void NumberFormatter::appendHex(std::string& str, UInt64 value)
|
void NumberFormatter::appendHex(std::string& str, UInt64 value)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz);
|
uIntToStr(value, 0x10, result, sz);
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
@@ -343,7 +343,7 @@ void NumberFormatter::appendHex(std::string& str, UInt64 value)
|
|||||||
void NumberFormatter::appendHex(std::string& str, UInt64 value, int width)
|
void NumberFormatter::appendHex(std::string& str, UInt64 value, int width)
|
||||||
{
|
{
|
||||||
char result[NF_MAX_INT_STRING_LEN];
|
char result[NF_MAX_INT_STRING_LEN];
|
||||||
unsigned sz = NF_MAX_INT_STRING_LEN;
|
std::size_t sz = NF_MAX_INT_STRING_LEN;
|
||||||
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
uIntToStr(value, 0x10, result, sz, false, width, '0');
|
||||||
str.append(result, sz);
|
str.append(result, sz);
|
||||||
}
|
}
|
||||||
|
@@ -175,7 +175,7 @@ float strToFloat(const char* str)
|
|||||||
int flags = StringToDoubleConverter::ALLOW_LEADING_SPACES |
|
int flags = StringToDoubleConverter::ALLOW_LEADING_SPACES |
|
||||||
StringToDoubleConverter::ALLOW_TRAILING_SPACES;
|
StringToDoubleConverter::ALLOW_TRAILING_SPACES;
|
||||||
StringToDoubleConverter converter(flags, 0.0, Single::NaN(), POCO_FLT_INF, POCO_FLT_NAN);
|
StringToDoubleConverter converter(flags, 0.0, Single::NaN(), POCO_FLT_INF, POCO_FLT_NAN);
|
||||||
float result = converter.StringToFloat(str, strlen(str), &processed);
|
float result = converter.StringToFloat(str, static_cast<int>(strlen(str)), &processed);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -187,7 +187,7 @@ double strToDouble(const char* str)
|
|||||||
int flags = StringToDoubleConverter::ALLOW_LEADING_SPACES |
|
int flags = StringToDoubleConverter::ALLOW_LEADING_SPACES |
|
||||||
StringToDoubleConverter::ALLOW_TRAILING_SPACES;
|
StringToDoubleConverter::ALLOW_TRAILING_SPACES;
|
||||||
StringToDoubleConverter converter(flags, 0.0, Double::NaN(), POCO_FLT_INF, POCO_FLT_NAN);
|
StringToDoubleConverter converter(flags, 0.0, Double::NaN(), POCO_FLT_INF, POCO_FLT_NAN);
|
||||||
double result = converter.StringToDouble(str, strlen(str), &processed);
|
double result = converter.StringToDouble(str, static_cast<int>(strlen(str)), &processed);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -83,7 +83,7 @@ StringTokenizer::~StringTokenizer()
|
|||||||
|
|
||||||
void StringTokenizer::trim (std::string& token)
|
void StringTokenizer::trim (std::string& token)
|
||||||
{
|
{
|
||||||
int front = 0, back = 0, length = token.length();
|
std::size_t front = 0, back = 0, length = token.length();
|
||||||
std::string::const_iterator tIt = token.begin();
|
std::string::const_iterator tIt = token.begin();
|
||||||
std::string::const_iterator tEnd = token.end();
|
std::string::const_iterator tEnd = token.end();
|
||||||
for (; tIt != tEnd; ++tIt, ++front)
|
for (; tIt != tEnd; ++tIt, ++front)
|
||||||
|
@@ -457,6 +457,8 @@
|
|||||||
RelativePath=".\src\HostEntry.cpp"/>
|
RelativePath=".\src\HostEntry.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\IPAddress.cpp"/>
|
RelativePath=".\src\IPAddress.cpp"/>
|
||||||
|
<File
|
||||||
|
RelativePath=".\src\Net.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\NetException.cpp"/>
|
RelativePath=".\src\NetException.cpp"/>
|
||||||
<File
|
<File
|
||||||
|
@@ -367,6 +367,7 @@
|
|||||||
<ClCompile Include="src\DNS.cpp" />
|
<ClCompile Include="src\DNS.cpp" />
|
||||||
<ClCompile Include="src\HostEntry.cpp" />
|
<ClCompile Include="src\HostEntry.cpp" />
|
||||||
<ClCompile Include="src\IPAddress.cpp" />
|
<ClCompile Include="src\IPAddress.cpp" />
|
||||||
|
<ClCompile Include="src\Net.cpp" />
|
||||||
<ClCompile Include="src\NetException.cpp" />
|
<ClCompile Include="src\NetException.cpp" />
|
||||||
<ClCompile Include="src\NetworkInterface.cpp" />
|
<ClCompile Include="src\NetworkInterface.cpp" />
|
||||||
<ClCompile Include="src\SocketAddress.cpp" />
|
<ClCompile Include="src\SocketAddress.cpp" />
|
||||||
|
@@ -686,6 +686,9 @@
|
|||||||
<ClCompile Include="src\WebSocketImpl.cpp">
|
<ClCompile Include="src\WebSocketImpl.cpp">
|
||||||
<Filter>WebSocket\Source Files</Filter>
|
<Filter>WebSocket\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="src\Net.cpp">
|
||||||
|
<Filter>NetCore\Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ResourceCompile Include="..\DLLVersion.rc" />
|
<ResourceCompile Include="..\DLLVersion.rc" />
|
||||||
|
@@ -373,6 +373,7 @@
|
|||||||
<ClCompile Include="src\DNS.cpp"/>
|
<ClCompile Include="src\DNS.cpp"/>
|
||||||
<ClCompile Include="src\HostEntry.cpp"/>
|
<ClCompile Include="src\HostEntry.cpp"/>
|
||||||
<ClCompile Include="src\IPAddress.cpp"/>
|
<ClCompile Include="src\IPAddress.cpp"/>
|
||||||
|
<ClCompile Include="src\Net.cpp"/>
|
||||||
<ClCompile Include="src\NetException.cpp"/>
|
<ClCompile Include="src\NetException.cpp"/>
|
||||||
<ClCompile Include="src\NetworkInterface.cpp"/>
|
<ClCompile Include="src\NetworkInterface.cpp"/>
|
||||||
<ClCompile Include="src\SocketAddress.cpp"/>
|
<ClCompile Include="src\SocketAddress.cpp"/>
|
||||||
|
@@ -425,6 +425,9 @@
|
|||||||
<ClCompile Include="src\IPAddress.cpp">
|
<ClCompile Include="src\IPAddress.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="src\Net.cpp">
|
||||||
|
<Filter>NetCore\Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="src\NetException.cpp">
|
<ClCompile Include="src\NetException.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@@ -389,6 +389,8 @@
|
|||||||
RelativePath=".\src\HostEntry.cpp"/>
|
RelativePath=".\src\HostEntry.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\IPAddress.cpp"/>
|
RelativePath=".\src\IPAddress.cpp"/>
|
||||||
|
<File
|
||||||
|
RelativePath=".\src\Net.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\NetException.cpp"/>
|
RelativePath=".\src\NetException.cpp"/>
|
||||||
<File
|
<File
|
||||||
|
@@ -410,6 +410,8 @@
|
|||||||
RelativePath=".\src\HostEntry.cpp"/>
|
RelativePath=".\src\HostEntry.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\IPAddress.cpp"/>
|
RelativePath=".\src\IPAddress.cpp"/>
|
||||||
|
<File
|
||||||
|
RelativePath=".\src\Net.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\NetException.cpp"/>
|
RelativePath=".\src\NetException.cpp"/>
|
||||||
<File
|
<File
|
||||||
|
@@ -409,6 +409,8 @@
|
|||||||
RelativePath=".\src\HostEntry.cpp"/>
|
RelativePath=".\src\HostEntry.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\IPAddress.cpp"/>
|
RelativePath=".\src\IPAddress.cpp"/>
|
||||||
|
<File
|
||||||
|
RelativePath=".\src\Net.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\NetException.cpp"/>
|
RelativePath=".\src\NetException.cpp"/>
|
||||||
<File
|
<File
|
||||||
|
@@ -365,6 +365,7 @@
|
|||||||
<ClCompile Include="src\DNS.cpp"/>
|
<ClCompile Include="src\DNS.cpp"/>
|
||||||
<ClCompile Include="src\HostEntry.cpp"/>
|
<ClCompile Include="src\HostEntry.cpp"/>
|
||||||
<ClCompile Include="src\IPAddress.cpp"/>
|
<ClCompile Include="src\IPAddress.cpp"/>
|
||||||
|
<ClCompile Include="src\Net.cpp"/>
|
||||||
<ClCompile Include="src\NetException.cpp"/>
|
<ClCompile Include="src\NetException.cpp"/>
|
||||||
<ClCompile Include="src\NetworkInterface.cpp"/>
|
<ClCompile Include="src\NetworkInterface.cpp"/>
|
||||||
<ClCompile Include="src\SocketAddress.cpp"/>
|
<ClCompile Include="src\SocketAddress.cpp"/>
|
||||||
|
@@ -425,6 +425,9 @@
|
|||||||
<ClCompile Include="src\IPAddress.cpp">
|
<ClCompile Include="src\IPAddress.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="src\Net.cpp">
|
||||||
|
<Filter>NetCore\Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="src\NetException.cpp">
|
<ClCompile Include="src\NetException.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@@ -371,6 +371,7 @@
|
|||||||
<ClCompile Include="src\DNS.cpp"/>
|
<ClCompile Include="src\DNS.cpp"/>
|
||||||
<ClCompile Include="src\HostEntry.cpp"/>
|
<ClCompile Include="src\HostEntry.cpp"/>
|
||||||
<ClCompile Include="src\IPAddress.cpp"/>
|
<ClCompile Include="src\IPAddress.cpp"/>
|
||||||
|
<ClCompile Include="src\Net.cpp"/>
|
||||||
<ClCompile Include="src\NetException.cpp"/>
|
<ClCompile Include="src\NetException.cpp"/>
|
||||||
<ClCompile Include="src\NetworkInterface.cpp"/>
|
<ClCompile Include="src\NetworkInterface.cpp"/>
|
||||||
<ClCompile Include="src\SocketAddress.cpp"/>
|
<ClCompile Include="src\SocketAddress.cpp"/>
|
||||||
|
@@ -425,6 +425,9 @@
|
|||||||
<ClCompile Include="src\IPAddress.cpp">
|
<ClCompile Include="src\IPAddress.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="src\Net.cpp">
|
||||||
|
<Filter>NetCore\Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="src\NetException.cpp">
|
<ClCompile Include="src\NetException.cpp">
|
||||||
<Filter>NetCore\Source Files</Filter>
|
<Filter>NetCore\Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@@ -414,6 +414,8 @@
|
|||||||
RelativePath=".\src\HostEntry.cpp"/>
|
RelativePath=".\src\HostEntry.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\IPAddress.cpp"/>
|
RelativePath=".\src\IPAddress.cpp"/>
|
||||||
|
<File
|
||||||
|
RelativePath=".\src\Net.cpp"/>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\NetException.cpp"/>
|
RelativePath=".\src\NetException.cpp"/>
|
||||||
<File
|
<File
|
||||||
|
@@ -81,25 +81,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
namespace Poco {
|
|
||||||
namespace Net {
|
|
||||||
|
|
||||||
|
|
||||||
void Net_API initializeNetwork();
|
|
||||||
/// Initialize the network subsystem.
|
|
||||||
/// Calls WSAStartup() on Windows, does nothing
|
|
||||||
/// on other platforms.
|
|
||||||
|
|
||||||
|
|
||||||
void Net_API uninitializeNetwork();
|
|
||||||
/// Uninitialize the network subsystem.
|
|
||||||
/// Calls WSACleanup() on Windows, does nothing
|
|
||||||
/// on other platforms.
|
|
||||||
|
|
||||||
|
|
||||||
} } // namespace Poco::Net
|
|
||||||
|
|
||||||
|
|
||||||
// Default to enabled IPv6 support if not explicitly disabled
|
// Default to enabled IPv6 support if not explicitly disabled
|
||||||
#if !defined(POCO_NET_NO_IPv6) && !defined (POCO_HAVE_IPv6)
|
#if !defined(POCO_NET_NO_IPv6) && !defined (POCO_HAVE_IPv6)
|
||||||
#define POCO_HAVE_IPv6
|
#define POCO_HAVE_IPv6
|
||||||
@@ -128,4 +109,29 @@ void Net_API uninitializeNetwork();
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
namespace Poco {
|
||||||
|
namespace Net {
|
||||||
|
|
||||||
|
|
||||||
|
inline void Net_API initializeNetwork();
|
||||||
|
/// Initialize the network subsystem.
|
||||||
|
|
||||||
|
|
||||||
|
inline void Net_API uninitializeNetwork();
|
||||||
|
/// Uninitialize the network subsystem.
|
||||||
|
|
||||||
|
}} // namespace Poco::Net
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Automate network initialization on Windows.
|
||||||
|
//
|
||||||
|
#if defined(POCO_OS_FAMILY_WINDOWS) && !defined(POCO_NET_NO_WINDOWS_INIT)
|
||||||
|
#if defined(POCO_STATIC)
|
||||||
|
extern "C" const struct NetworkInitializer pocoNetworkInitializer;
|
||||||
|
#pragma comment(linker, "/include:_pocoNetworkInitializer")
|
||||||
|
#endif // POCO_STATIC
|
||||||
|
#endif // POCO_NET_NO_WINDOWS_INIT
|
||||||
|
|
||||||
|
|
||||||
#endif // Net_Net_INCLUDED
|
#endif // Net_Net_INCLUDED
|
||||||
|
@@ -49,32 +49,12 @@ using Poco::NumberFormatter;
|
|||||||
using Poco::IOException;
|
using Poco::IOException;
|
||||||
|
|
||||||
|
|
||||||
namespace
|
|
||||||
{
|
|
||||||
class NetworkInitializer
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NetworkInitializer()
|
|
||||||
{
|
|
||||||
Poco::Net::initializeNetwork();
|
|
||||||
}
|
|
||||||
|
|
||||||
~NetworkInitializer()
|
|
||||||
{
|
|
||||||
Poco::Net::uninitializeNetwork();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
namespace Poco {
|
namespace Poco {
|
||||||
namespace Net {
|
namespace Net {
|
||||||
|
|
||||||
|
|
||||||
HostEntry DNS::hostByName(const std::string& hostname)
|
HostEntry DNS::hostByName(const std::string& hostname)
|
||||||
{
|
{
|
||||||
NetworkInitializer networkInitializer;
|
|
||||||
|
|
||||||
#if defined(POCO_HAVE_IPv6) || defined(POCO_HAVE_ADDRINFO)
|
#if defined(POCO_HAVE_IPv6) || defined(POCO_HAVE_ADDRINFO)
|
||||||
struct addrinfo* pAI;
|
struct addrinfo* pAI;
|
||||||
struct addrinfo hints;
|
struct addrinfo hints;
|
||||||
@@ -111,8 +91,6 @@ HostEntry DNS::hostByName(const std::string& hostname)
|
|||||||
|
|
||||||
HostEntry DNS::hostByAddress(const IPAddress& address)
|
HostEntry DNS::hostByAddress(const IPAddress& address)
|
||||||
{
|
{
|
||||||
NetworkInitializer networkInitializer;
|
|
||||||
|
|
||||||
#if defined(POCO_HAVE_IPv6) || defined(POCO_HAVE_ADDRINFO)
|
#if defined(POCO_HAVE_IPv6) || defined(POCO_HAVE_ADDRINFO)
|
||||||
SocketAddress sa(address, 0);
|
SocketAddress sa(address, 0);
|
||||||
static char fqname[1024];
|
static char fqname[1024];
|
||||||
@@ -160,8 +138,6 @@ HostEntry DNS::hostByAddress(const IPAddress& address)
|
|||||||
|
|
||||||
HostEntry DNS::resolve(const std::string& address)
|
HostEntry DNS::resolve(const std::string& address)
|
||||||
{
|
{
|
||||||
NetworkInitializer networkInitializer;
|
|
||||||
|
|
||||||
IPAddress ip;
|
IPAddress ip;
|
||||||
if (IPAddress::tryParse(address, ip))
|
if (IPAddress::tryParse(address, ip))
|
||||||
return hostByAddress(ip);
|
return hostByAddress(ip);
|
||||||
@@ -172,8 +148,6 @@ HostEntry DNS::resolve(const std::string& address)
|
|||||||
|
|
||||||
IPAddress DNS::resolveOne(const std::string& address)
|
IPAddress DNS::resolveOne(const std::string& address)
|
||||||
{
|
{
|
||||||
NetworkInitializer networkInitializer;
|
|
||||||
|
|
||||||
const HostEntry& entry = resolve(address);
|
const HostEntry& entry = resolve(address);
|
||||||
if (!entry.addresses().empty())
|
if (!entry.addresses().empty())
|
||||||
return entry.addresses()[0];
|
return entry.addresses()[0];
|
||||||
@@ -195,8 +169,6 @@ void DNS::flushCache()
|
|||||||
|
|
||||||
std::string DNS::hostName()
|
std::string DNS::hostName()
|
||||||
{
|
{
|
||||||
NetworkInitializer networkInitializer;
|
|
||||||
|
|
||||||
char buffer[256];
|
char buffer[256];
|
||||||
int rc = gethostname(buffer, sizeof(buffer));
|
int rc = gethostname(buffer, sizeof(buffer));
|
||||||
if (rc == 0)
|
if (rc == 0)
|
||||||
|
@@ -116,16 +116,10 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
IPAddressImpl()
|
IPAddressImpl()
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::initializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~IPAddressImpl()
|
virtual ~IPAddressImpl()
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::uninitializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
117
Net/src/Net.cpp
Normal file
117
Net/src/Net.cpp
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
//
|
||||||
|
// Net.cpp
|
||||||
|
//
|
||||||
|
// $Id: //poco/1.4/Net/src/Net.cpp#10 $
|
||||||
|
//
|
||||||
|
// Library: Net
|
||||||
|
// Package: NetCore
|
||||||
|
// Module: NetCore
|
||||||
|
//
|
||||||
|
// Copyright (c) 2005-2006, Applied Informatics Software Engineering GmbH.
|
||||||
|
// and Contributors.
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person or organization
|
||||||
|
// obtaining a copy of the software and accompanying documentation covered by
|
||||||
|
// this license (the "Software") to use, reproduce, display, distribute,
|
||||||
|
// execute, and transmit the Software, and to prepare derivative works of the
|
||||||
|
// Software, and to permit third-parties to whom the Software is furnished to
|
||||||
|
// do so, all subject to the following:
|
||||||
|
//
|
||||||
|
// The copyright notices in the Software and this entire statement, including
|
||||||
|
// the above license grant, this restriction and the following disclaimer,
|
||||||
|
// must be included in all copies of the Software, in whole or in part, and
|
||||||
|
// all derivative works of the Software, unless such copies or derivative
|
||||||
|
// works are solely in the form of machine-executable object code generated by
|
||||||
|
// a source language processor.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
||||||
|
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
||||||
|
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
||||||
|
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
// DEALINGS IN THE SOFTWARE.
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
#include "Poco/Net/Net.h"
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(POCO_OS_FAMILY_WINDOWS)
|
||||||
|
|
||||||
|
|
||||||
|
#include "Poco/Net/SocketDefs.h"
|
||||||
|
#include "Poco/Net/NetException.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace Poco {
|
||||||
|
namespace Net {
|
||||||
|
|
||||||
|
|
||||||
|
void Net_API initializeNetwork()
|
||||||
|
{
|
||||||
|
WORD version = MAKEWORD(2, 2);
|
||||||
|
WSADATA data;
|
||||||
|
if (WSAStartup(version, &data) != 0)
|
||||||
|
throw NetException("Failed to initialize network subsystem");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Net_API uninitializeNetwork()
|
||||||
|
{
|
||||||
|
WSACleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} } // namespace Poco::Net
|
||||||
|
|
||||||
|
|
||||||
|
#if !defined(POCO_NET_NO_WINDOWS_INIT)
|
||||||
|
#if defined (POCO_DLL)
|
||||||
|
BOOL APIENTRY DllMain(HANDLE, DWORD reasonForCall, LPVOID)
|
||||||
|
{
|
||||||
|
switch(reasonForCall)
|
||||||
|
{
|
||||||
|
case DLL_PROCESS_ATTACH:
|
||||||
|
Poco::Net::initializeNetwork();
|
||||||
|
break;
|
||||||
|
case DLL_PROCESS_DETACH:
|
||||||
|
Poco::Net::uninitializeNetwork();
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
#else // POCO_STATIC
|
||||||
|
struct NetworkInitializer
|
||||||
|
/// Network initializer for windows statically
|
||||||
|
/// linked library.
|
||||||
|
{
|
||||||
|
NetworkInitializer()
|
||||||
|
/// Calls Poco::Net::initializeNetwork();
|
||||||
|
{
|
||||||
|
Poco::Net::initializeNetwork();
|
||||||
|
}
|
||||||
|
|
||||||
|
~NetworkInitializer()
|
||||||
|
/// Calls Poco::Net::uninitializeNetwork();
|
||||||
|
{
|
||||||
|
Poco::Net::uninitializeNetwork();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const NetworkInitializer pocoNetworkInitializer;
|
||||||
|
#endif // POCO_DLL/POCO_STATIC
|
||||||
|
|
||||||
|
#endif // POCO_NET_NO_WINDOWS_INIT
|
||||||
|
|
||||||
|
|
||||||
|
#else // POCO_OS_FAMILY_WINDOWS
|
||||||
|
|
||||||
|
void Net_API initializeNetwork()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void Net_API uninitializeNetwork()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // POCO_OS_FAMILY_WINDOWS
|
@@ -82,16 +82,10 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
SocketAddressImpl()
|
SocketAddressImpl()
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::initializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~SocketAddressImpl()
|
virtual ~SocketAddressImpl()
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::uninitializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@@ -67,9 +67,6 @@ SocketImpl::SocketImpl():
|
|||||||
_sockfd(POCO_INVALID_SOCKET),
|
_sockfd(POCO_INVALID_SOCKET),
|
||||||
_blocking(true)
|
_blocking(true)
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::initializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -77,18 +74,12 @@ SocketImpl::SocketImpl(poco_socket_t sockfd):
|
|||||||
_sockfd(sockfd),
|
_sockfd(sockfd),
|
||||||
_blocking(true)
|
_blocking(true)
|
||||||
{
|
{
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::initializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
SocketImpl::~SocketImpl()
|
SocketImpl::~SocketImpl()
|
||||||
{
|
{
|
||||||
close();
|
close();
|
||||||
#if defined(_WIN32)
|
|
||||||
Poco::Net::uninitializeNetwork();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user