-
Notifications
You must be signed in to change notification settings - Fork 54
/
posix.fork.m
58 lines (47 loc) · 1.7 KB
/
posix.fork.m
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
%-----------------------------------------------------------------------------%
% vim: ft=mercury ts=4 sw=4 et
%-----------------------------------------------------------------------------%
% Copyright (C) 2001 The University of Melbourne.
% Copyright (C) 2018-2019 The Mercury team.
% This file is distributed under the terms specified in COPYING.LIB.
%-----------------------------------------------------------------------------%
%
% Module: posix.fork.m
% Main author: Michael Day <miked@lendtech.com.au>
%
%-----------------------------------------------------------------------------%
:- module posix.fork.
:- interface.
:- type whoami
---> child
; parent(pid_t).
:- pred fork(posix.result(whoami)::out, io::di, io::uo) is det.
%-----------------------------------------------------------------------------%
%-----------------------------------------------------------------------------%
:- implementation.
:- import_module int.
:- pragma foreign_decl("C", "
#include <sys/types.h>
#include <unistd.h>
").
%-----------------------------------------------------------------------------%
fork(Result, !IO) :-
fork0(Pid, !IO),
( if Pid < 0 then
errno(Err, !IO),
Result = error(Err)
else if Pid = 0 then
Result = ok(child)
else
Result = ok(parent(pid(Pid)))
).
:- pred fork0(int::out, io::di, io::uo) is det.
:- pragma foreign_proc("C",
fork0(Pid::out, _IO0::di, _IO::uo),
[promise_pure, will_not_call_mercury, tabled_for_io],
"
Pid = fork();
").
%------------------------------------------------------------------------------%
:- end_module posix.fork.
%------------------------------------------------------------------------------%