diff options
Diffstat (limited to 'src/util.py')
-rw-r--r-- | src/util.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/util.py b/src/util.py index 4698533..6b43e83 100644 --- a/src/util.py +++ b/src/util.py @@ -77,3 +77,20 @@ def spawn_read(*command): if out.endswith('\n'): out = out[:-1] return out + + +def reduce(f, items): + ''' + https://en.wikipedia.org/wiki/Fold_(higher-order_function) + + @param f:(¿E?, ¿E?)→¿E? The function + @param item:itr<¿E?> The input + @return ¿E? The output + ''' + if len(items) < 2: + return items + rc = items[0] + for i in range(1, len(items)): + rc = f(rc, items[i]) + return rc + |