aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/poco/Foundation/src/Process.cpp
diff options
context:
space:
mode:
authororivej <orivej@yandex-team.ru>2022-02-10 16:44:49 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:44:49 +0300
commit718c552901d703c502ccbefdfc3c9028d608b947 (patch)
tree46534a98bbefcd7b1f3faa5b52c138ab27db75b7 /contrib/libs/poco/Foundation/src/Process.cpp
parente9656aae26e0358d5378e5b63dcac5c8dbe0e4d0 (diff)
downloadydb-718c552901d703c502ccbefdfc3c9028d608b947.tar.gz
Restoring authorship annotation for <orivej@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'contrib/libs/poco/Foundation/src/Process.cpp')
-rw-r--r--contrib/libs/poco/Foundation/src/Process.cpp394
1 files changed, 197 insertions, 197 deletions
diff --git a/contrib/libs/poco/Foundation/src/Process.cpp b/contrib/libs/poco/Foundation/src/Process.cpp
index 6cc0b7e6b9..634a44b5b4 100644
--- a/contrib/libs/poco/Foundation/src/Process.cpp
+++ b/contrib/libs/poco/Foundation/src/Process.cpp
@@ -1,197 +1,197 @@
-//
-// Process.cpp
-//
-// Library: Foundation
-// Package: Processes
-// Module: Process
-//
-// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#include "Poco/Process.h"
-#include "Poco/Environment.h"
-
-
-namespace
-{
- std::vector<char> getEnvironmentVariablesBuffer(const Poco::Process::Env& env)
- {
- std::vector<char> envbuf;
- std::size_t pos = 0;
-
- for (Poco::Process::Env::const_iterator it = env.begin(); it != env.end(); ++it)
- {
- std::size_t envlen = it->first.length() + it->second.length() + 1;
-
- envbuf.resize(pos + envlen + 1);
- std::copy(it->first.begin(), it->first.end(), &envbuf[pos]);
- pos += it->first.length();
- envbuf[pos] = '=';
- ++pos;
- std::copy(it->second.begin(), it->second.end(), &envbuf[pos]);
- pos += it->second.length();
-
- envbuf[pos] = '\0';
- ++pos;
- }
-
- envbuf.resize(pos + 1);
- envbuf[pos] = '\0';
-
- return envbuf;
- }
-}
-
-
-#if defined(POCO_OS_FAMILY_WINDOWS) && defined(POCO_WIN32_UTF8)
-#if defined(_WIN32_WCE)
-#include "Process_WINCE.cpp"
-#else
-#include "Process_WIN32U.cpp"
-#endif
-#elif defined(POCO_OS_FAMILY_WINDOWS)
-#include "Process_WIN32.cpp"
-#elif defined(POCO_VXWORKS)
-#include "Process_VX.cpp"
-#elif defined(POCO_OS_FAMILY_UNIX)
-#include "Process_UNIX.cpp"
-#endif
-
-
-namespace Poco {
-
-
-//
-// ProcessHandle
-//
-ProcessHandle::ProcessHandle(const ProcessHandle& handle):
- _pImpl(handle._pImpl)
-{
- _pImpl->duplicate();
-}
-
-
-ProcessHandle::~ProcessHandle()
-{
- _pImpl->release();
-}
-
-
-ProcessHandle::ProcessHandle(ProcessHandleImpl* pImpl):
- _pImpl(pImpl)
-{
- poco_check_ptr (_pImpl);
-}
-
-
-ProcessHandle& ProcessHandle::operator = (const ProcessHandle& handle)
-{
- if (&handle != this)
- {
- _pImpl->release();
- _pImpl = handle._pImpl;
- _pImpl->duplicate();
- }
- return *this;
-}
-
-
-ProcessHandle::PID ProcessHandle::id() const
-{
- return _pImpl->id();
-}
-
-
-int ProcessHandle::wait() const
-{
- return _pImpl->wait();
-}
-
-
-//
-// Process
-//
-ProcessHandle Process::launch(const std::string& command, const Args& args)
-{
- std::string initialDirectory;
- Env env;
- return ProcessHandle(launchImpl(command, args, initialDirectory, 0, 0, 0, env));
-}
-
-
-ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory)
-{
- Env env;
- return ProcessHandle(launchImpl(command, args, initialDirectory, 0, 0, 0, env));
-}
-
-
-ProcessHandle Process::launch(const std::string& command, const Args& args, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe)
-{
- poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
- std::string initialDirectory;
- Env env;
- return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
-}
-
-
-ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe)
-{
- poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
- Env env;
- return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
-}
-
-
-ProcessHandle Process::launch(const std::string& command, const Args& args, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe, const Env& env)
-{
- poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
- std::string initialDirectory;
- return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
-}
-
-
-ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe, const Env& env)
-{
- poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
- return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
-}
-
-
-int Process::wait(const ProcessHandle& handle)
-{
- return handle.wait();
-}
-
-
-void Process::kill(ProcessHandle& handle)
-{
- killImpl(*handle._pImpl);
-}
-
-
-void Process::kill(PID pid)
-{
- killImpl(pid);
-}
-
-bool Process::isRunning(const ProcessHandle& handle)
-{
- return isRunningImpl(*handle._pImpl);
-}
-bool Process::isRunning(PID pid)
-{
- return isRunningImpl(pid);
-}
-
-void Process::requestTermination(PID pid)
-{
- requestTerminationImpl(pid);
-}
-
-
-} // namespace Poco
+//
+// Process.cpp
+//
+// Library: Foundation
+// Package: Processes
+// Module: Process
+//
+// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#include "Poco/Process.h"
+#include "Poco/Environment.h"
+
+
+namespace
+{
+ std::vector<char> getEnvironmentVariablesBuffer(const Poco::Process::Env& env)
+ {
+ std::vector<char> envbuf;
+ std::size_t pos = 0;
+
+ for (Poco::Process::Env::const_iterator it = env.begin(); it != env.end(); ++it)
+ {
+ std::size_t envlen = it->first.length() + it->second.length() + 1;
+
+ envbuf.resize(pos + envlen + 1);
+ std::copy(it->first.begin(), it->first.end(), &envbuf[pos]);
+ pos += it->first.length();
+ envbuf[pos] = '=';
+ ++pos;
+ std::copy(it->second.begin(), it->second.end(), &envbuf[pos]);
+ pos += it->second.length();
+
+ envbuf[pos] = '\0';
+ ++pos;
+ }
+
+ envbuf.resize(pos + 1);
+ envbuf[pos] = '\0';
+
+ return envbuf;
+ }
+}
+
+
+#if defined(POCO_OS_FAMILY_WINDOWS) && defined(POCO_WIN32_UTF8)
+#if defined(_WIN32_WCE)
+#include "Process_WINCE.cpp"
+#else
+#include "Process_WIN32U.cpp"
+#endif
+#elif defined(POCO_OS_FAMILY_WINDOWS)
+#include "Process_WIN32.cpp"
+#elif defined(POCO_VXWORKS)
+#include "Process_VX.cpp"
+#elif defined(POCO_OS_FAMILY_UNIX)
+#include "Process_UNIX.cpp"
+#endif
+
+
+namespace Poco {
+
+
+//
+// ProcessHandle
+//
+ProcessHandle::ProcessHandle(const ProcessHandle& handle):
+ _pImpl(handle._pImpl)
+{
+ _pImpl->duplicate();
+}
+
+
+ProcessHandle::~ProcessHandle()
+{
+ _pImpl->release();
+}
+
+
+ProcessHandle::ProcessHandle(ProcessHandleImpl* pImpl):
+ _pImpl(pImpl)
+{
+ poco_check_ptr (_pImpl);
+}
+
+
+ProcessHandle& ProcessHandle::operator = (const ProcessHandle& handle)
+{
+ if (&handle != this)
+ {
+ _pImpl->release();
+ _pImpl = handle._pImpl;
+ _pImpl->duplicate();
+ }
+ return *this;
+}
+
+
+ProcessHandle::PID ProcessHandle::id() const
+{
+ return _pImpl->id();
+}
+
+
+int ProcessHandle::wait() const
+{
+ return _pImpl->wait();
+}
+
+
+//
+// Process
+//
+ProcessHandle Process::launch(const std::string& command, const Args& args)
+{
+ std::string initialDirectory;
+ Env env;
+ return ProcessHandle(launchImpl(command, args, initialDirectory, 0, 0, 0, env));
+}
+
+
+ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory)
+{
+ Env env;
+ return ProcessHandle(launchImpl(command, args, initialDirectory, 0, 0, 0, env));
+}
+
+
+ProcessHandle Process::launch(const std::string& command, const Args& args, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe)
+{
+ poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
+ std::string initialDirectory;
+ Env env;
+ return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
+}
+
+
+ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe)
+{
+ poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
+ Env env;
+ return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
+}
+
+
+ProcessHandle Process::launch(const std::string& command, const Args& args, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe, const Env& env)
+{
+ poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
+ std::string initialDirectory;
+ return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
+}
+
+
+ProcessHandle Process::launch(const std::string& command, const Args& args, const std::string& initialDirectory, Pipe* inPipe, Pipe* outPipe, Pipe* errPipe, const Env& env)
+{
+ poco_assert (inPipe == 0 || (inPipe != outPipe && inPipe != errPipe));
+ return ProcessHandle(launchImpl(command, args, initialDirectory, inPipe, outPipe, errPipe, env));
+}
+
+
+int Process::wait(const ProcessHandle& handle)
+{
+ return handle.wait();
+}
+
+
+void Process::kill(ProcessHandle& handle)
+{
+ killImpl(*handle._pImpl);
+}
+
+
+void Process::kill(PID pid)
+{
+ killImpl(pid);
+}
+
+bool Process::isRunning(const ProcessHandle& handle)
+{
+ return isRunningImpl(*handle._pImpl);
+}
+bool Process::isRunning(PID pid)
+{
+ return isRunningImpl(pid);
+}
+
+void Process::requestTermination(PID pid)
+{
+ requestTerminationImpl(pid);
+}
+
+
+} // namespace Poco