Thun/thun/gnu-prolog/fork.pl

46 lines
1.1 KiB
Prolog

:- multifile(func/3).
func(fork, [F, G|S], [X, Y|S]) :-
fork(F, S, R, ChildPID),
thun(G, S, [Y|_]),
read_pipe(R, X),
wait(ChildPID, Status). % FIXME check status!!!
fork(Expr, Stack, In, ChildPID) :-
mkpipe(In, Out),
fork_prolog(ChildPID),
bar(ChildPID, In, Out, Expr, Stack).
bar(0, In, Out, Expr, Stack) :-
close(In),
thun(Expr, Stack, [Result|_]),
w(Out, Result),
close(Out),
halt.
bar(PID, _, Out, _, _) :-
integer(PID),
PID =\= 0,
close(Out).
read_pipe(In, Result) :-
select([In], R, [], _, 1500),
(R=[In] ->
read(In, Result)
;
Result=timeout
),
close(In).
mkpipe(In, Out) :-
create_pipe(In, Out),
set_stream_buffering(Out, none),
set_stream_buffering(In, none).
w(Out, Term) :- % To get a term written out and recognized,
write(Out, Term), % you write it to the stream
put_code(Out, 0'.), % add a period at the end
nl(Out), % and a newline even if you set buffering
flush_output(Out). % to none, then flush for good measure.