%% %% %CopyrightBegin% %% %% Copyright Ericsson AB 2004-2009. All Rights Reserved. %% %% Licensed under the Apache License, Version 2.0 (the "License"); %% you may not use this file except in compliance with the License. %% You may obtain a copy of the License at %% %% http://www.apache.org/licenses/LICENSE-2.0 %% %% Unless required by applicable law or agreed to in writing, software %% distributed under the License is distributed on an "AS IS" BASIS, %% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %% See the License for the specific language governing permissions and %% limitations under the License. %% %% %CopyrightEnd% %% -module(otp_5235). -export([?MODULE/0]). -record(commit, {node, decision, % presume_commit | Decision ram_copies = [], disc_copies = [], disc_only_copies = [], snmp = [], schema_ops = [self(),make_ref()] }). ?MODULE() -> process_flag(trap_exit, true), N = 1024, clone(N), wait(N). wait(0) -> ok; wait(N) -> receive {'EXIT',_,normal} -> wait(N-1); Other -> exit(Other) end. clone(0) -> ok; clone(N) -> spawn_link(fun worker/0), clone(N-1). worker() -> Seq = lists:seq(1, 10), PidList = [{N,self()} || N <- Seq], Commit = #commit{ram_copies=PidList,disc_copies=[], disc_only_copies=[],snmp=[]}, List = lists:duplicate(2, Commit), verify(run(2, List)). verify([#commit{node=true,ram_copies=L}|T]) -> verify_1(L, 1), verify(T); verify([]) -> ok. verify_1([{N,Pid}|T], N) when Pid =:= self() -> verify_1(T, N+1); verify_1([], _) -> ok. run(0, L) -> L; run(N, L) -> run(N-1, reverse(L)). reverse([]) -> []; reverse([H|R]) when record(H, commit) -> [H#commit{ ram_copies = lists:reverse(H#commit.ram_copies), disc_copies = lists:reverse(H#commit.disc_copies), disc_only_copies = lists:reverse(H#commit.disc_only_copies), snmp = lists:reverse(H#commit.snmp), node = erlang:yield() } | reverse(R)].