summary refs log tree commit diff stats
path: root/lib
diff options
context:
space:
mode:
authorTimothee Cour <timothee.cour2@gmail.com>2021-05-30 13:37:21 -0700
committerGitHub <noreply@github.com>2021-05-30 22:37:21 +0200
commit4a7f2c386cde91b784106905f6e70d3954d8fae9 (patch)
tree08edcb7d8f4b6d7f2d540668605615f2b0181b45 /lib
parentcfe19247e856950f7facaf7adbc50bca8dec3990 (diff)
downloadNim-4a7f2c386cde91b784106905f6e70d3954d8fae9.tar.gz
close #16569: deprecated `reversed(a, start, last)` overload, use toOpenArray instead (#18047)
* close #16569: deprecated reversed overload, use toOpenArray instead

* [skip ci] change wording in changelog per review

* fixup
Diffstat (limited to 'lib')
-rw-r--r--lib/pure/algorithm.nim41
1 files changed, 11 insertions, 30 deletions
diff --git a/lib/pure/algorithm.nim b/lib/pure/algorithm.nim
index f4b3f46be..c96f599e8 100644
--- a/lib/pure/algorithm.nim
+++ b/lib/pure/algorithm.nim
@@ -131,40 +131,21 @@ proc reverse*[T](a: var openArray[T]) =
   # the max is needed, since a.high is -1 if a is empty
   reverse(a, 0, max(0, a.high))
 
-proc reversed*[T](a: openArray[T], first: Natural, last: int): seq[T] =
-  ## Returns the reverse of the slice `a[first..last]`.
-  ##
-  ## If an invalid range is passed, it raises `IndexDefect`.
-  ##
-  ## **See also:**
-  ## * `reverse proc<#reverse,openArray[T],Natural,Natural>`_ reverse a slice
-  ## * `reverse proc<#reverse,openArray[T]>`_
-  runnableExamples:
-    let
-      a = [1, 2, 3, 4, 5, 6]
-      b = a.reversed(1, 3)
-    assert b == @[4, 3, 2]
-  assert last >= first - 1
-  var i = last - first
-  var x = first.int
-  result = newSeq[T](i + 1)
-  while i >= 0:
-    result[i] = a[x]
-    dec(i)
-    inc(x)
-
-proc reversed*[T](a: openArray[T]): seq[T] =
-  ## Returns the reverse of the container `a`.
+proc reversed*[T](a: openArray[T]): seq[T] {.inline.} =
+  ## Returns the elements of `a` in reverse order.
   ##
   ## **See also:**
-  ## * `reverse proc<#reverse,openArray[T],Natural,Natural>`_ reverse a slice
   ## * `reverse proc<#reverse,openArray[T]>`_
   runnableExamples:
-    let
-      a = [1, 2, 3, 4, 5, 6]
-      b = reversed(a)
-    assert b == @[6, 5, 4, 3, 2, 1]
-  reversed(a, 0, a.high)
+    assert [10, 11, 12].reversed == @[12, 11, 10]
+    assert seq[string].default.reversed == @[]
+  let n = a.len
+  result.setLen(n)
+  for i in 0..<n: result[i] = a[n - (i + 1)]
+
+proc reversed*[T](a: openArray[T], first: Natural, last: int): seq[T]
+  {.inline, deprecated: "use: `reversed(toOpenArray(a, first, last))`".} =
+  reversed(toOpenArray(a, first, last))
 
 proc binarySearch*[T, K](a: openArray[T], key: K,
                          cmp: proc (x: T, y: K): int {.closure.}): int =
a> ^
87c5b329 ^
9e751bb8 ^
4690ce81 ^
4a39d12d ^
a654e4ec ^
e5c11a51 ^
70f4e9b6 ^
4a39d12d ^
9e751bb8 ^
76755b28 ^

a654e4ec ^



e5c11a51 ^






















a654e4ec ^

76755b28 ^
e5c11a51 ^
a654e4ec ^
204dae92 ^









201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^

c5e4a41a ^
204dae92 ^

c5e4a41a ^
1c2d788b ^
204dae92 ^

2c678a4e ^
9e751bb8 ^
2c678a4e ^
c5e4a41a ^

9e751bb8 ^
2c678a4e ^
c5e4a41a ^

9e751bb8 ^
204dae92 ^


c5e4a41a ^
204dae92 ^
201458e3 ^
9e751bb8 ^

204dae92 ^
1c2d788b ^
204dae92 ^
1c2d788b ^
204dae92 ^

c5e4a41a ^
204dae92 ^
51728d93 ^
204dae92 ^
201458e3 ^
9e751bb8 ^
1c2d788b ^
9e751bb8 ^
204dae92 ^
1c2d788b ^

9e751bb8 ^
204dae92 ^

1c2d788b ^
9e751bb8 ^
204dae92 ^

9e751bb8 ^
1c2d788b ^
9e751bb8 ^





204dae92 ^



201458e3 ^
204dae92 ^






201458e3 ^
204dae92 ^






201458e3 ^
204dae92 ^






201458e3 ^
204dae92 ^







201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^

201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^


201458e3 ^
204dae92 ^

201458e3 ^
204dae92 ^




201458e3 ^
204dae92 ^









201458e3 ^
204dae92 ^



76755b28 ^


a654e4ec ^
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227