summary refs log tree commit diff stats
path: root/ranger/ext/iter_tools.py
diff options
context:
space:
mode:
authorhut <hut@lavabit.com>2010-01-23 00:43:43 +0100
committerhut <hut@lavabit.com>2010-01-23 00:43:43 +0100
commitb6d4e3e558d84ee7b211ed9332fe9b7002cb8ec2 (patch)
tree474b750a4deca3918b1852e1153a57653447c67b /ranger/ext/iter_tools.py
parent77d3d6f556b275dc2bed79b67bee47c13267a082 (diff)
downloadranger-b6d4e3e558d84ee7b211ed9332fe9b7002cb8ec2.tar.gz
added unique function, moved flatten to ext/iter_tools
Diffstat (limited to 'ranger/ext/iter_tools.py')
-rw-r--r--ranger/ext/iter_tools.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/ranger/ext/iter_tools.py b/ranger/ext/iter_tools.py
new file mode 100644
index 00000000..913b9c7d
--- /dev/null
+++ b/ranger/ext/iter_tools.py
@@ -0,0 +1,43 @@
+# Copyright (c) 2009, 2010 hut <hut@lavabit.com>
+#
+# Permission to use, copy, modify, and/or distribute this software for any
+# purpose with or without fee is hereby granted, provided that the above
+# copyright notice and this permission notice appear in all copies.
+#
+# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+
+from collections import deque
+
+def flatten(lst):
+	"""
+	Flatten an iterable.
+
+	All contained tuples, lists, deques and sets are replaced by their
+	elements and flattened as well.
+	"""
+	for elem in lst:
+		if isinstance(elem, (tuple, list, set, deque)):
+			for subelem in flatten(elem):
+				yield subelem
+		else:
+			yield elem
+
+def unique(iterable):
+	"""
+	Return an iterable of the same type which contains unique items.
+
+	This function assumes that:
+	type(iterable)(list(iterable)) == iterable
+	which is true for tuples, lists and deques (but not for strings)
+	"""
+	already_seen = []
+	for item in iterable:
+		if item not in already_seen:
+			already_seen.append(item)
+	return type(iterable)(already_seen)
1.2.1&id=f07bb12fc5c59430e995a64956b36331ce3629b9'>f07bb12f ^
4c13e1f2 ^
34a60763 ^


b3556b21 ^
f07bb12f ^

f07bb12f ^





34a60763 ^

f07bb12f ^



4e9450f9 ^
f07bb12f ^
34a60763 ^

f07bb12f ^














1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68