mirror of https://github.com/Icinga/icinga2.git
Merge pull request #5862 from Icinga/feature/nullptr-cleanup
Replace a few more NULLs with nullptr
This commit is contained in:
commit
721b18e6a0
|
@ -258,7 +258,7 @@ static int Main(void)
|
||||||
|| command->GetImpersonationLevel() == ImpersonationLevel::ImpersonateRoot) {
|
|| command->GetImpersonationLevel() == ImpersonationLevel::ImpersonateRoot) {
|
||||||
TCHAR szPath[MAX_PATH];
|
TCHAR szPath[MAX_PATH];
|
||||||
|
|
||||||
if (GetModuleFileName(NULL, szPath, ARRAYSIZE(szPath))) {
|
if (GetModuleFileName(nullptr, szPath, ARRAYSIZE(szPath))) {
|
||||||
SHELLEXECUTEINFO sei = { sizeof(sei) };
|
SHELLEXECUTEINFO sei = { sizeof(sei) };
|
||||||
sei.lpVerb = _T("runas");
|
sei.lpVerb = _T("runas");
|
||||||
sei.lpFile = "cmd.exe";
|
sei.lpFile = "cmd.exe";
|
||||||
|
@ -434,7 +434,7 @@ static int Main(void)
|
||||||
|
|
||||||
if (!command || vm.count("help")) {
|
if (!command || vm.count("help")) {
|
||||||
if (!command)
|
if (!command)
|
||||||
CLICommand::ShowCommands(argc, argv, NULL);
|
CLICommand::ShowCommands(argc, argv, nullptr);
|
||||||
|
|
||||||
std::cout << visibleDesc << std::endl
|
std::cout << visibleDesc << std::endl
|
||||||
<< "Report bugs at <https://github.com/Icinga/icinga2>" << std::endl
|
<< "Report bugs at <https://github.com/Icinga/icinga2>" << std::endl
|
||||||
|
@ -477,7 +477,7 @@ static int Main(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getgid() != gr->gr_gid) {
|
if (getgid() != gr->gr_gid) {
|
||||||
if (!vm.count("reload-internal") && setgroups(0, NULL) < 0) {
|
if (!vm.count("reload-internal") && setgroups(0, nullptr) < 0) {
|
||||||
Log(LogCritical, "cli")
|
Log(LogCritical, "cli")
|
||||||
<< "setgroups() failed with error code " << errno << ", \"" << Utility::FormatErrorNumber(errno) << "\"";
|
<< "setgroups() failed with error code " << errno << ", \"" << Utility::FormatErrorNumber(errno) << "\"";
|
||||||
Log(LogCritical, "cli")
|
Log(LogCritical, "cli")
|
||||||
|
@ -567,19 +567,16 @@ static int Main(void)
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
static int SetupService(bool install, int argc, char **argv)
|
static int SetupService(bool install, int argc, char **argv)
|
||||||
{
|
{
|
||||||
SC_HANDLE schSCManager = OpenSCManager(
|
SC_HANDLE schSCManager = OpenSCManager(nullptr, nullptr, SC_MANAGER_ALL_ACCESS);
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
SC_MANAGER_ALL_ACCESS);
|
|
||||||
|
|
||||||
if (NULL == schSCManager) {
|
if (!schSCManager) {
|
||||||
printf("OpenSCManager failed (%d)\n", GetLastError());
|
printf("OpenSCManager failed (%d)\n", GetLastError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
TCHAR szPath[MAX_PATH];
|
TCHAR szPath[MAX_PATH];
|
||||||
|
|
||||||
if (!GetModuleFileName(NULL, szPath, MAX_PATH)) {
|
if (!GetModuleFileName(nullptr, szPath, MAX_PATH)) {
|
||||||
printf("Cannot install service (%d)\n", GetLastError());
|
printf("Cannot install service (%d)\n", GetLastError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -604,7 +601,7 @@ static int SetupService(bool install, int argc, char **argv)
|
||||||
|
|
||||||
SC_HANDLE schService = OpenService(schSCManager, "icinga2", SERVICE_ALL_ACCESS);
|
SC_HANDLE schService = OpenService(schSCManager, "icinga2", SERVICE_ALL_ACCESS);
|
||||||
|
|
||||||
if (schService != NULL) {
|
if (schService) {
|
||||||
SERVICE_STATUS status;
|
SERVICE_STATUS status;
|
||||||
ControlService(schService, SERVICE_CONTROL_STOP, &status);
|
ControlService(schService, SERVICE_CONTROL_STOP, &status);
|
||||||
|
|
||||||
|
@ -634,13 +631,13 @@ static int SetupService(bool install, int argc, char **argv)
|
||||||
SERVICE_DEMAND_START,
|
SERVICE_DEMAND_START,
|
||||||
SERVICE_ERROR_NORMAL,
|
SERVICE_ERROR_NORMAL,
|
||||||
szArgs.CStr(),
|
szArgs.CStr(),
|
||||||
NULL,
|
nullptr,
|
||||||
NULL,
|
nullptr,
|
||||||
NULL,
|
nullptr,
|
||||||
scmUser.c_str(),
|
scmUser.c_str(),
|
||||||
NULL);
|
nullptr);
|
||||||
|
|
||||||
if (schService == NULL) {
|
if (!schService) {
|
||||||
printf("CreateService failed (%d)\n", GetLastError());
|
printf("CreateService failed (%d)\n", GetLastError());
|
||||||
CloseServiceHandle(schSCManager);
|
CloseServiceHandle(schSCManager);
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -662,7 +659,7 @@ static int SetupService(bool install, int argc, char **argv)
|
||||||
printf("Service uninstalled successfully\n");
|
printf("Service uninstalled successfully\n");
|
||||||
} else {
|
} else {
|
||||||
if (!ChangeServiceConfig(schService, SERVICE_NO_CHANGE, SERVICE_AUTO_START,
|
if (!ChangeServiceConfig(schService, SERVICE_NO_CHANGE, SERVICE_AUTO_START,
|
||||||
SERVICE_ERROR_NORMAL, szArgs.CStr(), NULL, NULL, NULL, scmUser.c_str(), NULL, NULL)) {
|
SERVICE_ERROR_NORMAL, szArgs.CStr(), nullptr, nullptr, nullptr, scmUser.c_str(), nullptr, nullptr)) {
|
||||||
printf("ChangeServiceConfig failed (%d)\n", GetLastError());
|
printf("ChangeServiceConfig failed (%d)\n", GetLastError());
|
||||||
CloseServiceHandle(schService);
|
CloseServiceHandle(schService);
|
||||||
CloseServiceHandle(schSCManager);
|
CloseServiceHandle(schSCManager);
|
||||||
|
@ -677,7 +674,7 @@ static int SetupService(bool install, int argc, char **argv)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!StartService(schService, 0, NULL)) {
|
if (!StartService(schService, 0, nullptr)) {
|
||||||
printf("StartService failed (%d)\n", GetLastError());
|
printf("StartService failed (%d)\n", GetLastError());
|
||||||
CloseServiceHandle(schService);
|
CloseServiceHandle(schService);
|
||||||
CloseServiceHandle(schSCManager);
|
CloseServiceHandle(schSCManager);
|
||||||
|
@ -743,7 +740,7 @@ static VOID WINAPI ServiceMain(DWORD argc, LPSTR *argv)
|
||||||
l_SvcStatus.dwServiceSpecificExitCode = 0;
|
l_SvcStatus.dwServiceSpecificExitCode = 0;
|
||||||
|
|
||||||
ReportSvcStatus(SERVICE_RUNNING, NO_ERROR, 0);
|
ReportSvcStatus(SERVICE_RUNNING, NO_ERROR, 0);
|
||||||
l_Job = CreateJobObject(NULL, NULL);
|
l_Job = CreateJobObject(nullptr, nullptr);
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
LPSTR arg = argv[0];
|
LPSTR arg = argv[0];
|
||||||
|
@ -765,7 +762,7 @@ static VOID WINAPI ServiceMain(DWORD argc, LPSTR *argv)
|
||||||
|
|
||||||
char *uargs = strdup(args.CStr());
|
char *uargs = strdup(args.CStr());
|
||||||
|
|
||||||
BOOL res = CreateProcess(NULL, uargs, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi);
|
BOOL res = CreateProcess(nullptr, uargs, nullptr, nullptr, FALSE, 0, nullptr, nullptr, &si, &pi);
|
||||||
|
|
||||||
free(uargs);
|
free(uargs);
|
||||||
|
|
||||||
|
@ -847,7 +844,7 @@ int main(int argc, char **argv)
|
||||||
if (argc > 1 && strcmp(argv[1], "--scm") == 0) {
|
if (argc > 1 && strcmp(argv[1], "--scm") == 0) {
|
||||||
SERVICE_TABLE_ENTRY dispatchTable[] = {
|
SERVICE_TABLE_ENTRY dispatchTable[] = {
|
||||||
{ "icinga2", ServiceMain },
|
{ "icinga2", ServiceMain },
|
||||||
{ NULL, NULL }
|
{ nullptr, nullptr }
|
||||||
};
|
};
|
||||||
|
|
||||||
StartServiceCtrlDispatcher(dispatchTable);
|
StartServiceCtrlDispatcher(dispatchTable);
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
static std::string GetIcingaInstallPath(void)
|
static std::string GetIcingaInstallPath(void)
|
||||||
{
|
{
|
||||||
char szFileName[MAX_PATH];
|
char szFileName[MAX_PATH];
|
||||||
if (!GetModuleFileName(NULL, szFileName, sizeof(szFileName)))
|
if (!GetModuleFileName(nullptr, szFileName, sizeof(szFileName)))
|
||||||
return "";
|
return "";
|
||||||
|
|
||||||
if (!PathRemoveFileSpec(szFileName))
|
if (!PathRemoveFileSpec(szFileName))
|
||||||
|
@ -100,7 +100,7 @@ static bool PathExists(const std::string& path)
|
||||||
static std::string GetIcingaDataPath(void)
|
static std::string GetIcingaDataPath(void)
|
||||||
{
|
{
|
||||||
char path[MAX_PATH];
|
char path[MAX_PATH];
|
||||||
if (!SUCCEEDED(SHGetFolderPath(NULL, CSIDL_COMMON_APPDATA, NULL, 0, path)))
|
if (!SUCCEEDED(SHGetFolderPath(nullptr, CSIDL_COMMON_APPDATA, nullptr, 0, path)))
|
||||||
throw std::runtime_error("SHGetFolderPath failed");
|
throw std::runtime_error("SHGetFolderPath failed");
|
||||||
return std::string(path) + "\\icinga2";
|
return std::string(path) + "\\icinga2";
|
||||||
}
|
}
|
||||||
|
@ -133,7 +133,7 @@ static std::string GetNSISInstallPath(void)
|
||||||
BYTE pvData[MAX_PATH];
|
BYTE pvData[MAX_PATH];
|
||||||
DWORD cbData = sizeof(pvData) - 1;
|
DWORD cbData = sizeof(pvData) - 1;
|
||||||
DWORD lType;
|
DWORD lType;
|
||||||
if (RegQueryValueEx(hKey, NULL, NULL, &lType, pvData, &cbData) == ERROR_SUCCESS && lType == REG_SZ) {
|
if (RegQueryValueEx(hKey, nullptr, nullptr, &lType, pvData, &cbData) == ERROR_SUCCESS && lType == REG_SZ) {
|
||||||
pvData[cbData] = '\0';
|
pvData[cbData] = '\0';
|
||||||
|
|
||||||
return (char *)pvData;
|
return (char *)pvData;
|
||||||
|
@ -279,7 +279,7 @@ static int UninstallIcinga(void)
|
||||||
*/
|
*/
|
||||||
int CALLBACK WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
|
int CALLBACK WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
|
||||||
{
|
{
|
||||||
CoInitializeEx(NULL, COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE);
|
CoInitializeEx(nullptr, COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE);
|
||||||
|
|
||||||
//AllocConsole();
|
//AllocConsole();
|
||||||
int rc;
|
int rc;
|
||||||
|
@ -291,7 +291,7 @@ int CALLBACK WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLi
|
||||||
} else if (strcmp(lpCmdLine, "upgrade-nsis") == 0) {
|
} else if (strcmp(lpCmdLine, "upgrade-nsis") == 0) {
|
||||||
rc = UpgradeNSIS();
|
rc = UpgradeNSIS();
|
||||||
} else {
|
} else {
|
||||||
MessageBox(NULL, "This application should only be run by the MSI installer package.", "Icinga 2 Installer", MB_ICONWARNING);
|
MessageBox(nullptr, "This application should only be run by the MSI installer package.", "Icinga 2 Installer", MB_ICONWARNING);
|
||||||
rc = 1;
|
rc = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ public:
|
||||||
|
|
||||||
std::string url = wUrl.ToStdString();
|
std::string url = wUrl.ToStdString();
|
||||||
|
|
||||||
ConnectForm f(NULL, new Url(url));
|
ConnectForm f(nullptr, new Url(url));
|
||||||
if (f.ShowModal() != wxID_OK)
|
if (f.ShowModal() != wxID_OK)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ public:
|
||||||
pUrl = new Url(argv[1].ToStdString());
|
pUrl = new Url(argv[1].ToStdString());
|
||||||
}
|
}
|
||||||
|
|
||||||
MainForm *m = new MainForm(NULL, pUrl);
|
MainForm *m = new MainForm(nullptr, pUrl);
|
||||||
m->Show();
|
m->Show();
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -54,7 +54,7 @@ using namespace icinga;
|
||||||
REGISTER_TYPE(Application);
|
REGISTER_TYPE(Application);
|
||||||
|
|
||||||
boost::signals2::signal<void (void)> Application::OnReopenLogs;
|
boost::signals2::signal<void (void)> Application::OnReopenLogs;
|
||||||
Application::Ptr Application::m_Instance = NULL;
|
Application::Ptr Application::m_Instance = nullptr;
|
||||||
bool Application::m_ShuttingDown = false;
|
bool Application::m_ShuttingDown = false;
|
||||||
bool Application::m_RequestRestart = false;
|
bool Application::m_RequestRestart = false;
|
||||||
bool Application::m_RequestReopenLogs = false;
|
bool Application::m_RequestReopenLogs = false;
|
||||||
|
@ -73,9 +73,9 @@ double Application::m_LastReloadFailed;
|
||||||
*/
|
*/
|
||||||
void Application::OnConfigLoaded(void)
|
void Application::OnConfigLoaded(void)
|
||||||
{
|
{
|
||||||
m_PidFile = NULL;
|
m_PidFile = nullptr;
|
||||||
|
|
||||||
ASSERT(m_Instance == NULL);
|
ASSERT(m_Instance == nullptr);
|
||||||
m_Instance = this;
|
m_Instance = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ void Application::Stop(bool runtimeRemoved)
|
||||||
|
|
||||||
Application::~Application(void)
|
Application::~Application(void)
|
||||||
{
|
{
|
||||||
m_Instance = NULL;
|
m_Instance = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::Exit(int rc)
|
void Application::Exit(int rc)
|
||||||
|
@ -151,7 +151,7 @@ void Application::InitializeBase(void)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = SIG_IGN;
|
sa.sa_handler = SIG_IGN;
|
||||||
sigaction(SIGPIPE, &sa, NULL);
|
sigaction(SIGPIPE, &sa, nullptr);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
Loader::ExecuteDeferredInitializers();
|
Loader::ExecuteDeferredInitializers();
|
||||||
|
@ -276,7 +276,7 @@ void Application::SetResourceLimits(void)
|
||||||
for (int i = 1; i < argc; i++)
|
for (int i = 1; i < argc; i++)
|
||||||
new_argv[i + 1] = argv[i];
|
new_argv[i + 1] = argv[i];
|
||||||
|
|
||||||
new_argv[argc + 1] = NULL;
|
new_argv[argc + 1] = nullptr;
|
||||||
|
|
||||||
(void) execvp(new_argv[0], new_argv);
|
(void) execvp(new_argv[0], new_argv);
|
||||||
perror("execvp");
|
perror("execvp");
|
||||||
|
@ -465,7 +465,7 @@ String Application::GetExePath(const String& argv0)
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
char buffer[MAXPATHLEN];
|
char buffer[MAXPATHLEN];
|
||||||
if (getcwd(buffer, sizeof(buffer)) == NULL) {
|
if (!getcwd(buffer, sizeof(buffer))) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("getcwd")
|
<< boost::errinfo_api_function("getcwd")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -488,7 +488,7 @@ String Application::GetExePath(const String& argv0)
|
||||||
|
|
||||||
if (!foundSlash) {
|
if (!foundSlash) {
|
||||||
const char *pathEnv = getenv("PATH");
|
const char *pathEnv = getenv("PATH");
|
||||||
if (pathEnv != NULL) {
|
if (pathEnv) {
|
||||||
std::vector<String> paths;
|
std::vector<String> paths;
|
||||||
boost::algorithm::split(paths, pathEnv, boost::is_any_of(":"));
|
boost::algorithm::split(paths, pathEnv, boost::is_any_of(":"));
|
||||||
|
|
||||||
|
@ -510,7 +510,7 @@ String Application::GetExePath(const String& argv0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (realpath(executablePath.CStr(), buffer) == NULL) {
|
if (!realpath(executablePath.CStr(), buffer)) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("realpath")
|
<< boost::errinfo_api_function("realpath")
|
||||||
<< boost::errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
|
@ -521,7 +521,7 @@ String Application::GetExePath(const String& argv0)
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
char FullExePath[MAXPATHLEN];
|
char FullExePath[MAXPATHLEN];
|
||||||
|
|
||||||
if (!GetModuleFileName(NULL, FullExePath, sizeof(FullExePath)))
|
if (!GetModuleFileName(nullptr, FullExePath, sizeof(FullExePath)))
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< boost::errinfo_api_function("GetModuleFileName")
|
<< boost::errinfo_api_function("GetModuleFileName")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< errinfo_win32_error(GetLastError()));
|
||||||
|
@ -632,7 +632,7 @@ void Application::AttachDebugger(const String& filename, bool interactive)
|
||||||
"gdb",
|
"gdb",
|
||||||
"-p",
|
"-p",
|
||||||
my_pid_str,
|
my_pid_str,
|
||||||
NULL
|
nullptr
|
||||||
};
|
};
|
||||||
argv = const_cast<char **>(uargv);
|
argv = const_cast<char **>(uargv);
|
||||||
} else {
|
} else {
|
||||||
|
@ -647,7 +647,7 @@ void Application::AttachDebugger(const String& filename, bool interactive)
|
||||||
"detach",
|
"detach",
|
||||||
"-ex",
|
"-ex",
|
||||||
"quit",
|
"quit",
|
||||||
NULL
|
nullptr
|
||||||
};
|
};
|
||||||
argv = const_cast<char **>(uargv);
|
argv = const_cast<char **>(uargv);
|
||||||
}
|
}
|
||||||
|
@ -685,7 +685,7 @@ void Application::SigIntTermHandler(int signum)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = SIG_DFL;
|
sa.sa_handler = SIG_DFL;
|
||||||
sigaction(signum, &sa, NULL);
|
sigaction(signum, &sa, nullptr);
|
||||||
|
|
||||||
Application::Ptr instance = Application::GetInstance();
|
Application::Ptr instance = Application::GetInstance();
|
||||||
|
|
||||||
|
@ -718,7 +718,7 @@ void Application::SigAbrtHandler(int)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = SIG_DFL;
|
sa.sa_handler = SIG_DFL;
|
||||||
sigaction(SIGABRT, &sa, NULL);
|
sigaction(SIGABRT, &sa, nullptr);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
std::cerr << "Caught SIGABRT." << std::endl
|
std::cerr << "Caught SIGABRT." << std::endl
|
||||||
|
@ -778,14 +778,14 @@ BOOL WINAPI Application::CtrlHandler(DWORD type)
|
||||||
|
|
||||||
instance->RequestShutdown();
|
instance->RequestShutdown();
|
||||||
|
|
||||||
SetConsoleCtrlHandler(NULL, FALSE);
|
SetConsoleCtrlHandler(nullptr, FALSE);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Application::IsProcessElevated(void) {
|
bool Application::IsProcessElevated(void) {
|
||||||
BOOL fIsElevated = FALSE;
|
BOOL fIsElevated = FALSE;
|
||||||
DWORD dwError = ERROR_SUCCESS;
|
DWORD dwError = ERROR_SUCCESS;
|
||||||
HANDLE hToken = NULL;
|
HANDLE hToken = nullptr;
|
||||||
|
|
||||||
if (!OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &hToken))
|
if (!OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &hToken))
|
||||||
dwError = GetLastError();
|
dwError = GetLastError();
|
||||||
|
@ -801,13 +801,13 @@ bool Application::IsProcessElevated(void) {
|
||||||
|
|
||||||
if (hToken) {
|
if (hToken) {
|
||||||
CloseHandle(hToken);
|
CloseHandle(hToken);
|
||||||
hToken = NULL;
|
hToken = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ERROR_SUCCESS != dwError) {
|
if (ERROR_SUCCESS != dwError) {
|
||||||
LPSTR mBuf = NULL;
|
LPSTR mBuf = nullptr;
|
||||||
if (!FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
|
if (!FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
|
||||||
NULL, dwError, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), mBuf, 0, NULL))
|
nullptr, dwError, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), mBuf, 0, nullptr))
|
||||||
BOOST_THROW_EXCEPTION(std::runtime_error("Failed to format error message, last error was: " + dwError));
|
BOOST_THROW_EXCEPTION(std::runtime_error("Failed to format error message, last error was: " + dwError));
|
||||||
else
|
else
|
||||||
BOOST_THROW_EXCEPTION(std::runtime_error(mBuf));
|
BOOST_THROW_EXCEPTION(std::runtime_error(mBuf));
|
||||||
|
@ -832,7 +832,7 @@ void Application::ExceptionHandler(void)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = SIG_DFL;
|
sa.sa_handler = SIG_DFL;
|
||||||
sigaction(SIGABRT, &sa, NULL);
|
sigaction(SIGABRT, &sa, nullptr);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
String fname = GetCrashReportFilename();
|
String fname = GetCrashReportFilename();
|
||||||
|
@ -937,7 +937,7 @@ void Application::InstallExceptionHandlers(void)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = &Application::SigAbrtHandler;
|
sa.sa_handler = &Application::SigAbrtHandler;
|
||||||
sigaction(SIGABRT, &sa, NULL);
|
sigaction(SIGABRT, &sa, nullptr);
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
SetUnhandledExceptionFilter(&Application::SEHUnhandledExceptionFilter);
|
SetUnhandledExceptionFilter(&Application::SEHUnhandledExceptionFilter);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
@ -954,11 +954,11 @@ int Application::Run(void)
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = &Application::SigIntTermHandler;
|
sa.sa_handler = &Application::SigIntTermHandler;
|
||||||
sigaction(SIGINT, &sa, NULL);
|
sigaction(SIGINT, &sa, nullptr);
|
||||||
sigaction(SIGTERM, &sa, NULL);
|
sigaction(SIGTERM, &sa, nullptr);
|
||||||
|
|
||||||
sa.sa_handler = &Application::SigUsr1Handler;
|
sa.sa_handler = &Application::SigUsr1Handler;
|
||||||
sigaction(SIGUSR1, &sa, NULL);
|
sigaction(SIGUSR1, &sa, nullptr);
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
SetConsoleCtrlHandler(&Application::CtrlHandler, TRUE);
|
SetConsoleCtrlHandler(&Application::CtrlHandler, TRUE);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
@ -987,17 +987,17 @@ void Application::UpdatePidFile(const String& filename, pid_t pid)
|
||||||
{
|
{
|
||||||
ObjectLock olock(this);
|
ObjectLock olock(this);
|
||||||
|
|
||||||
if (m_PidFile != NULL)
|
if (m_PidFile)
|
||||||
fclose(m_PidFile);
|
fclose(m_PidFile);
|
||||||
|
|
||||||
/* There's just no sane way of getting a file descriptor for a
|
/* There's just no sane way of getting a file descriptor for a
|
||||||
* C++ ofstream which is why we're using FILEs here. */
|
* C++ ofstream which is why we're using FILEs here. */
|
||||||
m_PidFile = fopen(filename.CStr(), "r+");
|
m_PidFile = fopen(filename.CStr(), "r+");
|
||||||
|
|
||||||
if (m_PidFile == NULL)
|
if (!m_PidFile)
|
||||||
m_PidFile = fopen(filename.CStr(), "w");
|
m_PidFile = fopen(filename.CStr(), "w");
|
||||||
|
|
||||||
if (m_PidFile == NULL) {
|
if (!m_PidFile) {
|
||||||
Log(LogCritical, "Application")
|
Log(LogCritical, "Application")
|
||||||
<< "Could not open PID file '" << filename << "'.";
|
<< "Could not open PID file '" << filename << "'.";
|
||||||
BOOST_THROW_EXCEPTION(std::runtime_error("Could not open PID file '" + filename + "'"));
|
BOOST_THROW_EXCEPTION(std::runtime_error("Could not open PID file '" + filename + "'"));
|
||||||
|
@ -1042,8 +1042,7 @@ void Application::ClosePidFile(bool unlink)
|
||||||
{
|
{
|
||||||
ObjectLock olock(this);
|
ObjectLock olock(this);
|
||||||
|
|
||||||
if (m_PidFile != NULL)
|
if (m_PidFile) {
|
||||||
{
|
|
||||||
if (unlink) {
|
if (unlink) {
|
||||||
String pidpath = GetPidPath();
|
String pidpath = GetPidPath();
|
||||||
::unlink(pidpath.CStr());
|
::unlink(pidpath.CStr());
|
||||||
|
@ -1052,7 +1051,7 @@ void Application::ClosePidFile(bool unlink)
|
||||||
fclose(m_PidFile);
|
fclose(m_PidFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_PidFile = NULL;
|
m_PidFile = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1065,7 +1064,7 @@ pid_t Application::ReadPidFile(const String& filename)
|
||||||
{
|
{
|
||||||
FILE *pidfile = fopen(filename.CStr(), "r");
|
FILE *pidfile = fopen(filename.CStr(), "r");
|
||||||
|
|
||||||
if (pidfile == NULL)
|
if (!pidfile)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
|
|
|
@ -36,7 +36,7 @@ ContextFrame::~ContextFrame(void)
|
||||||
|
|
||||||
std::list<String>& ContextFrame::GetFrames(void)
|
std::list<String>& ContextFrame::GetFrames(void)
|
||||||
{
|
{
|
||||||
if (l_Frames.get() == NULL)
|
if (!l_Frames.get())
|
||||||
l_Frames.reset(new std::list<String>());
|
l_Frames.reset(new std::list<String>());
|
||||||
|
|
||||||
return *l_Frames;
|
return *l_Frames;
|
||||||
|
|
|
@ -56,7 +56,7 @@ inline void *cast_exception(void *obj, const std::type_info *src, const std::typ
|
||||||
if (dst->__do_catch(src, &thrown_ptr, 1))
|
if (dst->__do_catch(src, &thrown_ptr, 1))
|
||||||
return thrown_ptr;
|
return thrown_ptr;
|
||||||
else
|
else
|
||||||
return NULL;
|
return nullptr;
|
||||||
#else /* __GLIBCXX__ */
|
#else /* __GLIBCXX__ */
|
||||||
const libcxx_type_info *srcInfo = static_cast<const libcxx_type_info *>(src);
|
const libcxx_type_info *srcInfo = static_cast<const libcxx_type_info *>(src);
|
||||||
const libcxx_type_info *dstInfo = static_cast<const libcxx_type_info *>(dst);
|
const libcxx_type_info *dstInfo = static_cast<const libcxx_type_info *>(dst);
|
||||||
|
@ -66,7 +66,7 @@ inline void *cast_exception(void *obj, const std::type_info *src, const std::typ
|
||||||
if (dstInfo->can_catch(srcInfo, adj))
|
if (dstInfo->can_catch(srcInfo, adj))
|
||||||
return adj;
|
return adj;
|
||||||
else
|
else
|
||||||
return NULL;
|
return nullptr;
|
||||||
#endif /* __GLIBCXX__ */
|
#endif /* __GLIBCXX__ */
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -128,7 +128,7 @@ void __cxa_throw(void *obj, TYPEINFO_TYPE *pvtinfo, void (*dest)(void *))
|
||||||
SetLastExceptionStack(stack);
|
SetLastExceptionStack(stack);
|
||||||
|
|
||||||
#ifndef NO_CAST_EXCEPTION
|
#ifndef NO_CAST_EXCEPTION
|
||||||
if (ex && boost::get_error_info<StackTraceErrorInfo>(*ex) == NULL)
|
if (ex && !boost::get_error_info<StackTraceErrorInfo>(*ex))
|
||||||
*ex << StackTraceErrorInfo(stack);
|
*ex << StackTraceErrorInfo(stack);
|
||||||
}
|
}
|
||||||
#endif /* NO_CAST_EXCEPTION */
|
#endif /* NO_CAST_EXCEPTION */
|
||||||
|
@ -137,7 +137,7 @@ void __cxa_throw(void *obj, TYPEINFO_TYPE *pvtinfo, void (*dest)(void *))
|
||||||
SetLastExceptionContext(context);
|
SetLastExceptionContext(context);
|
||||||
|
|
||||||
#ifndef NO_CAST_EXCEPTION
|
#ifndef NO_CAST_EXCEPTION
|
||||||
if (ex && boost::get_error_info<ContextTraceErrorInfo>(*ex) == NULL)
|
if (ex && !boost::get_error_info<ContextTraceErrorInfo>(*ex))
|
||||||
*ex << ContextTraceErrorInfo(context);
|
*ex << ContextTraceErrorInfo(context);
|
||||||
#endif /* NO_CAST_EXCEPTION */
|
#endif /* NO_CAST_EXCEPTION */
|
||||||
|
|
||||||
|
@ -277,7 +277,7 @@ String icinga::DiagnosticInformation(boost::exception_ptr eptr, bool verbose)
|
||||||
try {
|
try {
|
||||||
boost::rethrow_exception(eptr);
|
boost::rethrow_exception(eptr);
|
||||||
} catch (const std::exception& ex) {
|
} catch (const std::exception& ex) {
|
||||||
return DiagnosticInformation(ex, verbose, pt ? &stack : NULL, pc ? &context : NULL);
|
return DiagnosticInformation(ex, verbose, pt ? &stack : nullptr, pc ? &context : nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
return boost::diagnostic_information(eptr);
|
return boost::diagnostic_information(eptr);
|
||||||
|
@ -320,7 +320,7 @@ void ScriptError::SetHandledByDebugger(bool handled)
|
||||||
}
|
}
|
||||||
|
|
||||||
posix_error::posix_error(void)
|
posix_error::posix_error(void)
|
||||||
: m_Message(NULL)
|
: m_Message(nullptr)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
posix_error::~posix_error(void) throw()
|
posix_error::~posix_error(void) throw()
|
||||||
|
|
|
@ -120,7 +120,7 @@ inline std::string to_string(const ContextTraceErrorInfo& e)
|
||||||
return msgbuf.str();
|
return msgbuf.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
I2_BASE_API String DiagnosticInformation(const std::exception& ex, bool verbose = true, StackTrace *stack = NULL, ContextTrace *context = NULL);
|
I2_BASE_API String DiagnosticInformation(const std::exception& ex, bool verbose = true, StackTrace *stack = nullptr, ContextTrace *context = nullptr);
|
||||||
I2_BASE_API String DiagnosticInformation(boost::exception_ptr eptr, bool verbose = true);
|
I2_BASE_API String DiagnosticInformation(boost::exception_ptr eptr, bool verbose = true);
|
||||||
|
|
||||||
class I2_BASE_API posix_error : virtual public std::exception, virtual public boost::exception {
|
class I2_BASE_API posix_error : virtual public std::exception, virtual public boost::exception {
|
||||||
|
|
|
@ -25,7 +25,7 @@ using namespace icinga;
|
||||||
* Constructor for the FIFO class.
|
* Constructor for the FIFO class.
|
||||||
*/
|
*/
|
||||||
FIFO::FIFO(void)
|
FIFO::FIFO(void)
|
||||||
: m_Buffer(NULL), m_DataSize(0), m_AllocSize(0), m_Offset(0)
|
: m_Buffer(nullptr), m_DataSize(0), m_AllocSize(0), m_Offset(0)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -53,7 +53,7 @@ void FIFO::ResizeBuffer(size_t newSize, bool decrease)
|
||||||
|
|
||||||
char *newBuffer = static_cast<char *>(realloc(m_Buffer, newSize));
|
char *newBuffer = static_cast<char *>(realloc(m_Buffer, newSize));
|
||||||
|
|
||||||
if (newBuffer == NULL)
|
if (!newBuffer)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
m_Buffer = newBuffer;
|
m_Buffer = newBuffer;
|
||||||
|
@ -85,7 +85,7 @@ size_t FIFO::Peek(void *buffer, size_t count, bool allow_partial)
|
||||||
if (count > m_DataSize)
|
if (count > m_DataSize)
|
||||||
count = m_DataSize;
|
count = m_DataSize;
|
||||||
|
|
||||||
if (buffer != NULL)
|
if (buffer)
|
||||||
std::memcpy(buffer, m_Buffer + m_Offset, count);
|
std::memcpy(buffer, m_Buffer + m_Offset, count);
|
||||||
|
|
||||||
return count;
|
return count;
|
||||||
|
@ -101,7 +101,7 @@ size_t FIFO::Read(void *buffer, size_t count, bool allow_partial)
|
||||||
if (count > m_DataSize)
|
if (count > m_DataSize)
|
||||||
count = m_DataSize;
|
count = m_DataSize;
|
||||||
|
|
||||||
if (buffer != NULL)
|
if (buffer)
|
||||||
std::memcpy(buffer, m_Buffer + m_Offset, count);
|
std::memcpy(buffer, m_Buffer + m_Offset, count);
|
||||||
|
|
||||||
m_DataSize -= count;
|
m_DataSize -= count;
|
||||||
|
|
|
@ -102,9 +102,9 @@ String icinga::JsonEncode(const Value& value, bool pretty_print)
|
||||||
{
|
{
|
||||||
#if YAJL_MAJOR < 2
|
#if YAJL_MAJOR < 2
|
||||||
yajl_gen_config conf = { pretty_print, "" };
|
yajl_gen_config conf = { pretty_print, "" };
|
||||||
yajl_gen handle = yajl_gen_alloc(&conf, NULL);
|
yajl_gen handle = yajl_gen_alloc(&conf, nullptr);
|
||||||
#else /* YAJL_MAJOR */
|
#else /* YAJL_MAJOR */
|
||||||
yajl_gen handle = yajl_gen_alloc(NULL);
|
yajl_gen handle = yajl_gen_alloc(nullptr);
|
||||||
if (pretty_print)
|
if (pretty_print)
|
||||||
yajl_gen_config(handle, yajl_gen_beautify, 1);
|
yajl_gen_config(handle, yajl_gen_beautify, 1);
|
||||||
#endif /* YAJL_MAJOR */
|
#endif /* YAJL_MAJOR */
|
||||||
|
@ -307,8 +307,8 @@ Value icinga::JsonDecode(const String& data)
|
||||||
static const yajl_callbacks callbacks = {
|
static const yajl_callbacks callbacks = {
|
||||||
DecodeNull,
|
DecodeNull,
|
||||||
DecodeBoolean,
|
DecodeBoolean,
|
||||||
NULL,
|
nullptr,
|
||||||
NULL,
|
nullptr,
|
||||||
DecodeNumber,
|
DecodeNumber,
|
||||||
DecodeString,
|
DecodeString,
|
||||||
DecodeStartMap,
|
DecodeStartMap,
|
||||||
|
@ -325,9 +325,9 @@ Value icinga::JsonDecode(const String& data)
|
||||||
JsonContext context;
|
JsonContext context;
|
||||||
|
|
||||||
#if YAJL_MAJOR < 2
|
#if YAJL_MAJOR < 2
|
||||||
handle = yajl_alloc(&callbacks, &cfg, NULL, &context);
|
handle = yajl_alloc(&callbacks, &cfg, nullptr, &context);
|
||||||
#else /* YAJL_MAJOR */
|
#else /* YAJL_MAJOR */
|
||||||
handle = yajl_alloc(&callbacks, NULL, &context);
|
handle = yajl_alloc(&callbacks, nullptr, &context);
|
||||||
yajl_config(handle, yajl_dont_validate_strings, 1);
|
yajl_config(handle, yajl_dont_validate_strings, 1);
|
||||||
yajl_config(handle, yajl_allow_comments, 1);
|
yajl_config(handle, yajl_allow_comments, 1);
|
||||||
#endif /* YAJL_MAJOR */
|
#endif /* YAJL_MAJOR */
|
||||||
|
|
|
@ -46,7 +46,7 @@ void Loader::LoadExtensionLibrary(const String& library)
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
HMODULE hModule = LoadLibrary(path.CStr());
|
HMODULE hModule = LoadLibrary(path.CStr());
|
||||||
|
|
||||||
if (hModule == NULL) {
|
if (!hModule) {
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< boost::errinfo_api_function("LoadLibrary")
|
<< boost::errinfo_api_function("LoadLibrary")
|
||||||
<< errinfo_win32_error(GetLastError())
|
<< errinfo_win32_error(GetLastError())
|
||||||
|
@ -55,7 +55,7 @@ void Loader::LoadExtensionLibrary(const String& library)
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
void *hModule = dlopen(path.CStr(), RTLD_NOW | RTLD_GLOBAL);
|
void *hModule = dlopen(path.CStr(), RTLD_NOW | RTLD_GLOBAL);
|
||||||
|
|
||||||
if (hModule == NULL) {
|
if (!hModule) {
|
||||||
BOOST_THROW_EXCEPTION(std::runtime_error("Could not load library '" + path + "': " + dlerror()));
|
BOOST_THROW_EXCEPTION(std::runtime_error("Could not load library '" + path + "': " + dlerror()));
|
||||||
}
|
}
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
|
@ -35,7 +35,7 @@ void NetworkStream::Close(void)
|
||||||
/**
|
/**
|
||||||
* Reads data from the stream.
|
* Reads data from the stream.
|
||||||
*
|
*
|
||||||
* @param buffer The buffer where data should be stored. May be NULL if you're
|
* @param buffer The buffer where data should be stored. May be nullptr if you're
|
||||||
* not actually interested in the data.
|
* not actually interested in the data.
|
||||||
* @param count The number of bytes to read from the queue.
|
* @param count The number of bytes to read from the queue.
|
||||||
* @returns The number of bytes actually read.
|
* @returns The number of bytes actually read.
|
||||||
|
|
|
@ -35,7 +35,7 @@ struct I2_BASE_API ObjectLock
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
inline ObjectLock(void)
|
inline ObjectLock(void)
|
||||||
: m_Object(NULL), m_Locked(false)
|
: m_Object(nullptr), m_Locked(false)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
inline ~ObjectLock(void)
|
inline ~ObjectLock(void)
|
||||||
|
@ -96,7 +96,7 @@ public:
|
||||||
|
|
||||||
inline void Lock(void)
|
inline void Lock(void)
|
||||||
{
|
{
|
||||||
ASSERT(!m_Locked && m_Object != NULL);
|
ASSERT(!m_Locked && m_Object);
|
||||||
|
|
||||||
LockMutex(m_Object);
|
LockMutex(m_Object);
|
||||||
|
|
||||||
|
|
|
@ -58,7 +58,7 @@ int ObjectType::GetFieldId(const String& name) const
|
||||||
Field ObjectType::GetFieldInfo(int id) const
|
Field ObjectType::GetFieldInfo(int id) const
|
||||||
{
|
{
|
||||||
if (id == 0)
|
if (id == 0)
|
||||||
return Field(1, "String", "type", NULL, NULL, 0, 0);
|
return Field(1, "String", "type", nullptr, nullptr, 0, 0);
|
||||||
else
|
else
|
||||||
BOOST_THROW_EXCEPTION(std::runtime_error("Invalid field ID."));
|
BOOST_THROW_EXCEPTION(std::runtime_error("Invalid field ID."));
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,7 @@ private:
|
||||||
REGISTER_PRIMITIVE_TYPE_FACTORY(type, base, prototype, DefaultObjectFactoryVA<type>)
|
REGISTER_PRIMITIVE_TYPE_FACTORY(type, base, prototype, DefaultObjectFactoryVA<type>)
|
||||||
|
|
||||||
#define REGISTER_PRIMITIVE_TYPE_NOINST(type, base, prototype) \
|
#define REGISTER_PRIMITIVE_TYPE_NOINST(type, base, prototype) \
|
||||||
REGISTER_PRIMITIVE_TYPE_FACTORY(type, base, prototype, NULL)
|
REGISTER_PRIMITIVE_TYPE_FACTORY(type, base, prototype, nullptr)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -72,7 +72,7 @@ Process::Process(const Process::Arguments& arguments, const Dictionary::Ptr& ext
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
m_Overlapped.hEvent = CreateEvent(NULL, TRUE, FALSE, NULL);
|
m_Overlapped.hEvent = CreateEvent(nullptr, TRUE, FALSE, nullptr);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ static Value ProcessSpawnImpl(struct msghdr *msgh, const Dictionary::Ptr& reques
|
||||||
{
|
{
|
||||||
struct cmsghdr *cmsg = CMSG_FIRSTHDR(msgh);
|
struct cmsghdr *cmsg = CMSG_FIRSTHDR(msgh);
|
||||||
|
|
||||||
if (cmsg == NULL || cmsg->cmsg_level != SOL_SOCKET || cmsg->cmsg_len != CMSG_LEN(sizeof(int) * 3)) {
|
if (cmsg == nullptr || cmsg->cmsg_level != SOL_SOCKET || cmsg->cmsg_len != CMSG_LEN(sizeof(int) * 3)) {
|
||||||
std::cerr << "Invalid 'spawn' request: FDs missing" << std::endl;
|
std::cerr << "Invalid 'spawn' request: FDs missing" << std::endl;
|
||||||
return Empty;
|
return Empty;
|
||||||
}
|
}
|
||||||
|
@ -107,13 +107,13 @@ static Value ProcessSpawnImpl(struct msghdr *msgh, const Dictionary::Ptr& reques
|
||||||
argv[i] = strdup(arg.CStr());
|
argv[i] = strdup(arg.CStr());
|
||||||
}
|
}
|
||||||
|
|
||||||
argv[arguments->GetLength()] = NULL;
|
argv[arguments->GetLength()] = nullptr;
|
||||||
|
|
||||||
// build envp
|
// build envp
|
||||||
int envc = 0;
|
int envc = 0;
|
||||||
|
|
||||||
/* count existing environment variables */
|
/* count existing environment variables */
|
||||||
while (environ[envc] != NULL)
|
while (environ[envc])
|
||||||
envc++;
|
envc++;
|
||||||
|
|
||||||
char **envp = new char *[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0) + 2];
|
char **envp = new char *[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0) + 2];
|
||||||
|
@ -133,7 +133,7 @@ static Value ProcessSpawnImpl(struct msghdr *msgh, const Dictionary::Ptr& reques
|
||||||
}
|
}
|
||||||
|
|
||||||
envp[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0)] = strdup("LC_NUMERIC=C");
|
envp[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0)] = strdup("LC_NUMERIC=C");
|
||||||
envp[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0) + 1] = NULL;
|
envp[envc + (extraEnvironment ? extraEnvironment->GetLength() : 0) + 1] = nullptr;
|
||||||
|
|
||||||
extraEnvironment.reset();
|
extraEnvironment.reset();
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ static Value ProcessSpawnImpl(struct msghdr *msgh, const Dictionary::Ptr& reques
|
||||||
|
|
||||||
sigset_t mask;
|
sigset_t mask;
|
||||||
sigemptyset(&mask);
|
sigemptyset(&mask);
|
||||||
sigprocmask(SIG_SETMASK, &mask, NULL);
|
sigprocmask(SIG_SETMASK, &mask, nullptr);
|
||||||
|
|
||||||
if (icinga2_execvpe(argv[0], argv, envp) < 0) {
|
if (icinga2_execvpe(argv[0], argv, envp) < 0) {
|
||||||
char errmsg[512];
|
char errmsg[512];
|
||||||
|
@ -190,13 +190,13 @@ static Value ProcessSpawnImpl(struct msghdr *msgh, const Dictionary::Ptr& reques
|
||||||
(void)close(fds[2]);
|
(void)close(fds[2]);
|
||||||
|
|
||||||
// free arguments
|
// free arguments
|
||||||
for (int i = 0; argv[i] != NULL; i++)
|
for (int i = 0; argv[i]; i++)
|
||||||
free(argv[i]);
|
free(argv[i]);
|
||||||
|
|
||||||
delete[] argv;
|
delete[] argv;
|
||||||
|
|
||||||
// free environment
|
// free environment
|
||||||
for (int i = 0; envp[i] != NULL; i++)
|
for (int i = 0; envp[i]; i++)
|
||||||
free(envp[i]);
|
free(envp[i]);
|
||||||
|
|
||||||
delete[] envp;
|
delete[] envp;
|
||||||
|
@ -241,7 +241,7 @@ static void ProcessHandler(void)
|
||||||
{
|
{
|
||||||
sigset_t mask;
|
sigset_t mask;
|
||||||
sigfillset(&mask);
|
sigfillset(&mask);
|
||||||
sigprocmask(SIG_SETMASK, &mask, NULL);
|
sigprocmask(SIG_SETMASK, &mask, nullptr);
|
||||||
|
|
||||||
rlimit rl;
|
rlimit rl;
|
||||||
if (getrlimit(RLIMIT_NOFILE, &rl) >= 0) {
|
if (getrlimit(RLIMIT_NOFILE, &rl) >= 0) {
|
||||||
|
@ -508,7 +508,7 @@ static void InitializeProcess(void)
|
||||||
{
|
{
|
||||||
for (int tid = 0; tid < IOTHREADS; tid++) {
|
for (int tid = 0; tid < IOTHREADS; tid++) {
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
l_Events[tid] = CreateEvent(NULL, TRUE, FALSE, NULL);
|
l_Events[tid] = CreateEvent(nullptr, TRUE, FALSE, nullptr);
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
# ifdef HAVE_PIPE2
|
# ifdef HAVE_PIPE2
|
||||||
if (pipe2(l_EventFDs[tid], O_CLOEXEC) < 0) {
|
if (pipe2(l_EventFDs[tid], O_CLOEXEC) < 0) {
|
||||||
|
@ -601,10 +601,10 @@ bool Process::GetAdjustPriority(void) const
|
||||||
void Process::IOThreadProc(int tid)
|
void Process::IOThreadProc(int tid)
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
HANDLE *handles = NULL;
|
HANDLE *handles = nullptr;
|
||||||
HANDLE *fhandles = NULL;
|
HANDLE *fhandles = nullptr;
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
pollfd *pfds = NULL;
|
pollfd *pfds = nullptr;
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
int count = 0;
|
int count = 0;
|
||||||
double now;
|
double now;
|
||||||
|
@ -773,7 +773,7 @@ static BOOL CreatePipeOverlapped(HANDLE *outReadPipe, HANDLE *outWritePipe,
|
||||||
if (*outReadPipe == INVALID_HANDLE_VALUE)
|
if (*outReadPipe == INVALID_HANDLE_VALUE)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
*outWritePipe = CreateFile(pipeName, GENERIC_WRITE, 0, securityAttributes, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL | writeMode, NULL);
|
*outWritePipe = CreateFile(pipeName, GENERIC_WRITE, 0, securityAttributes, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL | writeMode, nullptr);
|
||||||
|
|
||||||
if (*outWritePipe == INVALID_HANDLE_VALUE) {
|
if (*outWritePipe == INVALID_HANDLE_VALUE) {
|
||||||
DWORD error = GetLastError();
|
DWORD error = GetLastError();
|
||||||
|
@ -821,7 +821,7 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
/* LPPROC_THREAD_ATTRIBUTE_LIST lpAttributeList;
|
/* LPPROC_THREAD_ATTRIBUTE_LIST lpAttributeList;
|
||||||
SIZE_T cbSize;
|
SIZE_T cbSize;
|
||||||
|
|
||||||
if (!InitializeProcThreadAttributeList(NULL, 1, 0, &cbSize) && GetLastError() != ERROR_INSUFFICIENT_BUFFER)
|
if (!InitializeProcThreadAttributeList(nullptr, 1, 0, &cbSize) && GetLastError() != ERROR_INSUFFICIENT_BUFFER)
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< boost::errinfo_api_function("InitializeProcThreadAttributeList")
|
<< boost::errinfo_api_function("InitializeProcThreadAttributeList")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< errinfo_win32_error(GetLastError()));
|
||||||
|
@ -839,7 +839,7 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
rgHandles[2] = GetStdHandle(STD_INPUT_HANDLE);
|
rgHandles[2] = GetStdHandle(STD_INPUT_HANDLE);
|
||||||
|
|
||||||
if (!UpdateProcThreadAttribute(lpAttributeList, 0, PROC_THREAD_ATTRIBUTE_HANDLE_LIST,
|
if (!UpdateProcThreadAttribute(lpAttributeList, 0, PROC_THREAD_ATTRIBUTE_HANDLE_LIST,
|
||||||
rgHandles, sizeof(rgHandles), NULL, NULL))
|
rgHandles, sizeof(rgHandles), nullptr, nullptr))
|
||||||
BOOST_THROW_EXCEPTION(win32_error()
|
BOOST_THROW_EXCEPTION(win32_error()
|
||||||
<< boost::errinfo_api_function("UpdateProcThreadAttribute")
|
<< boost::errinfo_api_function("UpdateProcThreadAttribute")
|
||||||
<< errinfo_win32_error(GetLastError()));
|
<< errinfo_win32_error(GetLastError()));
|
||||||
|
@ -862,7 +862,7 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
LPCH pEnvironment = GetEnvironmentStrings();
|
LPCH pEnvironment = GetEnvironmentStrings();
|
||||||
size_t ioffset = 0, offset = 0;
|
size_t ioffset = 0, offset = 0;
|
||||||
|
|
||||||
char *envp = NULL;
|
char *envp = nullptr;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
size_t len = strlen(pEnvironment + ioffset);
|
size_t len = strlen(pEnvironment + ioffset);
|
||||||
|
@ -878,7 +878,7 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
|
|
||||||
envp = static_cast<char *>(realloc(envp, offset + len + 1));
|
envp = static_cast<char *>(realloc(envp, offset + len + 1));
|
||||||
|
|
||||||
if (envp == NULL)
|
if (!envp)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
strcpy(envp + offset, pEnvironment + ioffset);
|
strcpy(envp + offset, pEnvironment + ioffset);
|
||||||
|
@ -896,7 +896,7 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
|
|
||||||
envp = static_cast<char *>(realloc(envp, offset + skv.GetLength() + 1));
|
envp = static_cast<char *>(realloc(envp, offset + skv.GetLength() + 1));
|
||||||
|
|
||||||
if (envp == NULL)
|
if (!envp)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
strcpy(envp + offset, skv.CStr());
|
strcpy(envp + offset, skv.CStr());
|
||||||
|
@ -906,13 +906,13 @@ void Process::Run(const std::function<void(const ProcessResult&)>& callback)
|
||||||
|
|
||||||
envp = static_cast<char *>(realloc(envp, offset + 1));
|
envp = static_cast<char *>(realloc(envp, offset + 1));
|
||||||
|
|
||||||
if (envp == NULL)
|
if (!envp)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
envp[offset] = '\0';
|
envp[offset] = '\0';
|
||||||
|
|
||||||
if (!CreateProcess(NULL, args, NULL, NULL, TRUE,
|
if (!CreateProcess(nullptr, args, nullptr, nullptr, TRUE,
|
||||||
0 /*EXTENDED_STARTUPINFO_PRESENT*/, envp, NULL, &si.StartupInfo, &pi)) {
|
0 /*EXTENDED_STARTUPINFO_PRESENT*/, envp, nullptr, &si.StartupInfo, &pi)) {
|
||||||
DWORD error = GetLastError();
|
DWORD error = GetLastError();
|
||||||
CloseHandle(outWritePipe);
|
CloseHandle(outWritePipe);
|
||||||
CloseHandle(outWritePipeDup);
|
CloseHandle(outWritePipeDup);
|
||||||
|
|
|
@ -34,7 +34,7 @@ namespace icinga
|
||||||
class I2_BASE_API ScriptGlobal
|
class I2_BASE_API ScriptGlobal
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static Value Get(const String& name, const Value *defaultValue = NULL);
|
static Value Get(const String& name, const Value *defaultValue = nullptr);
|
||||||
static void Set(const String& name, const Value& value);
|
static void Set(const String& name, const Value& value);
|
||||||
static bool Exists(const String& name);
|
static bool Exists(const String& name);
|
||||||
|
|
||||||
|
|
|
@ -155,12 +155,12 @@ Value icinga::Serialize(const Value& value, int attributeTypes)
|
||||||
|
|
||||||
Array::Ptr array = dynamic_pointer_cast<Array>(input);
|
Array::Ptr array = dynamic_pointer_cast<Array>(input);
|
||||||
|
|
||||||
if (array != NULL)
|
if (array)
|
||||||
return SerializeArray(array, attributeTypes);
|
return SerializeArray(array, attributeTypes);
|
||||||
|
|
||||||
Dictionary::Ptr dict = dynamic_pointer_cast<Dictionary>(input);
|
Dictionary::Ptr dict = dynamic_pointer_cast<Dictionary>(input);
|
||||||
|
|
||||||
if (dict != NULL)
|
if (dict)
|
||||||
return SerializeDictionary(dict, attributeTypes);
|
return SerializeDictionary(dict, attributeTypes);
|
||||||
|
|
||||||
return SerializeObject(input, attributeTypes);
|
return SerializeObject(input, attributeTypes);
|
||||||
|
@ -180,12 +180,12 @@ Value icinga::Deserialize(const Object::Ptr& object, const Value& value, bool sa
|
||||||
|
|
||||||
Array::Ptr array = dynamic_pointer_cast<Array>(input);
|
Array::Ptr array = dynamic_pointer_cast<Array>(input);
|
||||||
|
|
||||||
if (array != NULL)
|
if (array)
|
||||||
return DeserializeArray(array, safe_mode, attributeTypes);
|
return DeserializeArray(array, safe_mode, attributeTypes);
|
||||||
|
|
||||||
Dictionary::Ptr dict = dynamic_pointer_cast<Dictionary>(input);
|
Dictionary::Ptr dict = dynamic_pointer_cast<Dictionary>(input);
|
||||||
|
|
||||||
ASSERT(dict != NULL);
|
ASSERT(dict);
|
||||||
|
|
||||||
if ((safe_mode && !object) || !dict->Contains("type"))
|
if ((safe_mode && !object) || !dict->Contains("type"))
|
||||||
return DeserializeDictionary(dict, safe_mode, attributeTypes);
|
return DeserializeDictionary(dict, safe_mode, attributeTypes);
|
||||||
|
|
|
@ -53,7 +53,7 @@ public:
|
||||||
void Listen(void);
|
void Listen(void);
|
||||||
Socket::Ptr Accept(void);
|
Socket::Ptr Accept(void);
|
||||||
|
|
||||||
bool Poll(bool read, bool write, struct timeval *timeout = NULL);
|
bool Poll(bool read, bool write, struct timeval *timeout = nullptr);
|
||||||
|
|
||||||
void MakeNonBlocking(void);
|
void MakeNonBlocking(void);
|
||||||
|
|
||||||
|
|
|
@ -174,7 +174,7 @@ void SocketEventEngineEpoll::Unregister(SocketEvents *se)
|
||||||
m_Sockets[tid].erase(se->m_FD);
|
m_Sockets[tid].erase(se->m_FD);
|
||||||
m_FDChanged[tid] = true;
|
m_FDChanged[tid] = true;
|
||||||
|
|
||||||
epoll_ctl(m_PollFDs[tid], EPOLL_CTL_DEL, se->m_FD, NULL);
|
epoll_ctl(m_PollFDs[tid], EPOLL_CTL_DEL, se->m_FD, nullptr);
|
||||||
|
|
||||||
se->m_FD = INVALID_SOCKET;
|
se->m_FD = INVALID_SOCKET;
|
||||||
se->m_Events = false;
|
se->m_Events = false;
|
||||||
|
|
|
@ -112,7 +112,7 @@ void SocketEvents::InitializeEngine(void)
|
||||||
* Constructor for the SocketEvents class.
|
* Constructor for the SocketEvents class.
|
||||||
*/
|
*/
|
||||||
SocketEvents::SocketEvents(const Socket::Ptr& socket, Object *lifesupportObject)
|
SocketEvents::SocketEvents(const Socket::Ptr& socket, Object *lifesupportObject)
|
||||||
: m_ID(m_NextID++), m_FD(socket->GetFD()), m_EnginePrivate(NULL)
|
: m_ID(m_NextID++), m_FD(socket->GetFD()), m_EnginePrivate(nullptr)
|
||||||
{
|
{
|
||||||
boost::call_once(l_SocketIOOnceFlag, &SocketEvents::InitializeEngine);
|
boost::call_once(l_SocketIOOnceFlag, &SocketEvents::InitializeEngine);
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ struct SocketEventDescriptor
|
||||||
Object *LifesupportObject;
|
Object *LifesupportObject;
|
||||||
|
|
||||||
SocketEventDescriptor(void)
|
SocketEventDescriptor(void)
|
||||||
: Events(POLLIN), EventInterface(NULL), LifesupportObject(NULL)
|
: Events(POLLIN), EventInterface(nullptr), LifesupportObject(nullptr)
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@ StackTrace::StackTrace(void)
|
||||||
m_Count = backtrace(m_Frames, sizeof(m_Frames) / sizeof(m_Frames[0]));
|
m_Count = backtrace(m_Frames, sizeof(m_Frames) / sizeof(m_Frames[0]));
|
||||||
#else /* HAVE_BACKTRACE_SYMBOLS */
|
#else /* HAVE_BACKTRACE_SYMBOLS */
|
||||||
# ifdef _WIN32
|
# ifdef _WIN32
|
||||||
m_Count = CaptureStackBackTrace(0, sizeof(m_Frames) / sizeof(m_Frames), m_Frames, NULL);
|
m_Count = CaptureStackBackTrace(0, sizeof(m_Frames) / sizeof(m_Frames), m_Frames, nullptr);
|
||||||
# else /* _WIN32 */
|
# else /* _WIN32 */
|
||||||
m_Count = 0;
|
m_Count = 0;
|
||||||
# endif /* _WIN32 */
|
# endif /* _WIN32 */
|
||||||
|
@ -75,8 +75,8 @@ StackTrace::StackTrace(PEXCEPTION_POINTERS exi)
|
||||||
m_Count = 0;
|
m_Count = 0;
|
||||||
|
|
||||||
while (StackWalk64(architecture, GetCurrentProcess(), GetCurrentThread(),
|
while (StackWalk64(architecture, GetCurrentProcess(), GetCurrentThread(),
|
||||||
&frame, exi->ContextRecord, NULL, &SymFunctionTableAccess64,
|
&frame, exi->ContextRecord, nullptr, &SymFunctionTableAccess64,
|
||||||
&SymGetModuleBase64, NULL) && m_Count < sizeof(m_Frames) / sizeof(m_Frames[0])) {
|
&SymGetModuleBase64, nullptr) && m_Count < sizeof(m_Frames) / sizeof(m_Frames[0])) {
|
||||||
m_Frames[m_Count] = reinterpret_cast<void *>(frame.AddrPC.Offset);
|
m_Frames[m_Count] = reinterpret_cast<void *>(frame.AddrPC.Offset);
|
||||||
m_Count++;
|
m_Count++;
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ StackTrace::StackTrace(PEXCEPTION_POINTERS exi)
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
INITIALIZE_ONCE([]() {
|
INITIALIZE_ONCE([]() {
|
||||||
(void) SymSetOptions(SYMOPT_UNDNAME | SYMOPT_LOAD_LINES);
|
(void) SymSetOptions(SYMOPT_UNDNAME | SYMOPT_LOAD_LINES);
|
||||||
(void) SymInitialize(GetCurrentProcess(), NULL, TRUE);
|
(void) SymInitialize(GetCurrentProcess(), nullptr, TRUE);
|
||||||
});
|
});
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ void StackTrace::Print(std::ostream& fp, int ignoreFrames) const
|
||||||
# ifdef HAVE_BACKTRACE_SYMBOLS
|
# ifdef HAVE_BACKTRACE_SYMBOLS
|
||||||
char **messages = backtrace_symbols(m_Frames, m_Count);
|
char **messages = backtrace_symbols(m_Frames, m_Count);
|
||||||
|
|
||||||
for (int i = ignoreFrames + 1; i < m_Count && messages != NULL; ++i) {
|
for (int i = ignoreFrames + 1; i < m_Count && messages; ++i) {
|
||||||
String message = messages[i];
|
String message = messages[i];
|
||||||
|
|
||||||
char *sym_begin = strchr(messages[i], '(');
|
char *sym_begin = strchr(messages[i], '(');
|
||||||
|
@ -114,7 +114,7 @@ void StackTrace::Print(std::ostream& fp, int ignoreFrames) const
|
||||||
if (sym_begin) {
|
if (sym_begin) {
|
||||||
char *sym_end = strchr(sym_begin, '+');
|
char *sym_end = strchr(sym_begin, '+');
|
||||||
|
|
||||||
if (sym_end != NULL) {
|
if (sym_end) {
|
||||||
String sym = String(sym_begin + 1, sym_end);
|
String sym = String(sym_begin + 1, sym_end);
|
||||||
String sym_demangled = Utility::DemangleSymbolName(sym);
|
String sym_demangled = Utility::DemangleSymbolName(sym);
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@ enum ConnectionRole
|
||||||
struct I2_BASE_API StreamReadContext
|
struct I2_BASE_API StreamReadContext
|
||||||
{
|
{
|
||||||
StreamReadContext(void)
|
StreamReadContext(void)
|
||||||
: Buffer(NULL), Size(0), MustRead(true), Eof(false)
|
: Buffer(nullptr), Size(0), MustRead(true), Eof(false)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
~StreamReadContext(void)
|
~StreamReadContext(void)
|
||||||
|
@ -76,7 +76,7 @@ public:
|
||||||
/**
|
/**
|
||||||
* Reads data from the stream without removing it from the stream buffer.
|
* Reads data from the stream without removing it from the stream buffer.
|
||||||
*
|
*
|
||||||
* @param buffer The buffer where data should be stored. May be NULL if you're
|
* @param buffer The buffer where data should be stored. May be nullptr if you're
|
||||||
* not actually interested in the data.
|
* not actually interested in the data.
|
||||||
* @param count The number of bytes to read from the queue.
|
* @param count The number of bytes to read from the queue.
|
||||||
* @param allow_partial Whether to allow partial reads.
|
* @param allow_partial Whether to allow partial reads.
|
||||||
|
@ -87,7 +87,7 @@ public:
|
||||||
/**
|
/**
|
||||||
* Reads data from the stream.
|
* Reads data from the stream.
|
||||||
*
|
*
|
||||||
* @param buffer The buffer where data should be stored. May be NULL if you're
|
* @param buffer The buffer where data should be stored. May be nullptr if you're
|
||||||
* not actually interested in the data.
|
* not actually interested in the data.
|
||||||
* @param count The number of bytes to read from the queue.
|
* @param count The number of bytes to read from the queue.
|
||||||
* @param allow_partial Whether to allow partial reads.
|
* @param allow_partial Whether to allow partial reads.
|
||||||
|
|
|
@ -34,7 +34,7 @@ boost::mutex StreamLogger::m_Mutex;
|
||||||
* Constructor for the StreamLogger class.
|
* Constructor for the StreamLogger class.
|
||||||
*/
|
*/
|
||||||
StreamLogger::StreamLogger(void)
|
StreamLogger::StreamLogger(void)
|
||||||
: m_Stream(NULL), m_OwnsStream(false)
|
: m_Stream(nullptr), m_OwnsStream(false)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void StreamLogger::Stop(bool runtimeRemoved)
|
void StreamLogger::Stop(bool runtimeRemoved)
|
||||||
|
|
|
@ -58,7 +58,7 @@ void TcpSocket::Bind(const String& node, const String& service, int family)
|
||||||
hints.ai_protocol = IPPROTO_TCP;
|
hints.ai_protocol = IPPROTO_TCP;
|
||||||
hints.ai_flags = AI_PASSIVE;
|
hints.ai_flags = AI_PASSIVE;
|
||||||
|
|
||||||
int rc = getaddrinfo(node.IsEmpty() ? NULL : node.CStr(),
|
int rc = getaddrinfo(node.IsEmpty() ? nullptr : node.CStr(),
|
||||||
service.CStr(), &hints, &result);
|
service.CStr(), &hints, &result);
|
||||||
|
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
|
@ -72,7 +72,7 @@ void TcpSocket::Bind(const String& node, const String& service, int family)
|
||||||
|
|
||||||
int fd = INVALID_SOCKET;
|
int fd = INVALID_SOCKET;
|
||||||
|
|
||||||
for (addrinfo *info = result; info != NULL; info = info->ai_next) {
|
for (addrinfo *info = result; info != nullptr; info = info->ai_next) {
|
||||||
fd = socket(info->ai_family, info->ai_socktype, info->ai_protocol);
|
fd = socket(info->ai_family, info->ai_socktype, info->ai_protocol);
|
||||||
|
|
||||||
if (fd == INVALID_SOCKET) {
|
if (fd == INVALID_SOCKET) {
|
||||||
|
@ -163,7 +163,7 @@ void TcpSocket::Connect(const String& node, const String& service)
|
||||||
|
|
||||||
SOCKET fd = INVALID_SOCKET;
|
SOCKET fd = INVALID_SOCKET;
|
||||||
|
|
||||||
for (addrinfo *info = result; info != NULL; info = info->ai_next) {
|
for (addrinfo *info = result; info != nullptr; info = info->ai_next) {
|
||||||
fd = socket(info->ai_family, info->ai_socktype, info->ai_protocol);
|
fd = socket(info->ai_family, info->ai_socktype, info->ai_protocol);
|
||||||
|
|
||||||
if (fd == INVALID_SOCKET) {
|
if (fd == INVALID_SOCKET) {
|
||||||
|
|
|
@ -83,7 +83,7 @@ private:
|
||||||
boost::thread *Thread;
|
boost::thread *Thread;
|
||||||
|
|
||||||
WorkerThread(ThreadState state = ThreadDead)
|
WorkerThread(ThreadState state = ThreadDead)
|
||||||
: State(state), Zombie(false), Utilization(0), LastUpdate(0), Thread(NULL)
|
: State(state), Zombie(false), Utilization(0), LastUpdate(0), Thread(nullptr)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void UpdateUtilization(ThreadState state = ThreadUnspecified);
|
void UpdateUtilization(ThreadState state = ThreadUnspecified);
|
||||||
|
|
|
@ -58,7 +58,7 @@ TlsStream::TlsStream(const Socket::Ptr& socket, const String& hostname, Connecti
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!m_SSLIndexInitialized) {
|
if (!m_SSLIndexInitialized) {
|
||||||
m_SSLIndex = SSL_get_ex_new_index(0, const_cast<char *>("TlsStream"), NULL, NULL, NULL);
|
m_SSLIndex = SSL_get_ex_new_index(0, const_cast<char *>("TlsStream"), nullptr, nullptr, nullptr);
|
||||||
m_SSLIndexInitialized = true;
|
m_SSLIndexInitialized = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,7 +187,7 @@ void TlsStream::OnEvent(int revents)
|
||||||
rc = SSL_write(m_SSL.get(), buffer, count);
|
rc = SSL_write(m_SSL.get(), buffer, count);
|
||||||
|
|
||||||
if (rc > 0) {
|
if (rc > 0) {
|
||||||
m_SendQ->Read(NULL, rc, true);
|
m_SendQ->Read(nullptr, rc, true);
|
||||||
success = true;
|
success = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,7 +232,7 @@ void TlsStream::OnEvent(int revents)
|
||||||
|
|
||||||
if (m_ErrorCode != 0) {
|
if (m_ErrorCode != 0) {
|
||||||
Log(LogWarning, "TlsStream")
|
Log(LogWarning, "TlsStream")
|
||||||
<< "OpenSSL error: " << ERR_error_string(m_ErrorCode, NULL);
|
<< "OpenSSL error: " << ERR_error_string(m_ErrorCode, nullptr);
|
||||||
} else {
|
} else {
|
||||||
Log(LogWarning, "TlsStream", "TLS stream was disconnected.");
|
Log(LogWarning, "TlsStream", "TLS stream was disconnected.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,7 @@ std::shared_ptr<SSL_CTX> MakeSSLContext(const String& pubkey, const String& priv
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cakey.IsEmpty()) {
|
if (!cakey.IsEmpty()) {
|
||||||
if (!SSL_CTX_load_verify_locations(sslContext.get(), cakey.CStr(), NULL)) {
|
if (!SSL_CTX_load_verify_locations(sslContext.get(), cakey.CStr(), nullptr)) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
<< "Error loading and verifying locations in ca key file '" << cakey << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
<< "Error loading and verifying locations in ca key file '" << cakey << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
|
@ -154,7 +154,7 @@ std::shared_ptr<SSL_CTX> MakeSSLContext(const String& pubkey, const String& priv
|
||||||
STACK_OF(X509_NAME) *cert_names;
|
STACK_OF(X509_NAME) *cert_names;
|
||||||
|
|
||||||
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) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
<< "Error loading client ca key file '" << cakey << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
<< "Error loading client ca key file '" << cakey << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
|
@ -298,7 +298,7 @@ std::shared_ptr<X509> GetX509Certificate(const String& pemfile)
|
||||||
X509 *cert;
|
X509 *cert;
|
||||||
BIO *fpcert = BIO_new(BIO_s_file());
|
BIO *fpcert = BIO_new(BIO_s_file());
|
||||||
|
|
||||||
if (fpcert == NULL) {
|
if (!fpcert) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
<< "Error creating new BIO: " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
<< "Error creating new BIO: " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
|
@ -315,8 +315,8 @@ std::shared_ptr<X509> GetX509Certificate(const String& pemfile)
|
||||||
<< boost::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, nullptr, nullptr, nullptr);
|
||||||
if (cert == NULL) {
|
if (!cert) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
<< "Error on bio X509 AUX reading pem file '" << pemfile << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
<< "Error on bio X509 AUX reading pem file '" << pemfile << "': " << ERR_peek_error() << ", \"" << ERR_error_string(ERR_peek_error(), errbuf) << "\"";
|
||||||
BOOST_THROW_EXCEPTION(openssl_error()
|
BOOST_THROW_EXCEPTION(openssl_error()
|
||||||
|
@ -379,7 +379,7 @@ int MakeX509CSR(const String& cn, const String& keyfile, const String& csrfile,
|
||||||
<< boost::errinfo_file_name(keyfile));
|
<< boost::errinfo_file_name(keyfile));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!PEM_write_bio_PrivateKey(bio, key, NULL, NULL, 0, 0, NULL)) {
|
if (!PEM_write_bio_PrivateKey(bio, key, nullptr, nullptr, 0, 0, nullptr)) {
|
||||||
EVP_PKEY_free(key);
|
EVP_PKEY_free(key);
|
||||||
EC_KEY_free(eckey);
|
EC_KEY_free(eckey);
|
||||||
BIO_free(bio);
|
BIO_free(bio);
|
||||||
|
@ -446,7 +446,7 @@ int MakeX509CSR(const String& cn, const String& keyfile, const String& csrfile,
|
||||||
|
|
||||||
if (!ca) {
|
if (!ca) {
|
||||||
String san = "DNS:" + cn;
|
String san = "DNS:" + cn;
|
||||||
X509_EXTENSION *subjectAltNameExt = X509V3_EXT_conf_nid(NULL, NULL, NID_subject_alt_name, const_cast<char *>(san.CStr()));
|
X509_EXTENSION *subjectAltNameExt = X509V3_EXT_conf_nid(nullptr, nullptr, NID_subject_alt_name, const_cast<char *>(san.CStr()));
|
||||||
if (subjectAltNameExt) {
|
if (subjectAltNameExt) {
|
||||||
/* OpenSSL 0.9.8 requires STACK_OF(X509_EXTENSION), otherwise we would just use stack_st_X509_EXTENSION. */
|
/* OpenSSL 0.9.8 requires STACK_OF(X509_EXTENSION), otherwise we would just use stack_st_X509_EXTENSION. */
|
||||||
STACK_OF(X509_EXTENSION) *exts = sk_X509_EXTENSION_new_null();
|
STACK_OF(X509_EXTENSION) *exts = sk_X509_EXTENSION_new_null();
|
||||||
|
@ -539,7 +539,7 @@ std::shared_ptr<X509> CreateCert(EVP_PKEY *pubkey, X509_NAME *subject, X509_NAME
|
||||||
|
|
||||||
X509V3_CTX ctx;
|
X509V3_CTX ctx;
|
||||||
X509V3_set_ctx_nodb(&ctx);
|
X509V3_set_ctx_nodb(&ctx);
|
||||||
X509V3_set_ctx(&ctx, cert, cert, NULL, NULL, 0);
|
X509V3_set_ctx(&ctx, cert, cert, nullptr, nullptr, 0);
|
||||||
|
|
||||||
const char *attr;
|
const char *attr;
|
||||||
|
|
||||||
|
@ -548,7 +548,7 @@ std::shared_ptr<X509> CreateCert(EVP_PKEY *pubkey, X509_NAME *subject, X509_NAME
|
||||||
else
|
else
|
||||||
attr = "critical,CA:FALSE";
|
attr = "critical,CA:FALSE";
|
||||||
|
|
||||||
X509_EXTENSION *basicConstraintsExt = X509V3_EXT_conf_nid(NULL, &ctx, NID_basic_constraints, const_cast<char *>(attr));
|
X509_EXTENSION *basicConstraintsExt = X509V3_EXT_conf_nid(nullptr, &ctx, NID_basic_constraints, const_cast<char *>(attr));
|
||||||
|
|
||||||
if (basicConstraintsExt) {
|
if (basicConstraintsExt) {
|
||||||
X509_add_ext(cert, basicConstraintsExt, -1);
|
X509_add_ext(cert, basicConstraintsExt, -1);
|
||||||
|
@ -559,7 +559,7 @@ std::shared_ptr<X509> CreateCert(EVP_PKEY *pubkey, X509_NAME *subject, X509_NAME
|
||||||
|
|
||||||
if (!ca) {
|
if (!ca) {
|
||||||
String san = "DNS:" + cn;
|
String san = "DNS:" + cn;
|
||||||
X509_EXTENSION *subjectAltNameExt = X509V3_EXT_conf_nid(NULL, &ctx, NID_subject_alt_name, const_cast<char *>(san.CStr()));
|
X509_EXTENSION *subjectAltNameExt = X509V3_EXT_conf_nid(nullptr, &ctx, NID_subject_alt_name, const_cast<char *>(san.CStr()));
|
||||||
if (subjectAltNameExt) {
|
if (subjectAltNameExt) {
|
||||||
X509_add_ext(cert, subjectAltNameExt, -1);
|
X509_add_ext(cert, subjectAltNameExt, -1);
|
||||||
X509_EXTENSION_free(subjectAltNameExt);
|
X509_EXTENSION_free(subjectAltNameExt);
|
||||||
|
@ -592,7 +592,7 @@ std::shared_ptr<X509> CreateCertIcingaCA(EVP_PKEY *pubkey, X509_NAME *subject)
|
||||||
return std::shared_ptr<X509>();
|
return std::shared_ptr<X509>();
|
||||||
}
|
}
|
||||||
|
|
||||||
EVP_PKEY *privkey = PEM_read_bio_PrivateKey(cakeybio, NULL, NULL, NULL);
|
EVP_PKEY *privkey = PEM_read_bio_PrivateKey(cakeybio, nullptr, nullptr, nullptr);
|
||||||
|
|
||||||
if (!privkey) {
|
if (!privkey) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
|
@ -635,7 +635,7 @@ std::shared_ptr<X509> StringToCertificate(const String& cert)
|
||||||
BIO *bio = BIO_new(BIO_s_mem());
|
BIO *bio = BIO_new(BIO_s_mem());
|
||||||
BIO_write(bio, (const void *)cert.CStr(), cert.GetLength());
|
BIO_write(bio, (const void *)cert.CStr(), cert.GetLength());
|
||||||
|
|
||||||
X509 *rawCert = PEM_read_bio_X509_AUX(bio, NULL, NULL, NULL);
|
X509 *rawCert = PEM_read_bio_X509_AUX(bio, nullptr, nullptr, nullptr);
|
||||||
|
|
||||||
BIO_free(bio);
|
BIO_free(bio);
|
||||||
|
|
||||||
|
@ -772,7 +772,7 @@ bool VerifyCertificate(const std::shared_ptr<X509>& caCertificate, const std::sh
|
||||||
X509_STORE_add_cert(store, caCertificate.get());
|
X509_STORE_add_cert(store, caCertificate.get());
|
||||||
|
|
||||||
X509_STORE_CTX *csc = X509_STORE_CTX_new();
|
X509_STORE_CTX *csc = X509_STORE_CTX_new();
|
||||||
X509_STORE_CTX_init(csc, store, certificate.get(), NULL);
|
X509_STORE_CTX_init(csc, store, certificate.get(), nullptr);
|
||||||
|
|
||||||
int rc = X509_verify_cert(csc);
|
int rc = X509_verify_cert(csc);
|
||||||
|
|
||||||
|
|
|
@ -69,7 +69,7 @@ inline std::string to_string(const errinfo_openssl_error& e)
|
||||||
|
|
||||||
const char *message = ERR_error_string(code, errbuf);
|
const char *message = ERR_error_string(code, errbuf);
|
||||||
|
|
||||||
if (message == NULL)
|
if (!message)
|
||||||
message = "Unknown error.";
|
message = "Unknown error.";
|
||||||
|
|
||||||
tmp << code << ", \"" << message << "\"";
|
tmp << code << ", \"" << message << "\"";
|
||||||
|
|
|
@ -39,7 +39,7 @@ String Type::ToString(void) const
|
||||||
|
|
||||||
void Type::Register(const Type::Ptr& type)
|
void Type::Register(const Type::Ptr& type)
|
||||||
{
|
{
|
||||||
VERIFY(GetByName(type->GetName()) == NULL);
|
VERIFY(!GetByName(type->GetName()));
|
||||||
|
|
||||||
ScriptGlobal::Set("Types." + type->GetName(), type);
|
ScriptGlobal::Set("Types." + type->GetName(), type);
|
||||||
}
|
}
|
||||||
|
@ -195,11 +195,11 @@ Field TypeType::GetFieldInfo(int id) const
|
||||||
return GetBaseType()->GetFieldInfo(id);
|
return GetBaseType()->GetFieldInfo(id);
|
||||||
|
|
||||||
if (real_id == 0)
|
if (real_id == 0)
|
||||||
return Field(0, "String", "name", "", NULL, 0, 0);
|
return Field(0, "String", "name", "", nullptr, 0, 0);
|
||||||
else if (real_id == 1)
|
else if (real_id == 1)
|
||||||
return Field(1, "Object", "prototype", "", NULL, 0, 0);
|
return Field(1, "Object", "prototype", "", nullptr, 0, 0);
|
||||||
else if (real_id == 2)
|
else if (real_id == 2)
|
||||||
return Field(2, "Type", "base", "", NULL, 0, 0);
|
return Field(2, "Type", "base", "", nullptr, 0, 0);
|
||||||
|
|
||||||
throw std::runtime_error("Invalid field ID.");
|
throw std::runtime_error("Invalid field ID.");
|
||||||
}
|
}
|
||||||
|
@ -211,6 +211,6 @@ int TypeType::GetFieldCount(void) const
|
||||||
|
|
||||||
ObjectFactory TypeType::GetFactory(void) const
|
ObjectFactory TypeType::GetFactory(void) const
|
||||||
{
|
{
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -85,7 +85,7 @@ String Utility::DemangleSymbolName(const String& sym)
|
||||||
int status;
|
int status;
|
||||||
char *realname = abi::__cxa_demangle(sym.CStr(), 0, 0, &status);
|
char *realname = abi::__cxa_demangle(sym.CStr(), 0, 0, &status);
|
||||||
|
|
||||||
if (realname != NULL) {
|
if (realname) {
|
||||||
result = String(realname);
|
result = String(realname);
|
||||||
free(realname);
|
free(realname);
|
||||||
}
|
}
|
||||||
|
@ -277,7 +277,7 @@ String Utility::DirName(const String& path)
|
||||||
dir = strdup(path.CStr());
|
dir = strdup(path.CStr());
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
if (dir == NULL)
|
if (!dir)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
String result;
|
String result;
|
||||||
|
@ -315,7 +315,7 @@ String Utility::BaseName(const String& path)
|
||||||
char *dir = strdup(path.CStr());
|
char *dir = strdup(path.CStr());
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
if (dir == NULL)
|
if (!dir)
|
||||||
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
BOOST_THROW_EXCEPTION(std::bad_alloc());
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
|
@ -395,7 +395,7 @@ double Utility::GetTime(void)
|
||||||
#else /* _WIN32 */
|
#else /* _WIN32 */
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
|
|
||||||
int rc = gettimeofday(&tv, NULL);
|
int rc = gettimeofday(&tv, nullptr);
|
||||||
VERIFY(rc >= 0);
|
VERIFY(rc >= 0);
|
||||||
|
|
||||||
return tv.tv_sec + tv.tv_usec / 1000000.0;
|
return tv.tv_sec + tv.tv_usec / 1000000.0;
|
||||||
|
@ -664,7 +664,7 @@ bool Utility::GlobRecursive(const String& path, const String& pattern, const std
|
||||||
|
|
||||||
dirp = opendir(path.CStr());
|
dirp = opendir(path.CStr());
|
||||||
|
|
||||||
if (dirp == NULL)
|
if (!dirp)
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("opendir")
|
<< boost::errinfo_api_function("opendir")
|
||||||
<< boost::errinfo_errno(errno)
|
<< boost::errinfo_errno(errno)
|
||||||
|
@ -1017,7 +1017,7 @@ String Utility::FormatDateTime(const char *format, double ts)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
tm *temp = localtime(&tempts);
|
tm *temp = localtime(&tempts);
|
||||||
|
|
||||||
if (temp == NULL) {
|
if (!temp) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime")
|
<< boost::errinfo_api_function("localtime")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -1025,7 +1025,7 @@ String Utility::FormatDateTime(const char *format, double ts)
|
||||||
|
|
||||||
tmthen = *temp;
|
tmthen = *temp;
|
||||||
#else /* _MSC_VER */
|
#else /* _MSC_VER */
|
||||||
if (localtime_r(&tempts, &tmthen) == NULL) {
|
if (!localtime_r(&tempts, &tmthen)) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime_r")
|
<< boost::errinfo_api_function("localtime_r")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -1045,8 +1045,8 @@ String Utility::FormatErrorNumber(int code) {
|
||||||
String result = "Unknown error.";
|
String result = "Unknown error.";
|
||||||
|
|
||||||
DWORD rc = FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
DWORD rc = FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
||||||
FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, code, 0, (char *)&message,
|
FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, nullptr, code, 0, (char *)&message,
|
||||||
0, NULL);
|
0, nullptr);
|
||||||
|
|
||||||
if (rc != 0) {
|
if (rc != 0) {
|
||||||
result = String(message);
|
result = String(message);
|
||||||
|
@ -1295,10 +1295,10 @@ String Utility::GetFQDN(void)
|
||||||
hints.ai_flags = AI_CANONNAME;
|
hints.ai_flags = AI_CANONNAME;
|
||||||
|
|
||||||
addrinfo *result;
|
addrinfo *result;
|
||||||
int rc = getaddrinfo(hostname.CStr(), NULL, &hints, &result);
|
int rc = getaddrinfo(hostname.CStr(), nullptr, &hints, &result);
|
||||||
|
|
||||||
if (rc != 0)
|
if (rc != 0)
|
||||||
result = NULL;
|
result = nullptr;
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
if (strcmp(result->ai_canonname, "localhost") != 0)
|
if (strcmp(result->ai_canonname, "localhost") != 0)
|
||||||
|
@ -1331,7 +1331,7 @@ tm Utility::LocalTime(time_t ts)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
tm *result = localtime(&ts);
|
tm *result = localtime(&ts);
|
||||||
|
|
||||||
if (result == NULL) {
|
if (!result) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime")
|
<< boost::errinfo_api_function("localtime")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -1341,7 +1341,7 @@ tm Utility::LocalTime(time_t ts)
|
||||||
#else /* _MSC_VER */
|
#else /* _MSC_VER */
|
||||||
tm result;
|
tm result;
|
||||||
|
|
||||||
if (localtime_r(&ts, &result) == NULL) {
|
if (!localtime_r(&ts, &result)) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime_r")
|
<< boost::errinfo_api_function("localtime_r")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -1479,7 +1479,7 @@ static String UnameHelper(char type)
|
||||||
char line[1024];
|
char line[1024];
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
|
|
||||||
while (fgets(line, sizeof(line), fp) != NULL)
|
while (fgets(line, sizeof(line), fp))
|
||||||
msgbuf << line;
|
msgbuf << line;
|
||||||
|
|
||||||
pclose(fp);
|
pclose(fp);
|
||||||
|
@ -1557,10 +1557,10 @@ static bool ReleaseHelper(String *platformName, String *platformVersion)
|
||||||
/* You are using a distribution which supports LSB. */
|
/* You are using a distribution which supports LSB. */
|
||||||
FILE *fp = popen("type lsb_release >/dev/null 2>&1 && lsb_release -s -i 2>&1", "r");
|
FILE *fp = popen("type lsb_release >/dev/null 2>&1 && lsb_release -s -i 2>&1", "r");
|
||||||
|
|
||||||
if (fp != NULL) {
|
if (fp) {
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
char line[1024];
|
char line[1024];
|
||||||
while (fgets(line, sizeof(line), fp) != NULL)
|
while (fgets(line, sizeof(line), fp))
|
||||||
msgbuf << line;
|
msgbuf << line;
|
||||||
int status = pclose(fp);
|
int status = pclose(fp);
|
||||||
if (WEXITSTATUS(status) == 0) {
|
if (WEXITSTATUS(status) == 0) {
|
||||||
|
@ -1571,10 +1571,10 @@ static bool ReleaseHelper(String *platformName, String *platformVersion)
|
||||||
|
|
||||||
fp = popen("type lsb_release >/dev/null 2>&1 && lsb_release -s -r 2>&1", "r");
|
fp = popen("type lsb_release >/dev/null 2>&1 && lsb_release -s -r 2>&1", "r");
|
||||||
|
|
||||||
if (fp != NULL) {
|
if (fp) {
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
char line[1024];
|
char line[1024];
|
||||||
while (fgets(line, sizeof(line), fp) != NULL)
|
while (fgets(line, sizeof(line), fp))
|
||||||
msgbuf << line;
|
msgbuf << line;
|
||||||
int status = pclose(fp);
|
int status = pclose(fp);
|
||||||
if (WEXITSTATUS(status) == 0) {
|
if (WEXITSTATUS(status) == 0) {
|
||||||
|
@ -1586,10 +1586,10 @@ static bool ReleaseHelper(String *platformName, String *platformVersion)
|
||||||
/* OS X */
|
/* OS X */
|
||||||
fp = popen("type sw_vers >/dev/null 2>&1 && sw_vers -productName 2>&1", "r");
|
fp = popen("type sw_vers >/dev/null 2>&1 && sw_vers -productName 2>&1", "r");
|
||||||
|
|
||||||
if (fp != NULL) {
|
if (fp) {
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
char line[1024];
|
char line[1024];
|
||||||
while (fgets(line, sizeof(line), fp) != NULL)
|
while (fgets(line, sizeof(line), fp))
|
||||||
msgbuf << line;
|
msgbuf << line;
|
||||||
int status = pclose(fp);
|
int status = pclose(fp);
|
||||||
if (WEXITSTATUS(status) == 0) {
|
if (WEXITSTATUS(status) == 0) {
|
||||||
|
@ -1603,10 +1603,10 @@ static bool ReleaseHelper(String *platformName, String *platformVersion)
|
||||||
|
|
||||||
fp = popen("type sw_vers >/dev/null 2>&1 && sw_vers -productVersion 2>&1", "r");
|
fp = popen("type sw_vers >/dev/null 2>&1 && sw_vers -productVersion 2>&1", "r");
|
||||||
|
|
||||||
if (fp != NULL) {
|
if (fp) {
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
char line[1024];
|
char line[1024];
|
||||||
while (fgets(line, sizeof(line), fp) != NULL)
|
while (fgets(line, sizeof(line), fp))
|
||||||
msgbuf << line;
|
msgbuf << line;
|
||||||
int status = pclose(fp);
|
int status = pclose(fp);
|
||||||
if (WEXITSTATUS(status) == 0) {
|
if (WEXITSTATUS(status) == 0) {
|
||||||
|
@ -1690,7 +1690,7 @@ String Utility::GetPlatformKernelVersion(void)
|
||||||
String Utility::GetPlatformName(void)
|
String Utility::GetPlatformName(void)
|
||||||
{
|
{
|
||||||
String platformName;
|
String platformName;
|
||||||
if (!ReleaseHelper(&platformName, NULL))
|
if (!ReleaseHelper(&platformName, nullptr))
|
||||||
return "Unknown";
|
return "Unknown";
|
||||||
return platformName;
|
return platformName;
|
||||||
}
|
}
|
||||||
|
@ -1698,7 +1698,7 @@ String Utility::GetPlatformName(void)
|
||||||
String Utility::GetPlatformVersion(void)
|
String Utility::GetPlatformVersion(void)
|
||||||
{
|
{
|
||||||
String platformVersion;
|
String platformVersion;
|
||||||
if (!ReleaseHelper(NULL, &platformVersion))
|
if (!ReleaseHelper(nullptr, &platformVersion))
|
||||||
return "Unknown";
|
return "Unknown";
|
||||||
return platformVersion;
|
return platformVersion;
|
||||||
}
|
}
|
||||||
|
@ -1928,7 +1928,7 @@ String Utility::GetIcingaInstallPath(void)
|
||||||
String Utility::GetIcingaDataPath(void)
|
String Utility::GetIcingaDataPath(void)
|
||||||
{
|
{
|
||||||
char path[MAX_PATH];
|
char path[MAX_PATH];
|
||||||
if (!SUCCEEDED(SHGetFolderPath(NULL, CSIDL_COMMON_APPDATA, NULL, 0, path)))
|
if (!SUCCEEDED(SHGetFolderPath(nullptr, CSIDL_COMMON_APPDATA, nullptr, 0, path)))
|
||||||
return "";
|
return "";
|
||||||
return String(path) + "\\icinga2";
|
return String(path) + "\\icinga2";
|
||||||
}
|
}
|
||||||
|
|
|
@ -259,7 +259,7 @@ public:
|
||||||
if (!IsObject())
|
if (!IsObject())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return (dynamic_cast<T *>(boost::get<Object::Ptr>(m_Value).get()) != NULL);
|
return dynamic_cast<T *>(boost::get<Object::Ptr>(m_Value).get());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -78,9 +78,9 @@ public:
|
||||||
CLICommand::Ptr& command, bool autocomplete);
|
CLICommand::Ptr& command, bool autocomplete);
|
||||||
|
|
||||||
static void ShowCommands(int argc, char **argv,
|
static void ShowCommands(int argc, char **argv,
|
||||||
boost::program_options::options_description *visibleDesc = NULL,
|
boost::program_options::options_description *visibleDesc = nullptr,
|
||||||
boost::program_options::options_description *hiddenDesc = NULL,
|
boost::program_options::options_description *hiddenDesc = nullptr,
|
||||||
ArgumentCompletionCallback globalArgCompletionCallback = NULL,
|
ArgumentCompletionCallback globalArgCompletionCallback = nullptr,
|
||||||
bool autocomplete = false, int autoindex = -1);
|
bool autocomplete = false, int autoindex = -1);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -68,7 +68,7 @@ extern "C" void dbg_inspect_object(Object *obj)
|
||||||
|
|
||||||
extern "C" void dbg_eval(const char *text)
|
extern "C" void dbg_eval(const char *text)
|
||||||
{
|
{
|
||||||
Expression *expr = NULL;
|
Expression *expr = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
ScriptFrame frame;
|
ScriptFrame frame;
|
||||||
|
@ -84,7 +84,7 @@ extern "C" void dbg_eval(const char *text)
|
||||||
|
|
||||||
extern "C" void dbg_eval_with_value(const Value& value, const char *text)
|
extern "C" void dbg_eval_with_value(const Value& value, const char *text)
|
||||||
{
|
{
|
||||||
Expression *expr = NULL;
|
Expression *expr = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
ScriptFrame frame;
|
ScriptFrame frame;
|
||||||
|
@ -102,7 +102,7 @@ extern "C" void dbg_eval_with_value(const Value& value, const char *text)
|
||||||
|
|
||||||
extern "C" void dbg_eval_with_object(Object *object, const char *text)
|
extern "C" void dbg_eval_with_object(Object *object, const char *text)
|
||||||
{
|
{
|
||||||
Expression *expr = NULL;
|
Expression *expr = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
ScriptFrame frame;
|
ScriptFrame frame;
|
||||||
|
@ -214,7 +214,7 @@ char *ConsoleCommand::ConsoleCompleteHelper(const char *word, int state)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (state >= static_cast<int>(matches.size()))
|
if (state >= static_cast<int>(matches.size()))
|
||||||
return NULL;
|
return nullptr;
|
||||||
|
|
||||||
return strdup(matches[state].CStr());
|
return strdup(matches[state].CStr());
|
||||||
}
|
}
|
||||||
|
@ -400,7 +400,7 @@ incomplete:
|
||||||
|
|
||||||
command += line;
|
command += line;
|
||||||
|
|
||||||
Expression *expr = NULL;
|
Expression *expr = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
lines[fileName] = command;
|
lines[fileName] = command;
|
||||||
|
|
|
@ -306,7 +306,7 @@ int DaemonCommand::Run(const po::variables_map& vm, const std::vector<std::strin
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
memset(&sa, 0, sizeof(sa));
|
memset(&sa, 0, sizeof(sa));
|
||||||
sa.sa_handler = &SigHupHandler;
|
sa.sa_handler = &SigHupHandler;
|
||||||
sigaction(SIGHUP, &sa, NULL);
|
sigaction(SIGHUP, &sa, nullptr);
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
ApiListener::UpdateObjectAuthority();
|
ApiListener::UpdateObjectAuthority();
|
||||||
|
|
|
@ -185,7 +185,7 @@ bool TroubleshootCommand::ObjectInfo(InfoLog& log, const boost::program_options:
|
||||||
<< "FAILED: This probably means you have a fault configuration.\n";
|
<< "FAILED: This probably means you have a fault configuration.\n";
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
InfoLog *OFile = NULL;
|
InfoLog *OFile = nullptr;
|
||||||
bool OConsole = false;
|
bool OConsole = false;
|
||||||
if (vm.count("include-objects")) {
|
if (vm.count("include-objects")) {
|
||||||
if (vm.count("console"))
|
if (vm.count("console"))
|
||||||
|
@ -196,7 +196,7 @@ bool TroubleshootCommand::ObjectInfo(InfoLog& log, const boost::program_options:
|
||||||
InfoLogLine(log, 0, LogWarning)
|
InfoLogLine(log, 0, LogWarning)
|
||||||
<< "Failed to open Object-write-stream, not printing objects\n\n";
|
<< "Failed to open Object-write-stream, not printing objects\n\n";
|
||||||
delete OFile;
|
delete OFile;
|
||||||
OFile = NULL;
|
OFile = nullptr;
|
||||||
} else
|
} else
|
||||||
InfoLogLine(log)
|
InfoLogLine(log)
|
||||||
<< "Printing all objects to " << path+"-objects\n";
|
<< "Printing all objects to " << path+"-objects\n";
|
||||||
|
|
|
@ -541,7 +541,7 @@ void CompatLogger::ScheduleNextRotation(void)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
tm *temp = localtime(&now);
|
tm *temp = localtime(&now);
|
||||||
|
|
||||||
if (temp == NULL) {
|
if (!temp) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime")
|
<< boost::errinfo_api_function("localtime")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
@ -549,7 +549,7 @@ void CompatLogger::ScheduleNextRotation(void)
|
||||||
|
|
||||||
tmthen = *temp;
|
tmthen = *temp;
|
||||||
#else /* _MSC_VER */
|
#else /* _MSC_VER */
|
||||||
if (localtime_r(&now, &tmthen) == NULL) {
|
if (!localtime_r(&now, &tmthen)) {
|
||||||
BOOST_THROW_EXCEPTION(posix_error()
|
BOOST_THROW_EXCEPTION(posix_error()
|
||||||
<< boost::errinfo_api_function("localtime_r")
|
<< boost::errinfo_api_function("localtime_r")
|
||||||
<< boost::errinfo_errno(errno));
|
<< boost::errinfo_errno(errno));
|
||||||
|
|
|
@ -385,7 +385,7 @@ void StatusDataWriter::DumpCheckableStatusAttrs(std::ostream& fp, const Checkabl
|
||||||
"\t" "max_attempts=" << checkable->GetMaxCheckAttempts() << "\n"
|
"\t" "max_attempts=" << checkable->GetMaxCheckAttempts() << "\n"
|
||||||
"\t" "last_state_change=" << static_cast<long>(checkable->GetLastStateChange()) << "\n"
|
"\t" "last_state_change=" << static_cast<long>(checkable->GetLastStateChange()) << "\n"
|
||||||
"\t" "last_hard_state_change=" << static_cast<long>(checkable->GetLastHardStateChange()) << "\n"
|
"\t" "last_hard_state_change=" << static_cast<long>(checkable->GetLastHardStateChange()) << "\n"
|
||||||
"\t" "last_update=" << static_cast<long>(time(NULL)) << "\n"
|
"\t" "last_update=" << static_cast<long>(time(nullptr)) << "\n"
|
||||||
"\t" "notifications_enabled=" << CompatUtility::GetCheckableNotificationsEnabled(checkable) << "\n"
|
"\t" "notifications_enabled=" << CompatUtility::GetCheckableNotificationsEnabled(checkable) << "\n"
|
||||||
"\t" "active_checks_enabled=" << CompatUtility::GetCheckableActiveChecksEnabled(checkable) << "\n"
|
"\t" "active_checks_enabled=" << CompatUtility::GetCheckableActiveChecksEnabled(checkable) << "\n"
|
||||||
"\t" "passive_checks_enabled=" << CompatUtility::GetCheckablePassiveChecksEnabled(checkable) << "\n"
|
"\t" "passive_checks_enabled=" << CompatUtility::GetCheckablePassiveChecksEnabled(checkable) << "\n"
|
||||||
|
|
|
@ -32,7 +32,7 @@ ConfigCompilerContext *ConfigCompilerContext::GetInstance(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
ConfigCompilerContext::ConfigCompilerContext(void)
|
ConfigCompilerContext::ConfigCompilerContext(void)
|
||||||
: m_ObjectsFP(NULL)
|
: m_ObjectsFP(nullptr)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void ConfigCompilerContext::OpenObjectsFile(const String& filename)
|
void ConfigCompilerContext::OpenObjectsFile(const String& filename)
|
||||||
|
@ -69,7 +69,7 @@ void ConfigCompilerContext::WriteObject(const Dictionary::Ptr& object)
|
||||||
void ConfigCompilerContext::CancelObjectsFile(void)
|
void ConfigCompilerContext::CancelObjectsFile(void)
|
||||||
{
|
{
|
||||||
delete m_ObjectsFP;
|
delete m_ObjectsFP;
|
||||||
m_ObjectsFP = NULL;
|
m_ObjectsFP = nullptr;
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
_unlink(m_ObjectsTempFile.CStr());
|
_unlink(m_ObjectsTempFile.CStr());
|
||||||
|
@ -81,7 +81,7 @@ void ConfigCompilerContext::CancelObjectsFile(void)
|
||||||
void ConfigCompilerContext::FinishObjectsFile(void)
|
void ConfigCompilerContext::FinishObjectsFile(void)
|
||||||
{
|
{
|
||||||
delete m_ObjectsFP;
|
delete m_ObjectsFP;
|
||||||
m_ObjectsFP = NULL;
|
m_ObjectsFP = nullptr;
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
_unlink(m_ObjectsPath.CStr());
|
_unlink(m_ObjectsPath.CStr());
|
||||||
|
|
|
@ -137,7 +137,7 @@ bool VariableExpression::GetReference(ScriptFrame& frame, bool init_dict, Value
|
||||||
*parent = frame.Locals;
|
*parent = frame.Locals;
|
||||||
|
|
||||||
if (dhint)
|
if (dhint)
|
||||||
*dhint = NULL;
|
*dhint = nullptr;
|
||||||
} else if (frame.Self.IsObject() && frame.Locals != frame.Self.Get<Object::Ptr>() && frame.Self.Get<Object::Ptr>()->HasOwnField(m_Variable)) {
|
} else if (frame.Self.IsObject() && frame.Locals != frame.Self.Get<Object::Ptr>() && frame.Self.Get<Object::Ptr>()->HasOwnField(m_Variable)) {
|
||||||
*parent = frame.Self;
|
*parent = frame.Self;
|
||||||
|
|
||||||
|
@ -149,7 +149,7 @@ bool VariableExpression::GetReference(ScriptFrame& frame, bool init_dict, Value
|
||||||
*parent = ScriptGlobal::GetGlobals();
|
*parent = ScriptGlobal::GetGlobals();
|
||||||
|
|
||||||
if (dhint)
|
if (dhint)
|
||||||
*dhint = NULL;
|
*dhint = nullptr;
|
||||||
} else
|
} else
|
||||||
*parent = frame.Self;
|
*parent = frame.Self;
|
||||||
|
|
||||||
|
@ -487,7 +487,7 @@ ExpressionResult DictExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhint
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (Expression *aexpr : m_Expressions) {
|
for (Expression *aexpr : m_Expressions) {
|
||||||
ExpressionResult element = aexpr->Evaluate(frame, m_Inline ? dhint : NULL);
|
ExpressionResult element = aexpr->Evaluate(frame, m_Inline ? dhint : nullptr);
|
||||||
CHECK_RESULT(element);
|
CHECK_RESULT(element);
|
||||||
result = element.GetValue();
|
result = element.GetValue();
|
||||||
}
|
}
|
||||||
|
@ -643,7 +643,7 @@ bool IndexerExpression::GetReference(ScriptFrame& frame, bool init_dict, Value *
|
||||||
{
|
{
|
||||||
Value vparent;
|
Value vparent;
|
||||||
String vindex;
|
String vindex;
|
||||||
DebugHint *psdhint = NULL;
|
DebugHint *psdhint = nullptr;
|
||||||
bool free_psd = false;
|
bool free_psd = false;
|
||||||
|
|
||||||
if (dhint)
|
if (dhint)
|
||||||
|
@ -674,7 +674,7 @@ bool IndexerExpression::GetReference(ScriptFrame& frame, bool init_dict, Value *
|
||||||
if (psdhint)
|
if (psdhint)
|
||||||
*dhint = new DebugHint(psdhint->GetChild(*index));
|
*dhint = new DebugHint(psdhint->GetChild(*index));
|
||||||
else
|
else
|
||||||
*dhint = NULL;
|
*dhint = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (free_psd)
|
if (free_psd)
|
||||||
|
@ -921,7 +921,7 @@ ExpressionResult IncludeExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dh
|
||||||
|
|
||||||
ExpressionResult BreakpointExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const
|
ExpressionResult BreakpointExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const
|
||||||
{
|
{
|
||||||
ScriptBreakpoint(frame, NULL, GetDebugInfo());
|
ScriptBreakpoint(frame, nullptr, GetDebugInfo());
|
||||||
|
|
||||||
return Empty;
|
return Empty;
|
||||||
}
|
}
|
||||||
|
|
|
@ -200,8 +200,8 @@ class I2_CONFIG_API Expression
|
||||||
public:
|
public:
|
||||||
virtual ~Expression(void);
|
virtual ~Expression(void);
|
||||||
|
|
||||||
ExpressionResult Evaluate(ScriptFrame& frame, DebugHint *dhint = NULL) const;
|
ExpressionResult Evaluate(ScriptFrame& frame, DebugHint *dhint = nullptr) const;
|
||||||
virtual bool GetReference(ScriptFrame& frame, bool init_dict, Value *parent, String *index, DebugHint **dhint = NULL) const;
|
virtual bool GetReference(ScriptFrame& frame, bool init_dict, Value *parent, String *index, DebugHint **dhint = nullptr) const;
|
||||||
virtual const DebugInfo& GetDebugInfo(void) const;
|
virtual const DebugInfo& GetDebugInfo(void) const;
|
||||||
|
|
||||||
virtual ExpressionResult DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const = 0;
|
virtual ExpressionResult DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const = 0;
|
||||||
|
|
|
@ -52,10 +52,10 @@ void IdoCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const CheckResult
|
||||||
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
||||||
|
|
||||||
String idoType = MacroProcessor::ResolveMacros("$ido_type$", resolvers, checkable->GetLastCheckResult(),
|
String idoType = MacroProcessor::ResolveMacros("$ido_type$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
String idoName = MacroProcessor::ResolveMacros("$ido_name$", resolvers, checkable->GetLastCheckResult(),
|
String idoName = MacroProcessor::ResolveMacros("$ido_name$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
if (resolvedMacros && !useResolvedMacros)
|
if (resolvedMacros && !useResolvedMacros)
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -235,18 +235,18 @@ void IdoMysqlConnection::Reconnect(void)
|
||||||
isslCaPath = GetSslCapath();
|
isslCaPath = GetSslCapath();
|
||||||
isslCipher = GetSslCipher();
|
isslCipher = GetSslCipher();
|
||||||
|
|
||||||
host = (!ihost.IsEmpty()) ? ihost.CStr() : NULL;
|
host = (!ihost.IsEmpty()) ? ihost.CStr() : nullptr;
|
||||||
port = GetPort();
|
port = GetPort();
|
||||||
socket_path = (!isocket_path.IsEmpty()) ? isocket_path.CStr() : NULL;
|
socket_path = (!isocket_path.IsEmpty()) ? isocket_path.CStr() : nullptr;
|
||||||
user = (!iuser.IsEmpty()) ? iuser.CStr() : NULL;
|
user = (!iuser.IsEmpty()) ? iuser.CStr() : nullptr;
|
||||||
passwd = (!ipasswd.IsEmpty()) ? ipasswd.CStr() : NULL;
|
passwd = (!ipasswd.IsEmpty()) ? ipasswd.CStr() : nullptr;
|
||||||
db = (!idb.IsEmpty()) ? idb.CStr() : NULL;
|
db = (!idb.IsEmpty()) ? idb.CStr() : nullptr;
|
||||||
|
|
||||||
sslKey = (!isslKey.IsEmpty()) ? isslKey.CStr() : NULL;
|
sslKey = (!isslKey.IsEmpty()) ? isslKey.CStr() : nullptr;
|
||||||
sslCert = (!isslCert.IsEmpty()) ? isslCert.CStr() : NULL;
|
sslCert = (!isslCert.IsEmpty()) ? isslCert.CStr() : nullptr;
|
||||||
sslCa = (!isslCa.IsEmpty()) ? isslCa.CStr() : NULL;
|
sslCa = (!isslCa.IsEmpty()) ? isslCa.CStr() : nullptr;
|
||||||
sslCaPath = (!isslCaPath.IsEmpty()) ? isslCaPath.CStr() : NULL;
|
sslCaPath = (!isslCaPath.IsEmpty()) ? isslCaPath.CStr() : nullptr;
|
||||||
sslCipher = (!isslCipher.IsEmpty()) ? isslCipher.CStr() : NULL;
|
sslCipher = (!isslCipher.IsEmpty()) ? isslCipher.CStr() : nullptr;
|
||||||
|
|
||||||
/* connection */
|
/* connection */
|
||||||
if (!mysql_init(&m_Connection)) {
|
if (!mysql_init(&m_Connection)) {
|
||||||
|
|
|
@ -210,13 +210,13 @@ void IdoPgsqlConnection::Reconnect(void)
|
||||||
ipasswd = GetPassword();
|
ipasswd = GetPassword();
|
||||||
idb = GetDatabase();
|
idb = GetDatabase();
|
||||||
|
|
||||||
host = (!ihost.IsEmpty()) ? ihost.CStr() : NULL;
|
host = (!ihost.IsEmpty()) ? ihost.CStr() : nullptr;
|
||||||
port = (!iport.IsEmpty()) ? iport.CStr() : NULL;
|
port = (!iport.IsEmpty()) ? iport.CStr() : nullptr;
|
||||||
user = (!iuser.IsEmpty()) ? iuser.CStr() : NULL;
|
user = (!iuser.IsEmpty()) ? iuser.CStr() : nullptr;
|
||||||
passwd = (!ipasswd.IsEmpty()) ? ipasswd.CStr() : NULL;
|
passwd = (!ipasswd.IsEmpty()) ? ipasswd.CStr() : nullptr;
|
||||||
db = (!idb.IsEmpty()) ? idb.CStr() : NULL;
|
db = (!idb.IsEmpty()) ? idb.CStr() : nullptr;
|
||||||
|
|
||||||
m_Connection = PQsetdbLogin(host, port, NULL, NULL, db, user, passwd);
|
m_Connection = PQsetdbLogin(host, port, nullptr, nullptr, db, user, passwd);
|
||||||
|
|
||||||
if (!m_Connection)
|
if (!m_Connection)
|
||||||
return;
|
return;
|
||||||
|
@ -508,7 +508,7 @@ String IdoPgsqlConnection::Escape(const String& s)
|
||||||
size_t length = utf8s.GetLength();
|
size_t length = utf8s.GetLength();
|
||||||
char *to = new char[utf8s.GetLength() * 2 + 1];
|
char *to = new char[utf8s.GetLength() * 2 + 1];
|
||||||
|
|
||||||
PQescapeStringConn(m_Connection, to, utf8s.CStr(), length, NULL);
|
PQescapeStringConn(m_Connection, to, utf8s.CStr(), length, nullptr);
|
||||||
|
|
||||||
String result = String(to);
|
String result = String(to);
|
||||||
|
|
||||||
|
|
|
@ -67,7 +67,7 @@ void Checkable::UpdateNextCheck(const MessageOrigin::Ptr& origin)
|
||||||
{
|
{
|
||||||
double interval;
|
double interval;
|
||||||
|
|
||||||
if (GetStateType() == StateTypeSoft && GetLastCheckResult() != NULL)
|
if (GetStateType() == StateTypeSoft && GetLastCheckResult() != nullptr)
|
||||||
interval = GetRetryInterval();
|
interval = GetRetryInterval();
|
||||||
else
|
else
|
||||||
interval = GetCheckInterval();
|
interval = GetCheckInterval();
|
||||||
|
@ -85,7 +85,7 @@ void Checkable::UpdateNextCheck(const MessageOrigin::Ptr& origin)
|
||||||
|
|
||||||
bool Checkable::HasBeenChecked(void) const
|
bool Checkable::HasBeenChecked(void) const
|
||||||
{
|
{
|
||||||
return GetLastCheckResult() != NULL;
|
return GetLastCheckResult() != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
double Checkable::GetLastCheck(void) const
|
double Checkable::GetLastCheck(void) const
|
||||||
|
@ -445,7 +445,7 @@ void Checkable::ExecuteCheck(void)
|
||||||
bool local = !endpoint || endpoint == Endpoint::GetLocalEndpoint();
|
bool local = !endpoint || endpoint == Endpoint::GetLocalEndpoint();
|
||||||
|
|
||||||
if (local) {
|
if (local) {
|
||||||
GetCheckCommand()->Execute(this, cr, NULL, false);
|
GetCheckCommand()->Execute(this, cr, nullptr, false);
|
||||||
} else {
|
} else {
|
||||||
Dictionary::Ptr macros = new Dictionary();
|
Dictionary::Ptr macros = new Dictionary();
|
||||||
GetCheckCommand()->Execute(this, cr, macros, false);
|
GetCheckCommand()->Execute(this, cr, macros, false);
|
||||||
|
|
|
@ -94,7 +94,7 @@ public:
|
||||||
|
|
||||||
void AddGroup(const String& name);
|
void AddGroup(const String& name);
|
||||||
|
|
||||||
bool IsReachable(DependencyType dt = DependencyState, intrusive_ptr<Dependency> *failedDependency = NULL, int rstack = 0) const;
|
bool IsReachable(DependencyType dt = DependencyState, intrusive_ptr<Dependency> *failedDependency = nullptr, int rstack = 0) const;
|
||||||
|
|
||||||
AcknowledgementType GetAcknowledgement(void);
|
AcknowledgementType GetAcknowledgement(void);
|
||||||
|
|
||||||
|
|
|
@ -292,7 +292,7 @@ void LegacyTimePeriod::ParseTimeRange(const String& timerange, tm *begin, tm *en
|
||||||
|
|
||||||
String second = def.SubStr(pos + 1).Trim();
|
String second = def.SubStr(pos + 1).Trim();
|
||||||
|
|
||||||
ParseTimeSpec(first, begin, NULL, reference);
|
ParseTimeSpec(first, begin, nullptr, reference);
|
||||||
|
|
||||||
/* If the second definition starts with a number we need
|
/* If the second definition starts with a number we need
|
||||||
* to add the first word from the first definition, e.g.:
|
* to add the first word from the first definition, e.g.:
|
||||||
|
@ -313,7 +313,7 @@ void LegacyTimePeriod::ParseTimeRange(const String& timerange, tm *begin, tm *en
|
||||||
second = first.SubStr(0, xpos + 1) + second;
|
second = first.SubStr(0, xpos + 1) + second;
|
||||||
}
|
}
|
||||||
|
|
||||||
ParseTimeSpec(second, NULL, end, reference);
|
ParseTimeSpec(second, nullptr, end, reference);
|
||||||
} else {
|
} else {
|
||||||
ParseTimeSpec(def, begin, end, reference);
|
ParseTimeSpec(def, begin, end, reference);
|
||||||
}
|
}
|
||||||
|
|
|
@ -454,7 +454,7 @@ Value MacroProcessor::ResolveArguments(const Value& command, const Dictionary::P
|
||||||
{
|
{
|
||||||
Value resolvedCommand;
|
Value resolvedCommand;
|
||||||
if (!arguments || command.IsObjectType<Array>() || command.IsObjectType<Function>())
|
if (!arguments || command.IsObjectType<Array>() || command.IsObjectType<Function>())
|
||||||
resolvedCommand = MacroProcessor::ResolveMacros(command, resolvers, cr, NULL,
|
resolvedCommand = MacroProcessor::ResolveMacros(command, resolvers, cr, nullptr,
|
||||||
EscapeMacroShellArg, resolvedMacros, useResolvedMacros, recursionLevel + 1);
|
EscapeMacroShellArg, resolvedMacros, useResolvedMacros, recursionLevel + 1);
|
||||||
else {
|
else {
|
||||||
Array::Ptr arr = new Array();
|
Array::Ptr arr = new Array();
|
||||||
|
|
|
@ -41,7 +41,7 @@ public:
|
||||||
typedef std::vector<ResolverSpec> ResolverList;
|
typedef std::vector<ResolverSpec> ResolverList;
|
||||||
|
|
||||||
static Value ResolveMacros(const Value& str, const ResolverList& resolvers,
|
static Value ResolveMacros(const Value& str, const ResolverList& resolvers,
|
||||||
const CheckResult::Ptr& cr = nullptr, String *missingMacro = NULL,
|
const CheckResult::Ptr& cr = nullptr, String *missingMacro = nullptr,
|
||||||
const EscapeCallback& escapeFn = EscapeCallback(),
|
const EscapeCallback& escapeFn = EscapeCallback(),
|
||||||
const Dictionary::Ptr& resolvedMacros = nullptr,
|
const Dictionary::Ptr& resolvedMacros = nullptr,
|
||||||
bool useResolvedMacros = false, int recursionLevel = 0);
|
bool useResolvedMacros = false, int recursionLevel = 0);
|
||||||
|
|
|
@ -73,7 +73,7 @@ void PluginUtility::ExecuteCommand(const Command::Ptr& commandObj, const Checkab
|
||||||
String name = kv.second;
|
String name = kv.second;
|
||||||
|
|
||||||
Value value = MacroProcessor::ResolveMacros(name, macroResolvers, cr,
|
Value value = MacroProcessor::ResolveMacros(name, macroResolvers, cr,
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros,
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros,
|
||||||
useResolvedMacros);
|
useResolvedMacros);
|
||||||
|
|
||||||
if (value.IsObjectType<Array>())
|
if (value.IsObjectType<Array>())
|
||||||
|
|
|
@ -526,7 +526,7 @@ void LivestatusQuery::ExecuteGetHelper(const Stream::Ptr& stream)
|
||||||
auto it = allStats.find(statsKey);
|
auto it = allStats.find(statsKey);
|
||||||
|
|
||||||
if (it == allStats.end()) {
|
if (it == allStats.end()) {
|
||||||
std::vector<AggregatorState *> newStats(m_Aggregators.size(), NULL);
|
std::vector<AggregatorState *> newStats(m_Aggregators.size(), nullptr);
|
||||||
it = allStats.insert(std::make_pair(statsKey, newStats)).first;
|
it = allStats.insert(std::make_pair(statsKey, newStats)).first;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -51,7 +51,7 @@ static void InitializeClr(void)
|
||||||
{
|
{
|
||||||
ICorRuntimeHost *runtimeHost;
|
ICorRuntimeHost *runtimeHost;
|
||||||
|
|
||||||
if (FAILED(CorBindToRuntimeEx(NULL, NULL,
|
if (FAILED(CorBindToRuntimeEx(nullptr, nullptr,
|
||||||
STARTUP_LOADER_OPTIMIZATION_SINGLE_DOMAIN | STARTUP_CONCURRENT_GC,
|
STARTUP_LOADER_OPTIMIZATION_SINGLE_DOMAIN | STARTUP_CONCURRENT_GC,
|
||||||
CLSID_CorRuntimeHost, IID_ICorRuntimeHost, (void **)&runtimeHost))) {
|
CLSID_CorRuntimeHost, IID_ICorRuntimeHost, (void **)&runtimeHost))) {
|
||||||
return;
|
return;
|
||||||
|
@ -59,7 +59,7 @@ static void InitializeClr(void)
|
||||||
|
|
||||||
runtimeHost->Start();
|
runtimeHost->Start();
|
||||||
|
|
||||||
IUnknownPtr punkAppDomain = NULL;
|
IUnknownPtr punkAppDomain = nullptr;
|
||||||
runtimeHost->GetDefaultDomain(&punkAppDomain);
|
runtimeHost->GetDefaultDomain(&punkAppDomain);
|
||||||
|
|
||||||
punkAppDomain->QueryInterface(__uuidof(mscorlib::_AppDomain), (void **)&l_AppDomain);
|
punkAppDomain->QueryInterface(__uuidof(mscorlib::_AppDomain), (void **)&l_AppDomain);
|
||||||
|
@ -87,7 +87,7 @@ static variant_t InvokeClrMethod(const variant_t& vtObject, const String& method
|
||||||
HRESULT hr = CLSIDFromProgID(L"System.Collections.Hashtable", &clsid);
|
HRESULT hr = CLSIDFromProgID(L"System.Collections.Hashtable", &clsid);
|
||||||
|
|
||||||
mscorlib::IDictionaryPtr pHashtable;
|
mscorlib::IDictionaryPtr pHashtable;
|
||||||
CoCreateInstance(clsid, NULL, CLSCTX_ALL, __uuidof(mscorlib::IDictionary), (void **)&pHashtable);
|
CoCreateInstance(clsid, nullptr, CLSCTX_ALL, __uuidof(mscorlib::IDictionary), (void **)&pHashtable);
|
||||||
|
|
||||||
ObjectLock olock(args);
|
ObjectLock olock(args);
|
||||||
for (const Dictionary::Pair& kv : args) {
|
for (const Dictionary::Pair& kv : args) {
|
||||||
|
@ -107,7 +107,7 @@ static variant_t InvokeClrMethod(const variant_t& vtObject, const String& method
|
||||||
|
|
||||||
variant_t result = pType->InvokeMember_3(methodName.CStr(),
|
variant_t result = pType->InvokeMember_3(methodName.CStr(),
|
||||||
mscorlib::BindingFlags_InvokeMethod,
|
mscorlib::BindingFlags_InvokeMethod,
|
||||||
NULL,
|
nullptr,
|
||||||
vtObject,
|
vtObject,
|
||||||
psa);
|
psa);
|
||||||
|
|
||||||
|
@ -125,19 +125,19 @@ static void FillCheckResult(const CheckResult::Ptr& cr, variant_t vtResult)
|
||||||
SAFEARRAY *psa = SafeArrayCreateVector(VT_VARIANT, 0, 0);
|
SAFEARRAY *psa = SafeArrayCreateVector(VT_VARIANT, 0, 0);
|
||||||
int lState = pType->InvokeMember_3("State",
|
int lState = pType->InvokeMember_3("State",
|
||||||
mscorlib::BindingFlags_GetField,
|
mscorlib::BindingFlags_GetField,
|
||||||
NULL,
|
nullptr,
|
||||||
vtResult,
|
vtResult,
|
||||||
psa);
|
psa);
|
||||||
cr->SetState(static_cast<ServiceState>(lState));
|
cr->SetState(static_cast<ServiceState>(lState));
|
||||||
bstr_t sOutput = pType->InvokeMember_3("Output",
|
bstr_t sOutput = pType->InvokeMember_3("Output",
|
||||||
mscorlib::BindingFlags_GetField,
|
mscorlib::BindingFlags_GetField,
|
||||||
NULL,
|
nullptr,
|
||||||
vtResult,
|
vtResult,
|
||||||
psa);
|
psa);
|
||||||
cr->SetOutput(static_cast<const char *>(sOutput));
|
cr->SetOutput(static_cast<const char *>(sOutput));
|
||||||
bstr_t sPerformanceData = pType->InvokeMember_3("PerformanceData",
|
bstr_t sPerformanceData = pType->InvokeMember_3("PerformanceData",
|
||||||
mscorlib::BindingFlags_GetField,
|
mscorlib::BindingFlags_GetField,
|
||||||
NULL,
|
nullptr,
|
||||||
vtResult,
|
vtResult,
|
||||||
psa);
|
psa);
|
||||||
SafeArrayDestroy(psa);
|
SafeArrayDestroy(psa);
|
||||||
|
@ -171,7 +171,7 @@ void ClrCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const CheckResult
|
||||||
String name = kv.second;
|
String name = kv.second;
|
||||||
|
|
||||||
Value value = MacroProcessor::ResolveMacros(name, resolvers, checkable->GetLastCheckResult(),
|
Value value = MacroProcessor::ResolveMacros(name, resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
envMacros->Set(kv.first, value);
|
envMacros->Set(kv.first, value);
|
||||||
}
|
}
|
||||||
|
@ -188,9 +188,9 @@ void ClrCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const CheckResult
|
||||||
vtObject = it->second;
|
vtObject = it->second;
|
||||||
} else {
|
} else {
|
||||||
String clr_assembly = MacroProcessor::ResolveMacros("$clr_assembly$", resolvers, checkable->GetLastCheckResult(),
|
String clr_assembly = MacroProcessor::ResolveMacros("$clr_assembly$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
String clr_type = MacroProcessor::ResolveMacros("$clr_type$", resolvers, checkable->GetLastCheckResult(),
|
String clr_type = MacroProcessor::ResolveMacros("$clr_type$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
if (resolvedMacros && !useResolvedMacros)
|
if (resolvedMacros && !useResolvedMacros)
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -58,7 +58,7 @@ void ClusterZoneCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const Che
|
||||||
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
||||||
|
|
||||||
String zoneName = MacroProcessor::ResolveMacros("$cluster_zone$", resolvers, checkable->GetLastCheckResult(),
|
String zoneName = MacroProcessor::ResolveMacros("$cluster_zone$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
String missingLagWarning;
|
String missingLagWarning;
|
||||||
String missingLagCritical;
|
String missingLagCritical;
|
||||||
|
|
|
@ -50,10 +50,10 @@ void DummyCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const CheckResu
|
||||||
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
||||||
|
|
||||||
int dummyState = MacroProcessor::ResolveMacros("$dummy_state$", resolvers, checkable->GetLastCheckResult(),
|
int dummyState = MacroProcessor::ResolveMacros("$dummy_state$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
String dummyText = MacroProcessor::ResolveMacros("$dummy_text$", resolvers, checkable->GetLastCheckResult(),
|
String dummyText = MacroProcessor::ResolveMacros("$dummy_text$", resolvers, checkable->GetLastCheckResult(),
|
||||||
NULL, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
|
||||||
|
|
||||||
if (resolvedMacros && !useResolvedMacros)
|
if (resolvedMacros && !useResolvedMacros)
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -206,9 +206,9 @@ void GraphiteWriter::CheckResultHandlerInternal(const Checkable::Ptr& checkable,
|
||||||
String prefix;
|
String prefix;
|
||||||
|
|
||||||
if (service) {
|
if (service) {
|
||||||
prefix = MacroProcessor::ResolveMacros(GetServiceNameTemplate(), resolvers, cr, NULL, std::bind(&GraphiteWriter::EscapeMacroMetric, _1));
|
prefix = MacroProcessor::ResolveMacros(GetServiceNameTemplate(), resolvers, cr, nullptr, std::bind(&GraphiteWriter::EscapeMacroMetric, _1));
|
||||||
} else {
|
} else {
|
||||||
prefix = MacroProcessor::ResolveMacros(GetHostNameTemplate(), resolvers, cr, NULL, std::bind(&GraphiteWriter::EscapeMacroMetric, _1));
|
prefix = MacroProcessor::ResolveMacros(GetHostNameTemplate(), resolvers, cr, nullptr, std::bind(&GraphiteWriter::EscapeMacroMetric, _1));
|
||||||
}
|
}
|
||||||
|
|
||||||
String prefixPerfdata = prefix + ".perfdata";
|
String prefixPerfdata = prefix + ".perfdata";
|
||||||
|
|
|
@ -105,7 +105,7 @@ void PerfdataWriter::CheckResultHandler(const Checkable::Ptr& checkable, const C
|
||||||
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
|
||||||
|
|
||||||
if (service) {
|
if (service) {
|
||||||
String line = MacroProcessor::ResolveMacros(GetServiceFormatTemplate(), resolvers, cr, NULL, &PerfdataWriter::EscapeMacroMetric);
|
String line = MacroProcessor::ResolveMacros(GetServiceFormatTemplate(), resolvers, cr, nullptr, &PerfdataWriter::EscapeMacroMetric);
|
||||||
|
|
||||||
{
|
{
|
||||||
ObjectLock olock(this);
|
ObjectLock olock(this);
|
||||||
|
@ -115,7 +115,7 @@ void PerfdataWriter::CheckResultHandler(const Checkable::Ptr& checkable, const C
|
||||||
m_ServiceOutputFile << line << "\n";
|
m_ServiceOutputFile << line << "\n";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
String line = MacroProcessor::ResolveMacros(GetHostFormatTemplate(), resolvers, cr, NULL, &PerfdataWriter::EscapeMacroMetric);
|
String line = MacroProcessor::ResolveMacros(GetHostFormatTemplate(), resolvers, cr, nullptr, &PerfdataWriter::EscapeMacroMetric);
|
||||||
|
|
||||||
{
|
{
|
||||||
ObjectLock olock(this);
|
ObjectLock olock(this);
|
||||||
|
|
|
@ -132,7 +132,7 @@ bool ConfigObjectUtility::CreateObject(const Type::Ptr& type, const String& full
|
||||||
ScriptFrame frame;
|
ScriptFrame frame;
|
||||||
expr->Evaluate(frame);
|
expr->Evaluate(frame);
|
||||||
delete expr;
|
delete expr;
|
||||||
expr = NULL;
|
expr = nullptr;
|
||||||
|
|
||||||
WorkQueue upq;
|
WorkQueue upq;
|
||||||
std::vector<ConfigItem::Ptr> newItems;
|
std::vector<ConfigItem::Ptr> newItems;
|
||||||
|
|
|
@ -123,7 +123,7 @@ bool ConsoleHandler::ExecuteScriptHelper(HttpRequest& request, HttpResponse& res
|
||||||
|
|
||||||
Array::Ptr results = new Array();
|
Array::Ptr results = new Array();
|
||||||
Dictionary::Ptr resultInfo = new Dictionary();
|
Dictionary::Ptr resultInfo = new Dictionary();
|
||||||
Expression *expr = NULL;
|
Expression *expr = nullptr;
|
||||||
Value exprResult;
|
Value exprResult;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
EventQueue::EventQueue(const String& name)
|
EventQueue::EventQueue(const String& name)
|
||||||
: m_Name(name), m_Filter(NULL)
|
: m_Name(name), m_Filter(nullptr)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
EventQueue::~EventQueue(void)
|
EventQueue::~EventQueue(void)
|
||||||
|
|
|
@ -66,7 +66,7 @@ bool EventsHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request
|
||||||
|
|
||||||
String filter = HttpUtility::GetLastParameter(params, "filter");
|
String filter = HttpUtility::GetLastParameter(params, "filter");
|
||||||
|
|
||||||
Expression *ufilter = NULL;
|
Expression *ufilter = nullptr;
|
||||||
|
|
||||||
if (!filter.IsEmpty())
|
if (!filter.IsEmpty())
|
||||||
ufilter = ConfigCompiler::CompileText("<API query>", filter);
|
ufilter = ConfigCompiler::CompileText("<API query>", filter);
|
||||||
|
|
|
@ -133,7 +133,7 @@ static void FilteredAddTarget(ScriptFrame& permissionFrame, Expression *permissi
|
||||||
void FilterUtility::CheckPermission(const ApiUser::Ptr& user, const String& permission, Expression **permissionFilter)
|
void FilterUtility::CheckPermission(const ApiUser::Ptr& user, const String& permission, Expression **permissionFilter)
|
||||||
{
|
{
|
||||||
if (permissionFilter)
|
if (permissionFilter)
|
||||||
*permissionFilter = NULL;
|
*permissionFilter = nullptr;
|
||||||
|
|
||||||
if (permission.IsEmpty())
|
if (permission.IsEmpty())
|
||||||
return;
|
return;
|
||||||
|
@ -250,7 +250,7 @@ std::vector<Value> FilterUtility::GetFilterTargets(const QueryDescription& qd, c
|
||||||
frame.Sandboxed = true;
|
frame.Sandboxed = true;
|
||||||
Dictionary::Ptr uvars = new Dictionary();
|
Dictionary::Ptr uvars = new Dictionary();
|
||||||
|
|
||||||
Expression *ufilter = NULL;
|
Expression *ufilter = nullptr;
|
||||||
|
|
||||||
if (query->Contains("filter")) {
|
if (query->Contains("filter")) {
|
||||||
String filter = HttpUtility::GetLastParameter(query, "filter");
|
String filter = HttpUtility::GetLastParameter(query, "filter");
|
||||||
|
|
|
@ -68,7 +68,7 @@ class I2_REMOTE_API FilterUtility
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static Type::Ptr TypeFromPluralName(const String& pluralName);
|
static Type::Ptr TypeFromPluralName(const String& pluralName);
|
||||||
static void CheckPermission(const ApiUser::Ptr& user, const String& permission, Expression **filter = NULL);
|
static void CheckPermission(const ApiUser::Ptr& user, const String& permission, Expression **filter = nullptr);
|
||||||
static std::vector<Value> GetFilterTargets(const QueryDescription& qd, const Dictionary::Ptr& query,
|
static std::vector<Value> GetFilterTargets(const QueryDescription& qd, const Dictionary::Ptr& query,
|
||||||
const ApiUser::Ptr& user, const String& variableName = String());
|
const ApiUser::Ptr& user, const String& variableName = String());
|
||||||
static bool EvaluateFilter(ScriptFrame& frame, Expression *filter,
|
static bool EvaluateFilter(ScriptFrame& frame, Expression *filter,
|
||||||
|
|
|
@ -226,7 +226,7 @@ void HttpRequest::Finish(void)
|
||||||
if (m_State == HttpRequestStart || m_State == HttpRequestHeaders)
|
if (m_State == HttpRequestStart || m_State == HttpRequestHeaders)
|
||||||
FinishHeaders();
|
FinishHeaders();
|
||||||
|
|
||||||
WriteBody(NULL, 0);
|
WriteBody(nullptr, 0);
|
||||||
m_Stream->Write("\r\n", 2);
|
m_Stream->Write("\r\n", 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -108,7 +108,7 @@ void HttpResponse::Finish(void)
|
||||||
m_Stream->Write(buffer, rc);
|
m_Stream->Write(buffer, rc);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
WriteBody(NULL, 0);
|
WriteBody(nullptr, 0);
|
||||||
m_Stream->Write("\r\n", 2);
|
m_Stream->Write("\r\n", 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -71,7 +71,7 @@ int PkiUtility::SignCsr(const String& csrfile, const String& certfile)
|
||||||
InitializeOpenSSL();
|
InitializeOpenSSL();
|
||||||
|
|
||||||
BIO *csrbio = BIO_new_file(csrfile.CStr(), "r");
|
BIO *csrbio = BIO_new_file(csrfile.CStr(), "r");
|
||||||
X509_REQ *req = PEM_read_bio_X509_REQ(csrbio, NULL, NULL, NULL);
|
X509_REQ *req = PEM_read_bio_X509_REQ(csrbio, nullptr, nullptr, nullptr);
|
||||||
|
|
||||||
if (!req) {
|
if (!req) {
|
||||||
Log(LogCritical, "SSL")
|
Log(LogCritical, "SSL")
|
||||||
|
@ -396,7 +396,7 @@ static void CollectRequestHandler(const Dictionary::Ptr& requests, const String&
|
||||||
/* XXX (requires OpenSSL >= 1.0.0)
|
/* XXX (requires OpenSSL >= 1.0.0)
|
||||||
time_t now;
|
time_t now;
|
||||||
time(&now);
|
time(&now);
|
||||||
ASN1_TIME *tm = ASN1_TIME_adj(NULL, now, 0, 0);
|
ASN1_TIME *tm = ASN1_TIME_adj(nullptr, now, 0, 0);
|
||||||
|
|
||||||
int day, sec;
|
int day, sec;
|
||||||
ASN1_TIME_diff(&day, &sec, tm, X509_get_notBefore(certRequest.get()));
|
ASN1_TIME_diff(&day, &sec, tm, X509_get_notBefore(certRequest.get()));
|
||||||
|
|
|
@ -226,7 +226,7 @@ void ClassCompiler::HandleClass(const Klass& klass, const ClassDebugInfo&)
|
||||||
<< "{" << std::endl
|
<< "{" << std::endl
|
||||||
<< "\t" << "static ObjectFactory GetFactory(void)" << std::endl
|
<< "\t" << "static ObjectFactory GetFactory(void)" << std::endl
|
||||||
<< "\t" << "{" << std::endl
|
<< "\t" << "{" << std::endl
|
||||||
<< "\t\t" << "return NULL;" << std::endl
|
<< "\t\t" << "return nullptr;" << std::endl
|
||||||
<< "\t" << "}" << std::endl
|
<< "\t" << "}" << std::endl
|
||||||
<< "};" << std::endl << std::endl;
|
<< "};" << std::endl << std::endl;
|
||||||
}
|
}
|
||||||
|
@ -374,7 +374,7 @@ void ClassCompiler::HandleClass(const Klass& klass, const ClassDebugInfo&)
|
||||||
if (field.Type.IsName)
|
if (field.Type.IsName)
|
||||||
nameref = "\"" + field.Type.TypeName + "\"";
|
nameref = "\"" + field.Type.TypeName + "\"";
|
||||||
else
|
else
|
||||||
nameref = "NULL";
|
nameref = "nullptr";
|
||||||
|
|
||||||
m_Impl << "\t\t" << "case " << num << ":" << std::endl
|
m_Impl << "\t\t" << "case " << num << ":" << std::endl
|
||||||
<< "\t\t\t" << "return Field(" << num << ", \"" << ftype << "\", \"" << field.Name << "\", \"" << (field.NavigationName.empty() ? field.Name : field.NavigationName) << "\", " << nameref << ", " << field.Attributes << ", " << field.Type.ArrayRank << ");" << std::endl;
|
<< "\t\t\t" << "return Field(" << num << ", \"" << ftype << "\", \"" << field.Name << "\", \"" << (field.NavigationName.empty() ? field.Name : field.NavigationName) << "\", " << nameref << ", " << field.Attributes << ", " << field.Type.ArrayRank << ");" << std::endl;
|
||||||
|
@ -1411,7 +1411,7 @@ std::string ClassCompiler::BaseName(const std::string& path)
|
||||||
char *dir = strdup(path.c_str());
|
char *dir = strdup(path.c_str());
|
||||||
std::string result;
|
std::string result;
|
||||||
|
|
||||||
if (dir == NULL)
|
if (!dir)
|
||||||
throw std::bad_alloc();
|
throw std::bad_alloc();
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
|
|
Loading…
Reference in New Issue