Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add ToSorted function to return a sorted copy of a slice #413

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

KylinDC
Copy link

@KylinDC KylinDC commented Dec 30, 2023

Add a function to return a sorted copy of a slice. Tests also added.
Feel free to comment.

@kqvanity
Copy link

I'm wondering why it hasn't merged or discusses even. The current plain go implementation requires a separate sort package interfaces. related

Comment on lines +597 to +608
// ToSorted return a sorted copy of a slice
// Play: https://go.dev/play/p/G4-aR2Yxh3M
func ToSorted[T constraints.Ordered](collection []T) []T {
if collection == nil {
return nil
}

copied := make([]T, len(collection))
copy(copied, collection)
slices.Sort(copied)
return copied
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would have used "Sort"

Suggested change
// ToSorted return a sorted copy of a slice
// Play: https://go.dev/play/p/G4-aR2Yxh3M
func ToSorted[T constraints.Ordered](collection []T) []T {
if collection == nil {
return nil
}
copied := make([]T, len(collection))
copy(copied, collection)
slices.Sort(copied)
return copied
}
// Sort return a sorted copy of a slice
// Play: https://go.dev/play/p/G4-aR2Yxh3M
func Sort[T constraints.Ordered](collection []T) []T {
if collection == nil {
return nil
}
copied := make([]T, len(collection))
copy(copied, collection)
slices.Sort(copied)
return copied
}

@@ -116,6 +116,7 @@ Supported helpers for slices:
- [Compact](#compact)
- [IsSorted](#issorted)
- [IsSortedByKey](#issortedbykey)
- [ToSorted](#tosorted)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
- [ToSorted](#tosorted)
- [Sort](#sort)

Comment on lines +928 to +937
### ToSorted

Return a sorted copy of a slice.

```go
sorted := lo.ToSorted([]int{0, 1, 4, 3, 2})
// [0 1 2 3 4]
```

[[play](https://go.dev/play/p/G4-aR2Yxh3M)]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
### ToSorted
Return a sorted copy of a slice.
```go
sorted := lo.ToSorted([]int{0, 1, 4, 3, 2})
// [0 1 2 3 4]
```
[[play](https://go.dev/play/p/G4-aR2Yxh3M)]
### Sort
Return a sorted copy of a slice.
```go
sorted := lo.Sort([]int{0, 1, 4, 3, 2})
// [0 1 2 3 4]
```
[[play](https://go.dev/play/p/G4-aR2Yxh3M)]

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants