mirror of https://github.com/Icinga/icinga2.git
Refactor #includes (Part 5).
This commit is contained in:
parent
0744397427
commit
2a8bc3ca0f
|
@ -138,18 +138,18 @@ void CompatComponent::CommandPipeThread(const String& commandPath)
|
||||||
} else {
|
} else {
|
||||||
if (unlink(commandPath.CStr()) < 0) {
|
if (unlink(commandPath.CStr()) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("unlink")
|
<< boost::errinfo_api_function("unlink")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(commandPath));
|
<< boost::errinfo_file_name(commandPath));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fifo_ok && mkfifo(commandPath.CStr(), S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP) < 0) {
|
if (!fifo_ok && mkfifo(commandPath.CStr(), S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("mkfifo")
|
<< boost::errinfo_api_function("mkfifo")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(commandPath));
|
<< boost::errinfo_file_name(commandPath));
|
||||||
}
|
}
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
@ -161,9 +161,9 @@ void CompatComponent::CommandPipeThread(const String& commandPath)
|
||||||
|
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("open")
|
<< boost::errinfo_api_function("open")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(commandPath));
|
<< boost::errinfo_file_name(commandPath));
|
||||||
}
|
}
|
||||||
|
|
||||||
FILE *fp = fdopen(fd, "r");
|
FILE *fp = fdopen(fd, "r");
|
||||||
|
@ -171,8 +171,8 @@ void CompatComponent::CommandPipeThread(const String& commandPath)
|
||||||
if (fp == NULL) {
|
if (fp == NULL) {
|
||||||
(void) close(fd);
|
(void) close(fd);
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fdopen")
|
<< boost::errinfo_api_function("fdopen")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
char line[2048];
|
char line[2048];
|
||||||
|
@ -665,16 +665,16 @@ void CompatComponent::StatusTimerHandler(void)
|
||||||
statusfp.close();
|
statusfp.close();
|
||||||
if (rename(statuspathtmp.CStr(), statuspath.CStr()) < 0) {
|
if (rename(statuspathtmp.CStr(), statuspath.CStr()) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("rename")
|
<< boost::errinfo_api_function("rename")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(statuspathtmp));
|
<< boost::errinfo_file_name(statuspathtmp));
|
||||||
}
|
}
|
||||||
|
|
||||||
objectfp.close();
|
objectfp.close();
|
||||||
if (rename(objectspathtmp.CStr(), objectspath.CStr()) < 0) {
|
if (rename(objectspathtmp.CStr(), objectspath.CStr()) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("rename")
|
<< boost::errinfo_api_function("rename")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(objectspathtmp));
|
<< boost::errinfo_file_name(objectspathtmp));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,6 +32,9 @@
|
||||||
#include <boost/foreach.hpp>
|
#include <boost/foreach.hpp>
|
||||||
#include <boost/exception/diagnostic_information.hpp>
|
#include <boost/exception/diagnostic_information.hpp>
|
||||||
#include <boost/algorithm/string/split.hpp>
|
#include <boost/algorithm/string/split.hpp>
|
||||||
|
#include <boost/exception/errinfo_api_function.hpp>
|
||||||
|
#include <boost/exception/errinfo_errno.hpp>
|
||||||
|
#include <boost/exception/errinfo_file_name.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
@ -62,8 +65,8 @@ Application::Application(const Dictionary::Ptr& serializedUpdate)
|
||||||
WSADATA wsaData;
|
WSADATA wsaData;
|
||||||
if (WSAStartup(MAKEWORD(1, 1), &wsaData) != 0) {
|
if (WSAStartup(MAKEWORD(1, 1), &wsaData) != 0) {
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("WSAStartup")
|
<< boost::errinfo_api_function("WSAStartup")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
}
|
}
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
|
@ -208,8 +211,8 @@ String Application::GetExePath(const String& argv0)
|
||||||
char buffer[MAXPATHLEN];
|
char buffer[MAXPATHLEN];
|
||||||
if (getcwd(buffer, sizeof(buffer)) == NULL) {
|
if (getcwd(buffer, sizeof(buffer)) == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("getcwd")
|
<< boost::errinfo_api_function("getcwd")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
String workingDirectory = buffer;
|
String workingDirectory = buffer;
|
||||||
|
@ -253,9 +256,9 @@ String Application::GetExePath(const String& argv0)
|
||||||
|
|
||||||
if (realpath(executablePath.CStr(), buffer) == NULL) {
|
if (realpath(executablePath.CStr(), buffer) == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("realpath")
|
<< boost::errinfo_api_function("realpath")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(executablePath));
|
<< boost::errinfo_file_name(executablePath));
|
||||||
}
|
}
|
||||||
|
|
||||||
return buffer;
|
return buffer;
|
||||||
|
@ -264,8 +267,8 @@ String Application::GetExePath(const String& argv0)
|
||||||
|
|
||||||
if (!GetModuleFileName(NULL, FullExePath, sizeof(FullExePath)))
|
if (!GetModuleFileName(NULL, FullExePath, sizeof(FullExePath)))
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("GetModuleFileName")
|
<< boost::errinfo_api_function("GetModuleFileName")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< boost::errinfo_win32_error(GetLastError()));
|
||||||
|
|
||||||
return FullExePath;
|
return FullExePath;
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
|
@ -31,6 +31,9 @@
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <boost/make_shared.hpp>
|
#include <boost/make_shared.hpp>
|
||||||
#include <boost/foreach.hpp>
|
#include <boost/foreach.hpp>
|
||||||
|
#include <boost/exception/errinfo_api_function.hpp>
|
||||||
|
#include <boost/exception/errinfo_errno.hpp>
|
||||||
|
#include <boost/exception/errinfo_file_name.hpp>
|
||||||
|
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
|
@ -519,9 +522,9 @@ void DynamicObject::DumpObjects(const String& filename)
|
||||||
|
|
||||||
if (rename(tempFilename.CStr(), filename.CStr()) < 0) {
|
if (rename(tempFilename.CStr(), filename.CStr()) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("rename")
|
<< boost::errinfo_api_function("rename")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(tempFilename));
|
<< boost::errinfo_file_name(tempFilename));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,9 @@
|
||||||
#include "base/stacktrace.h"
|
#include "base/stacktrace.h"
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <boost/thread/tss.hpp>
|
#include <boost/thread/tss.hpp>
|
||||||
|
#include <boost/exception/errinfo_api_function.hpp>
|
||||||
|
#include <boost/exception/errinfo_errno.hpp>
|
||||||
|
#include <boost/exception/errinfo_file_name.hpp>
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
# include <boost/algorithm/string/trim.hpp>
|
# include <boost/algorithm/string/trim.hpp>
|
||||||
|
@ -54,6 +57,7 @@ class I2_BASE_API posix_error : virtual public std::exception, virtual public bo
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
class I2_BASE_API win32_error : virtual public std::exception, virtual public boost::exception { };
|
class I2_BASE_API win32_error : virtual public std::exception, virtual public boost::exception { };
|
||||||
|
|
||||||
|
struct errinfo_win32_error_;
|
||||||
typedef boost::error_info<struct errinfo_win32_error_, int> errinfo_win32_error;
|
typedef boost::error_info<struct errinfo_win32_error_, int> errinfo_win32_error;
|
||||||
|
|
||||||
inline std::string to_string(const errinfo_win32_error& e)
|
inline std::string to_string(const errinfo_win32_error& e)
|
||||||
|
@ -83,6 +87,7 @@ inline std::string to_string(const errinfo_win32_error& e)
|
||||||
|
|
||||||
class I2_BASE_API openssl_error : virtual public std::exception, virtual public boost::exception { };
|
class I2_BASE_API openssl_error : virtual public std::exception, virtual public boost::exception { };
|
||||||
|
|
||||||
|
struct errinfo_openssl_error_;
|
||||||
typedef boost::error_info<struct errinfo_openssl_error_, int> errinfo_openssl_error;
|
typedef boost::error_info<struct errinfo_openssl_error_, int> errinfo_openssl_error;
|
||||||
|
|
||||||
inline std::string to_string(const errinfo_openssl_error& e)
|
inline std::string to_string(const errinfo_openssl_error& e)
|
||||||
|
|
|
@ -82,18 +82,11 @@
|
||||||
|
|
||||||
#include <boost/smart_ptr/shared_ptr.hpp>
|
#include <boost/smart_ptr/shared_ptr.hpp>
|
||||||
#include <boost/smart_ptr/weak_ptr.hpp>
|
#include <boost/smart_ptr/weak_ptr.hpp>
|
||||||
#include <boost/exception/error_info.hpp>
|
|
||||||
#include <boost/exception/errinfo_api_function.hpp>
|
|
||||||
#include <boost/exception/errinfo_errno.hpp>
|
|
||||||
#include <boost/exception/errinfo_file_name.hpp>
|
|
||||||
|
|
||||||
using boost::shared_ptr;
|
using boost::shared_ptr;
|
||||||
using boost::weak_ptr;
|
using boost::weak_ptr;
|
||||||
using boost::dynamic_pointer_cast;
|
using boost::dynamic_pointer_cast;
|
||||||
using boost::static_pointer_cast;
|
using boost::static_pointer_cast;
|
||||||
using boost::errinfo_api_function;
|
|
||||||
using boost::errinfo_errno;
|
|
||||||
using boost::errinfo_file_name;
|
|
||||||
|
|
||||||
#if defined(__APPLE__) && defined(__MACH__)
|
#if defined(__APPLE__) && defined(__MACH__)
|
||||||
# pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
# pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
||||||
|
|
|
@ -52,14 +52,14 @@ void Process::Initialize(void)
|
||||||
#if HAVE_PIPE2
|
#if HAVE_PIPE2
|
||||||
if (pipe2(fds, O_CLOEXEC) < 0) {
|
if (pipe2(fds, O_CLOEXEC) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("pipe2")
|
<< boost::errinfo_api_function("pipe2")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
#else /* HAVE_PIPE2 */
|
#else /* HAVE_PIPE2 */
|
||||||
if (pipe(fds) < 0) {
|
if (pipe(fds) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("pipe")
|
<< boost::errinfo_api_function("pipe")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Don't bother setting fds[0] to clo-exec as we'll only
|
/* Don't bother setting fds[0] to clo-exec as we'll only
|
||||||
|
@ -80,8 +80,8 @@ void Process::Initialize(void)
|
||||||
|
|
||||||
if (childTaskFd < 0) {
|
if (childTaskFd < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("dup")
|
<< boost::errinfo_api_function("dup")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
Utility::SetNonBlocking(childTaskFd);
|
Utility::SetNonBlocking(childTaskFd);
|
||||||
|
@ -111,8 +111,8 @@ void Process::WorkerThreadProc(int taskFd)
|
||||||
|
|
||||||
if (pfds == NULL) {
|
if (pfds == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("realloc")
|
<< boost::errinfo_api_function("realloc")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
|
@ -134,8 +134,8 @@ void Process::WorkerThreadProc(int taskFd)
|
||||||
|
|
||||||
if (rc < 0 && errno != EINTR) {
|
if (rc < 0 && errno != EINTR) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("poll")
|
<< boost::errinfo_api_function("poll")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == 0)
|
if (rc == 0)
|
||||||
|
@ -165,8 +165,8 @@ void Process::WorkerThreadProc(int taskFd)
|
||||||
break; /* Someone else was faster and took our task. */
|
break; /* Someone else was faster and took our task. */
|
||||||
|
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("read")
|
<< boost::errinfo_api_function("read")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
while (have > 0) {
|
while (have > 0) {
|
||||||
|
@ -232,8 +232,8 @@ void Process::QueueTask(void)
|
||||||
*/
|
*/
|
||||||
if (write(m_TaskFd, "T", 1) < 0) {
|
if (write(m_TaskFd, "T", 1) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("write")
|
<< boost::errinfo_api_function("write")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -249,14 +249,14 @@ void Process::InitTask(void)
|
||||||
#if HAVE_PIPE2
|
#if HAVE_PIPE2
|
||||||
if (pipe2(fds, O_NONBLOCK | O_CLOEXEC) < 0) {
|
if (pipe2(fds, O_NONBLOCK | O_CLOEXEC) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("pipe2")
|
<< boost::errinfo_api_function("pipe2")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
#else /* HAVE_PIPE2 */
|
#else /* HAVE_PIPE2 */
|
||||||
if (pipe(fds) < 0) {
|
if (pipe(fds) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("pipe")
|
<< boost::errinfo_api_function("pipe")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
Utility::SetNonBlocking(fds[0]);
|
Utility::SetNonBlocking(fds[0]);
|
||||||
|
@ -313,8 +313,8 @@ void Process::InitTask(void)
|
||||||
|
|
||||||
if (m_Pid < 0) {
|
if (m_Pid < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fork")
|
<< boost::errinfo_api_function("fork")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_Pid == 0) {
|
if (m_Pid == 0) {
|
||||||
|
@ -378,8 +378,8 @@ bool Process::RunTask(void)
|
||||||
|
|
||||||
if (waitpid(m_Pid, &status, 0) != m_Pid) {
|
if (waitpid(m_Pid, &status, 0) != m_Pid) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("waitpid")
|
<< boost::errinfo_api_function("waitpid")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (WIFEXITED(status)) {
|
if (WIFEXITED(status)) {
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#define STRING_H
|
#define STRING_H
|
||||||
|
|
||||||
#include "base/i2-base.h"
|
#include "base/i2-base.h"
|
||||||
|
#include <boost/range/iterator.hpp>
|
||||||
#include <ostream>
|
#include <ostream>
|
||||||
#include <istream>
|
#include <istream>
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,9 @@
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
#include <boost/make_shared.hpp>
|
#include <boost/make_shared.hpp>
|
||||||
|
#include <boost/exception/errinfo_api_function.hpp>
|
||||||
|
#include <boost/exception/errinfo_errno.hpp>
|
||||||
|
#include <boost/exception/errinfo_file_name.hpp>
|
||||||
|
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
|
@ -151,12 +154,12 @@ void Socket::HandleException(void)
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_errno(GetError()));
|
<< boost::errinfo_errno(GetError()));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_win32_error(GetError()));
|
<< boost::errinfo_win32_error(GetError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -174,12 +177,12 @@ String Socket::GetAddressFromSockaddr(sockaddr *address, socklen_t len)
|
||||||
sizeof(service), NI_NUMERICHOST | NI_NUMERICSERV) < 0) {
|
sizeof(service), NI_NUMERICHOST | NI_NUMERICSERV) < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getnameinfo")
|
<< boost::errinfo_api_function("getnameinfo")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getnameinfo")
|
<< boost::errinfo_api_function("getnameinfo")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,12 +206,12 @@ String Socket::GetClientAddress(void)
|
||||||
if (getsockname(GetFD(), (sockaddr *)&sin, &len) < 0) {
|
if (getsockname(GetFD(), (sockaddr *)&sin, &len) < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getsockname")
|
<< boost::errinfo_api_function("getsockname")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getsockname")
|
<< boost::errinfo_api_function("getsockname")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -230,12 +233,12 @@ String Socket::GetPeerAddress(void)
|
||||||
if (getpeername(GetFD(), (sockaddr *)&sin, &len) < 0) {
|
if (getpeername(GetFD(), (sockaddr *)&sin, &len) < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getpeername")
|
<< boost::errinfo_api_function("getpeername")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getpeername")
|
<< boost::errinfo_api_function("getpeername")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -282,12 +285,12 @@ void Socket::ReadThreadProc(void)
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -349,12 +352,12 @@ void Socket::WriteThreadProc(void)
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("select")
|
<< boost::errinfo_api_function("select")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -479,12 +482,12 @@ void Socket::Listen(void)
|
||||||
if (listen(GetFD(), SOMAXCONN) < 0) {
|
if (listen(GetFD(), SOMAXCONN) < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("listen")
|
<< boost::errinfo_api_function("listen")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("listen")
|
<< boost::errinfo_api_function("listen")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -537,12 +540,12 @@ void Socket::HandleWritableClient(void)
|
||||||
if (rc <= 0) {
|
if (rc <= 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("send")
|
<< boost::errinfo_api_function("send")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("send")
|
<< boost::errinfo_api_function("send")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -574,12 +577,12 @@ void Socket::HandleReadableClient(void)
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("recv")
|
<< boost::errinfo_api_function("recv")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("recv")
|
<< boost::errinfo_api_function("recv")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -618,12 +621,12 @@ void Socket::HandleReadableServer(void)
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("accept")
|
<< boost::errinfo_api_function("accept")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("accept")
|
<< boost::errinfo_api_function("accept")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
#include "base/tcpsocket.h"
|
#include "base/tcpsocket.h"
|
||||||
|
#include <boost/exception/errinfo_api_function.hpp>
|
||||||
|
#include <boost/exception/errinfo_errno.hpp>
|
||||||
|
#include <boost/exception/errinfo_file_name.hpp>
|
||||||
|
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
|
@ -55,12 +58,12 @@ void TcpSocket::Bind(String node, String service, int family)
|
||||||
service.CStr(), &hints, &result) < 0) {
|
service.CStr(), &hints, &result) < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getaddrinfo")
|
<< boost::errinfo_api_function("getaddrinfo")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getaddrinfo")
|
<< boost::errinfo_api_function("getaddrinfo")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,12 +129,12 @@ void TcpSocket::Connect(const String& node, const String& service)
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getaddrinfo")
|
<< boost::errinfo_api_function("getaddrinfo")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
BOOST_THROW_EXCEPTION(socket_error()
|
BOOST_THROW_EXCEPTION(socket_error()
|
||||||
<< errinfo_api_function("getaddrinfo")
|
<< boost::errinfo_api_function("getaddrinfo")
|
||||||
<< errinfo_win32_error(WSAGetLastError()));
|
<< boost::errinfo_win32_error(WSAGetLastError()));
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ void TlsStream::Start(void)
|
||||||
|
|
||||||
if (!m_SSL) {
|
if (!m_SSL) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_new")
|
<< boost::errinfo_api_function("SSL_new")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,7 +161,7 @@ void TlsStream::HandleIO(void)
|
||||||
default:
|
default:
|
||||||
I2Stream_check_exception(m_BIO);
|
I2Stream_check_exception(m_BIO);
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_do_handshake")
|
<< boost::errinfo_api_function("SSL_do_handshake")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -188,7 +188,7 @@ void TlsStream::HandleIO(void)
|
||||||
default:
|
default:
|
||||||
I2Stream_check_exception(m_BIO);
|
I2Stream_check_exception(m_BIO);
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_read")
|
<< boost::errinfo_api_function("SSL_read")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -227,7 +227,7 @@ void TlsStream::HandleIO(void)
|
||||||
default:
|
default:
|
||||||
I2Stream_check_exception(m_BIO);
|
I2Stream_check_exception(m_BIO);
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_write")
|
<< boost::errinfo_api_function("SSL_write")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,8 +29,8 @@ UnixSocket::UnixSocket(void)
|
||||||
|
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("socket")
|
<< boost::errinfo_api_function("socket")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
SetFD(fd);
|
SetFD(fd);
|
||||||
|
@ -48,8 +48,8 @@ void UnixSocket::Bind(const String& path)
|
||||||
|
|
||||||
if (bind(GetFD(), (sockaddr *)&sun, SUN_LEN(&sun)) < 0) {
|
if (bind(GetFD(), (sockaddr *)&sun, SUN_LEN(&sun)) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("bind")
|
<< boost::errinfo_api_function("bind")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,8 +63,8 @@ void UnixSocket::Connect(const String& path)
|
||||||
|
|
||||||
if (connect(GetFD(), (sockaddr *)&sun, SUN_LEN(&sun)) < 0 && errno != EINPROGRESS) {
|
if (connect(GetFD(), (sockaddr *)&sun, SUN_LEN(&sun)) < 0 && errno != EINPROGRESS) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("connect")
|
<< boost::errinfo_api_function("connect")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
|
@ -103,23 +103,23 @@ shared_ptr<SSL_CTX> Utility::MakeSSLContext(const String& pubkey, const String&
|
||||||
|
|
||||||
if (!SSL_CTX_use_certificate_chain_file(sslContext.get(), pubkey.CStr())) {
|
if (!SSL_CTX_use_certificate_chain_file(sslContext.get(), pubkey.CStr())) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_CTX_use_certificate_chain_file")
|
<< boost::errinfo_api_function("SSL_CTX_use_certificate_chain_file")
|
||||||
<< errinfo_openssl_error(ERR_get_error())
|
<< errinfo_openssl_error(ERR_get_error())
|
||||||
<< errinfo_file_name(pubkey));
|
<< boost::errinfo_file_name(pubkey));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!SSL_CTX_use_PrivateKey_file(sslContext.get(), privkey.CStr(), SSL_FILETYPE_PEM)) {
|
if (!SSL_CTX_use_PrivateKey_file(sslContext.get(), privkey.CStr(), SSL_FILETYPE_PEM)) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_CTX_use_PrivateKey_file")
|
<< boost::errinfo_api_function("SSL_CTX_use_PrivateKey_file")
|
||||||
<< errinfo_openssl_error(ERR_get_error())
|
<< errinfo_openssl_error(ERR_get_error())
|
||||||
<< errinfo_file_name(privkey));
|
<< boost::errinfo_file_name(privkey));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!SSL_CTX_load_verify_locations(sslContext.get(), cakey.CStr(), NULL)) {
|
if (!SSL_CTX_load_verify_locations(sslContext.get(), cakey.CStr(), NULL)) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_CTX_load_verify_locations")
|
<< boost::errinfo_api_function("SSL_CTX_load_verify_locations")
|
||||||
<< errinfo_openssl_error(ERR_get_error())
|
<< errinfo_openssl_error(ERR_get_error())
|
||||||
<< errinfo_file_name(cakey));
|
<< boost::errinfo_file_name(cakey));
|
||||||
}
|
}
|
||||||
|
|
||||||
STACK_OF(X509_NAME) *cert_names;
|
STACK_OF(X509_NAME) *cert_names;
|
||||||
|
@ -127,9 +127,9 @@ shared_ptr<SSL_CTX> Utility::MakeSSLContext(const String& pubkey, const String&
|
||||||
cert_names = SSL_load_client_CA_file(cakey.CStr());
|
cert_names = SSL_load_client_CA_file(cakey.CStr());
|
||||||
if (cert_names == NULL) {
|
if (cert_names == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("SSL_load_client_CA_file")
|
<< boost::errinfo_api_function("SSL_load_client_CA_file")
|
||||||
<< errinfo_openssl_error(ERR_get_error())
|
<< errinfo_openssl_error(ERR_get_error())
|
||||||
<< errinfo_file_name(cakey));
|
<< boost::errinfo_file_name(cakey));
|
||||||
}
|
}
|
||||||
|
|
||||||
SSL_CTX_set_client_CA_list(sslContext.get(), cert_names);
|
SSL_CTX_set_client_CA_list(sslContext.get(), cert_names);
|
||||||
|
@ -152,7 +152,7 @@ String Utility::GetCertificateCN(const shared_ptr<X509>& certificate)
|
||||||
|
|
||||||
if (rc == -1) {
|
if (rc == -1) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("X509_NAME_get_text_by_NID")
|
<< boost::errinfo_api_function("X509_NAME_get_text_by_NID")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -172,21 +172,21 @@ shared_ptr<X509> Utility::GetX509Certificate(const String& pemfile)
|
||||||
|
|
||||||
if (fpcert == NULL) {
|
if (fpcert == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("BIO_new")
|
<< boost::errinfo_api_function("BIO_new")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (BIO_read_filename(fpcert, pemfile.CStr()) < 0) {
|
if (BIO_read_filename(fpcert, pemfile.CStr()) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("BIO_read_filename")
|
<< boost::errinfo_api_function("BIO_read_filename")
|
||||||
<< errinfo_openssl_error(ERR_get_error())
|
<< errinfo_openssl_error(ERR_get_error())
|
||||||
<< errinfo_file_name(pemfile));
|
<< boost::errinfo_file_name(pemfile));
|
||||||
}
|
}
|
||||||
|
|
||||||
cert = PEM_read_bio_X509_AUX(fpcert, NULL, NULL, NULL);
|
cert = PEM_read_bio_X509_AUX(fpcert, NULL, NULL, NULL);
|
||||||
if (cert == NULL) {
|
if (cert == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
<< errinfo_api_function("PEM_read_bio_X509_AUX")
|
<< boost::errinfo_api_function("PEM_read_bio_X509_AUX")
|
||||||
<< errinfo_openssl_error(ERR_get_error()));
|
<< errinfo_openssl_error(ERR_get_error()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -243,7 +243,7 @@ String Utility::DirName(const String& path)
|
||||||
free(dir);
|
free(dir);
|
||||||
|
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("PathRemoveFileSpec")
|
<< boost::errinfo_api_function("PathRemoveFileSpec")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< errinfo_win32_error(GetLastError()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -322,8 +322,8 @@ double Utility::GetTime(void)
|
||||||
|
|
||||||
if (gettimeofday(&tv, NULL) < 0) {
|
if (gettimeofday(&tv, NULL) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("gettimeofday")
|
<< boost::errinfo_api_function("gettimeofday")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
return tv.tv_sec + tv.tv_usec / 1000000.0;
|
return tv.tv_sec + tv.tv_usec / 1000000.0;
|
||||||
|
@ -384,9 +384,9 @@ Utility::LoadExtensionLibrary(const String& library)
|
||||||
|
|
||||||
if (hModule == NULL) {
|
if (hModule == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("LoadLibrary")
|
<< boost::errinfo_api_function("LoadLibrary")
|
||||||
<< errinfo_win32_error(GetLastError())
|
<< errinfo_win32_error(GetLastError())
|
||||||
<< errinfo_file_name(path));
|
<< boost::errinfo_file_name(path));
|
||||||
}
|
}
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
lt_dlhandle hModule = lt_dlopen(path.CStr());
|
lt_dlhandle hModule = lt_dlopen(path.CStr());
|
||||||
|
@ -430,9 +430,9 @@ bool Utility::Glob(const String& pathSpec, const boost::function<void (const Str
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("FindFirstFile")
|
<< boost::errinfo_api_function("FindFirstFile")
|
||||||
<< errinfo_win32_error(errorCode)
|
<< boost::errinfo_win32_error(errorCode)
|
||||||
<< errinfo_file_name(pathSpec));
|
<< boost::errinfo_file_name(pathSpec));
|
||||||
}
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
@ -441,7 +441,7 @@ bool Utility::Glob(const String& pathSpec, const boost::function<void (const Str
|
||||||
|
|
||||||
if (!FindClose(handle)) {
|
if (!FindClose(handle)) {
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< errinfo_api_function("FindClose")
|
<< boost::errinfo_api_function("FindClose")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< errinfo_win32_error(GetLastError()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,9 +456,9 @@ bool Utility::Glob(const String& pathSpec, const boost::function<void (const Str
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("glob")
|
<< boost::errinfo_api_function("glob")
|
||||||
<< errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
<< errinfo_file_name(pathSpec));
|
<< boost::errinfo_file_name(pathSpec));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gr.gl_pathc == 0) {
|
if (gr.gl_pathc == 0) {
|
||||||
|
@ -485,14 +485,14 @@ void Utility::SetNonBlocking(int fd)
|
||||||
|
|
||||||
if (flags < 0) {
|
if (flags < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fcntl")
|
<< boost::errinfo_api_function("fcntl")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fcntl(fd, F_SETFL, flags | O_NONBLOCK) < 0) {
|
if (fcntl(fd, F_SETFL, flags | O_NONBLOCK) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fcntl")
|
<< boost::errinfo_api_function("fcntl")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -502,14 +502,14 @@ void Utility::SetCloExec(int fd)
|
||||||
|
|
||||||
if (flags < 0) {
|
if (flags < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fcntl")
|
<< boost::errinfo_api_function("fcntl")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fcntl(fd, F_SETFD, flags | FD_CLOEXEC) < 0) {
|
if (fcntl(fd, F_SETFD, flags | FD_CLOEXEC) < 0) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("fcntl")
|
<< boost::errinfo_api_function("fcntl")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
@ -540,16 +540,16 @@ String Utility::FormatDateTime(const char *format, double ts)
|
||||||
|
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("localtime")
|
<< boost::errinfo_api_function("localtime")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
tmthen = *temp;
|
tmthen = *temp;
|
||||||
#else /* _MSC_VER */
|
#else /* _MSC_VER */
|
||||||
if (localtime_r(&tempts, &tmthen) == NULL) {
|
if (localtime_r(&tempts, &tmthen) == NULL) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< errinfo_api_function("localtime_r")
|
<< boost::errinfo_api_function("localtime_r")
|
||||||
<< errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
}
|
}
|
||||||
#endif /* _MSC_VER */
|
#endif /* _MSC_VER */
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue