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
|
%% This tests the presence of possible races due to a register/whereis
%% combination in an indirectly recursive function.
-module(whereis_rec_function4).
-export([test/0]).
test() ->
start(undefined, second, mod:f(), self()).
start(AnAtom, NextAtom, Fun, Id) ->
case AnAtom of
undefined -> register(start, Id);
_ -> register(AnAtom, Id)
end,
case whereis(NextAtom) of
undefined ->
Pid = spawn(Fun),
case Pid =:= self() of
true -> ok;
false -> continue(NextAtom, mod:next(), Pid, Id)
end;
P when is_pid(P) ->
ok
end.
continue(Atom, NextAtom, Fun, Id) ->
start(Atom, NextAtom, Fun, Id).
|