1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
/*****************************************************************************
* Copyright 2014 - 2015 Yichao Yu <yyc1992@gmail.com> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU Lesser General Public License as *
* published by the Free Software Foundation; either version 2.1 of the *
* License, or (at your option) version 3, or any later version accepted *
* by the membership of KDE e.V. (or its successor approved by the *
* membership of KDE e.V.), which shall act as a proxy defined in *
* Section 6 of version 3 of the license. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public *
* License along with this library. If not, *
* see <http://www.gnu.org/licenses/>. *
*****************************************************************************/
#include <qtcurve-utils/process.h>
#include <assert.h>
#include <unistd.h>
#include <time.h>
#include <signal.h>
#include <sys/wait.h>
int pipe_fds[2];
long num;
static void
forkCb(void*)
{
write(pipe_fds[1], &num, sizeof(num));
}
static void
sigchld_handler(int)
{
wait(nullptr);
}
int
main()
{
int res = pipe(pipe_fds);
assert(res == 0);
srandom(time(nullptr));
num = random();
struct sigaction sa;
memset(&sa, 0, sizeof(struct sigaction));
sa.sa_handler = sigchld_handler;
sigemptyset(&sa.sa_mask);
sa.sa_flags = SA_RESTART;
sigaction(SIGCHLD, &sa, nullptr);
if (fork() == 0) {
sleep(4);
return 0;
}
alarm(1);
bool fork_res = qtcForkBackground(forkCb, nullptr);
assert(fork_res);
long num_sent = 0;
ssize_t read_res = read(pipe_fds[0], &num_sent, sizeof(num_sent));
assert(read_res == sizeof(num_sent));
assert(num_sent = num);
return 0;
}
|