aboutsummaryrefslogtreecommitdiffstats
path: root/lib/kernel/test/ch.erl
blob: c9f378e387fbac05cefa937fccfb39867187efdc (plain) (blame)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
%%
%% %CopyrightBegin%
%% 
%% Copyright Ericsson AB 1996-2016. 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(ch).
-behaviour(gen_server). 

%% External exports 
-export([start_link/1]). 
 
%% gen_server callbacks
-export([init/1, handle_call/3, handle_info/2, terminate/2,
	 handle_cast/2, code_change/3]).

start_link(Name) -> gen_server:start_link(ch, Name, []). 

%%----------------------------------------------------------------- 
%% Callback functions from gen_server 
%%----------------------------------------------------------------- 
init(Name) ->
    process_flag(trap_exit, true),
    global:re_register_name(Name, self()),
    St = application:start_type(),
    St1 = case St of
	      normal ->
		  normal;
	      local ->
		  local;
	      {takeover, _N} ->
		  takeover;
	      {failover, _N} ->
		  failover;
	      Else ->
		  Else
	  end,

    %% Slow start to make sure that applications are started
    %% "at the same time". (otp_2973)
    case Name of
	{ch,77} -> timer:sleep(100);
	_ -> ok
    end,

    (catch global:send(Name, {st_type,{st, St1}})),
    {ok, []}.

handle_call({get_pid_key, Key}, _, State) -> 
    Res = application:get_key(Key),
    {reply, Res, State};

handle_call(get_pid_all_key, _, State) -> 
    Res = application:get_all_key(),
    {reply, Res, State}.

handle_info({st_type, Msg}, State) -> 
    timer:sleep(1000),
    (catch global:send(st_type, Msg)),
    {noreply, State};

handle_info(_, State) -> 
    {noreply, State}.

terminate(_Reason, _State) -> 
    ok.

handle_cast(_, State) ->
    {noreply, State}.

code_change(_OldVsn, State, _Extra) ->
    {ok, State}.