Code Examples
A repository of 155 code examples for BeepBeep
PackExample.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 util;
19 
20 import ca.uqac.lif.cep.Connector;
21 import ca.uqac.lif.cep.Pullable;
22 import ca.uqac.lif.cep.tmf.QueueSource;
23 import ca.uqac.lif.cep.util.Lists;
24 
25 /**
26  * Use the {@link ca.uqac.lif.cep.util.Lists.Pack Pack} processor to
27  * accumulate events into a list.
28  * Graphically, this chain of processors can be represented as:
29  * <p>
30  * <img src="./doc-files/util/PackExample.png" alt="Processor graph">
31 * <p>
32  * The output of this program is:
33  * <pre>
34  * [3]
35  * [1, 4, 1, 5]
36  * [9, 2]
37  * [6, 5]
38  * </pre>
39  *
40  * @author Sylvain HallĂ©
41  * @difficulty Easy
42  */
43 public class PackExample
44 {
45 
46  public static void main(String[] args)
47  {
48  ///
49  QueueSource src1 = new QueueSource();
50  src1.setEvents(3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5);
51  QueueSource src2 = new QueueSource();
52  src2.setEvents(false, true, false, false, false, true, false, true);
53  Lists.Pack pack = new Lists.Pack();
54  Connector.connect(src1, 0, pack, 0);
55  Connector.connect(src2, 0, pack, 1);
56  Pullable p = pack.getPullableOutput();
57  for (int i = 0; i < 4; i++)
58  {
59  System.out.println(p.pull());
60  }
61  ///
62  }
63 
64 }
Use the Pack processor to accumulate events into a list.