]> git.lizzy.rs Git - rust.git/commit
Rollup merge of #104672 - Voultapher:unify-sort-modules, r=thomcc
authorMichael Goulet <michael@errs.io>
Sat, 21 Jan 2023 02:33:21 +0000 (21:33 -0500)
committerGitHub <noreply@github.com>
Sat, 21 Jan 2023 02:33:21 +0000 (21:33 -0500)
commit68b390ae2a099a598bfe44d4ec36ae15159c283f
treecbd2df16b4e222e6164576a0e9767ece46d943c2
parentbf75f8177b42da40faef510838eb1114c30c49df
parent4b5844fbe95a35370c19d74f9b70286897c3e153
Rollup merge of #104672 - Voultapher:unify-sort-modules, r=thomcc

Unify stable and unstable sort implementations in same core module

This moves the stable sort implementation to the core::slice::sort module. By virtue of being in core it can't access `Vec`. The two `Vec` used by merge sort, `buf` and `runs`, are modelled as custom types that implement the very limited required `Vec` interface with the help of provided allocation and free functions. This is done to allow future re-use of functions and logic between stable and unstable sort. Such as `insert_head`.

This is in preparation of #100856 and #104116. It only moves code, it *doesn't* change any of the sort related logic. This unlocks the ability to share `insert_head`, `insert_tail`, `swap_if_less` `merge` and more.

Tagging ````@Mark-Simulacrum```` I hope this allows progress on #100856, by moving `merge_sort` here I hope future changes will be easier to review.
library/alloc/src/slice.rs
library/core/src/slice/mod.rs
library/core/src/slice/sort.rs