Code Examples
A repository of 155 code examples for BeepBeep
KeepLastPull.java
1 /*
2  BeepBeep, an event stream processor
3  Copyright (C) 2008-2018 Sylvain HallĂ©
4 
5  This program is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published
7  by the Free Software Foundation, either version 3 of the License, or
8  (at your option) any later version.
9 
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 package basic;
19 
20 import ca.uqac.lif.cep.Connector;
21 import ca.uqac.lif.cep.Pullable;
22 import ca.uqac.lif.cep.tmf.KeepLast;
23 import ca.uqac.lif.cep.tmf.QueueSource;
24 
25 /**
26  * Use the {@link ca.uqac.lif.cep.tmf.KeepLast KeepLast} processor to
27  * keep the last event of an input stream.
28  * The chain of processors in this example can be represented
29  * graphically as:
30  * <p>
31  * <img src="./doc-files/basic/KeepLastPull.png" alt="Processor graph">
32  * <p>
33  * @author Sylvain HallĂ©
34  * @difficulty Easy
35  */
36 public class KeepLastPull
37 {
38  public static void main(String[] args)
39  {
40  ///
41  QueueSource src = new QueueSource().setEvents(1, 2, 3, 4, 5);
42  src.loop(false);
43  KeepLast kl = new KeepLast();
44  Connector.connect(src, kl);
45  Pullable p = kl.getPullableOutput();
46  while (p.hasNext())
47  {
48  Object o = p.next();
49  System.out.print(o);
50  }
51  ///
52  }
53 }
Use the KeepLast processor to keep the last event of an input stream.