Files
mercury/extras/posix/posix.fork.m
Julien Fischer 9751360ca4 Style and formatting fixes for the POSIX binding.
extras/posix/*.m:
    As above.
2019-03-22 10:53:31 +00:00

59 lines
1.7 KiB
Mathematica

%-----------------------------------------------------------------------------%
% 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.
%------------------------------------------------------------------------------%