%%------------------------------------------------------------------------
%%
%% %CopyrightBegin%
%%
%% Copyright Ericsson AB 2001-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%
%%
%%
%%------------------------------------------------------------------------
%% Description: a very simple implementation of Pull Supplier interface
%%------------------------------------------------------------------------
-module(event_test_PullS_impl).
-include_lib("orber/include/corba.hrl").
-export([init/1, terminate/2, pull/1, try_pull/1, disconnect_pull_supplier/1,
add_event/2]).
init(_) ->
{ok, []}.
terminate(_From, _Reason) ->
ok.
pull([]) ->
corba:raise(#'INTERNAL'{completion_status = ?COMPLETED_NO});
pull([Event|Events]) ->
{reply, Event, Events}.
try_pull([]) ->
{reply, {#any{typecode=tk_null, value = null}, false}, []};
try_pull([Event|Events]) ->
{reply, {Event, true}, Events}.
disconnect_pull_supplier(Events) ->
io:format("event_test_PullS terminates ~p~n", [Events]),
{stop, normal, ok, Events}.
add_event(Events, Event) ->
%% Store in FIFO order; don't really care if we use '++' since
%% this operation is used in tests only.
{reply, ok, Events ++ [Event]}.