Skip to content

Commit 1fd170f

Browse files
authored
order.reverse (#476)
1 parent 4942ac9 commit 1fd170f

File tree

3 files changed

+32
-8
lines changed

3 files changed

+32
-8
lines changed

CHANGELOG.md

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,8 @@
33
## Unreleased
44

55
- The `list` module gains the `list.map2` function.
6+
- `reverse` has been renamed to `negate` in the `order` module.
7+
- A new `reverse` function is added to the `order` module, which reverses an ordering function.
68
- `flatten` has been renamed to `concat` in the `list` module. The old name is
79
still available as an alias and is deprecated.
810

src/gleam/order.gleam

Lines changed: 18 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -18,21 +18,21 @@ pub type Order {
1818
/// ## Examples
1919
///
2020
/// ```gleam
21-
/// > reverse(Lt)
21+
/// > negate(Lt)
2222
/// Gt
2323
/// ```
2424
///
2525
/// ```gleam
26-
/// > reverse(Eq)
26+
/// > negate(Eq)
2727
/// Eq
2828
/// ```
2929
///
3030
/// ```gleam
31-
/// > reverse(Lt)
31+
/// > negate(Lt)
3232
/// Gt
3333
/// ```
3434
///
35-
pub fn reverse(order: Order) -> Order {
35+
pub fn negate(order: Order) -> Order {
3636
case order {
3737
Lt -> Gt
3838
Eq -> Eq
@@ -117,3 +117,17 @@ pub fn min(a: Order, b: Order) -> Order {
117117
_, _ -> b
118118
}
119119
}
120+
121+
/// Inverts an ordering function, so less-than becomes greater-than and greater-than
122+
/// becomes less-than.
123+
///
124+
/// ## Examples
125+
///
126+
/// ```gleam
127+
/// > list.sort([1, 5, 4], by: reverse(int.compare))
128+
/// [5, 4, 1]
129+
/// ```
130+
///
131+
pub fn reverse(orderer: fn(a, a) -> Order) -> fn(a, a) -> Order {
132+
fn(a, b) { orderer(b, a) }
133+
}

test/gleam/order_test.gleam

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,16 @@
1+
import gleam/int
2+
import gleam/list
13
import gleam/order.{Eq, Gt, Lt}
24
import gleam/should
35

4-
pub fn reverse_test() {
5-
order.reverse(Lt)
6+
pub fn negate_test() {
7+
order.negate(Lt)
68
|> should.equal(Gt)
79

8-
order.reverse(Eq)
10+
order.negate(Eq)
911
|> should.equal(Eq)
1012

11-
order.reverse(Gt)
13+
order.negate(Gt)
1214
|> should.equal(Lt)
1315
}
1416

@@ -109,3 +111,9 @@ pub fn min_test() {
109111
order.min(Gt, Gt)
110112
|> should.equal(Gt)
111113
}
114+
115+
pub fn reverse_test() {
116+
[4, 5, 1]
117+
|> list.sort(by: order.reverse(int.compare))
118+
|> should.equal([5, 4, 1])
119+
}

0 commit comments

Comments
 (0)