12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- /*##############################################################################
- HPCC SYSTEMS software Copyright (C) 2018 HPCC Systems.
- 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.
- ############################################################################## */
- //class=embedded
- //class=3rdparty
- //nohthor
- IMPORT Java;
- unsigned persister(integer initial) := EMBED(Java : PERSIST('thread'))
- public class persister
- {
- public persister(int initial) { tot = initial; }
- public synchronized int accumulate(int a)
- {
- tot = tot + a;
- return tot;
- }
- public synchronized int clear()
- {
- int _tot = tot;
- tot = 0;
- return _tot;
- }
- private int tot = 0;
- }
- ENDEMBED;
- integer accumulate(unsigned p, integer val) := IMPORT(Java, 'accumulate');
- integer clear(unsigned p) := IMPORT(Java, 'clear');
- r := record
- integer i;
- unsigned p := 0;
- end;
- r t(r l, r r) := TRANSFORM
- SELF.p := IF (l.p=0,persister(l.p),l.p);
- SELF.i := accumulate(self.p, r.i);
- END;
- d1 := DATASET([{1}, {2}, {3}], r);
- accumulated := ITERATE(d1, t(LEFT, RIGHT), LOCAL);
- OUTPUT(accumulated, {i});
|