TYPE3
[iec.git] / src / type3_AndroidCloud / anbox-master / external / process-cpp-minimal / include / core / posix / fork.h
1 /*
2  * Copyright © 2013 Canonical Ltd.
3  *
4  * This program is free software: you can redistribute it and/or modify it
5  * under the terms of the GNU Lesser General Public License version 3,
6  * as published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11  * GNU Lesser General Public License for more details.
12  *
13  * You should have received a copy of the GNU Lesser General Public License
14  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
15  *
16  * Authored by: Thomas Voß <thomas.voss@canonical.com>
17  */
18
19 #ifndef CORE_POSIX_FORK_H_
20 #define CORE_POSIX_FORK_H_
21
22 #include <core/posix/child_process.h>
23 #include <core/posix/standard_stream.h>
24 #include <core/posix/visibility.h>
25
26 #include <functional>
27
28 namespace core
29 {
30 namespace posix
31 {
32 /**
33  * @brief fork forks a new process and executes the provided main function in the newly forked process.
34  * @throws std::system_error in case of errors.
35  * @param [in] main The main function of the newly forked process.
36  * @param [in] flags Specify which standard streams should be redirected to the parent process.
37  * @return An instance of ChildProcess in case of success.
38  */
39 CORE_POSIX_DLL_PUBLIC ChildProcess fork(const std::function<posix::exit::Status()>& main,
40                                    const StandardStream& flags);
41
42 /**
43  * @brief fork vforks a new process and executes the provided main function in the newly forked process.
44  * @throws std::system_error in case of errors.
45  * @param [in] main The main function of the newly forked process.
46  * @param [in] flags Specify which standard streams should be redirected to the parent process.
47  * @return An instance of ChildProcess in case of success.
48  */
49 CORE_POSIX_DLL_PUBLIC ChildProcess vfork(const std::function<posix::exit::Status()>& main,
50                    const StandardStream& flags);
51 }
52 }
53
54 #endif // CORE_POSIX_FORK_H_