%%------------------------------------------------------------------------
%%
%% %CopyrightBegin%
%% 
%% Copyright Ericsson AB 2001-2010. All Rights Reserved.
%% 
%% The contents of this file are subject to the Erlang Public License,
%% Version 1.1, (the "License"); you may not use this file except in
%% compliance with the License. You should have received a copy of the
%% Erlang Public License along with this software. If not, it can be
%% retrieved online at http://www.erlang.org/.
%% 
%% Software distributed under the License is distributed on an "AS IS"
%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
%% the License for the specific language governing rights 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]}.