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

Incubate persistent data structures #31

Merged

Conversation

msteindorfer
Copy link
Contributor

This work-in-progress draft PR kicks the tires for incubating persistent data structures into the swift-collections project.

A long-term goal of this effort is to mature persistent replacements for the general-purpose data structures already present in the Swift Standard Library (i.e., Array, Set and Dictionary).

Currently, the PR covers the HashMap<Key: Hashable, Value> data type, which is supposed to become a persistent drop-in replacement for Swift's Dictionary. The draft implementation is neither feature complete nor performance optimized yet, but aims to create visibility for this effort and to elicit early feedback. Working title for the module is Capsule, based on prior work.

HashMap<Key: Hashable, Value> implements the Compressed Hash-Array Mapped Prefix-tree (CHAMP) data structure. The implementation is inspired by previous JVM data structures that I've authored in the past, amongst them:

Feel free to provide feedback on idiomatic Swift usage and Swift-specific performance optimization tips and tricks, if and where appropriate.

References and Further Readings

Publications

Talks

Checklist

  • I've read the Contribution Guidelines
  • My contributions are licensed under the Swift license.
  • I've followed the coding style of the rest of the project.
  • I've added tests covering all new code paths my change adds to the project (if appropriate).
  • I've added benchmarks covering new functionality (if appropriate).
  • I've verified that my change does not break any existing tests or introduce unexplained benchmark regressions.
  • I've updated the documentation if necessary.

@msteindorfer msteindorfer force-pushed the capsule-collections branch from 997a1f6 to 9ab9563 Compare May 4, 2021 07:14
@lorentey
Copy link
Member

lorentey commented May 4, 2021

This is exciting work. I think these would be a great fit for this package, and I'm personally very much interested in getting these landed (& eventually added to the stdlib). We'll need to figure out how to test & benchmark these, and carefully evaluate API decisions. I think there is a bunch of interesting low-level optimization work we can do on the internal representations (things like replacing Array<Any> storage with tail-allocated typed buffers).

(I think it may make sense to open an official feature branch for this project. I'll ponder how best to coordinate work, and I'll see about scheduling resources for getting this done.)

@msteindorfer
Copy link
Contributor Author

Hi @lorentey, great that we share the same interest and vision regarding this effort.

(I think it may make sense to open an official feature branch for this project. I'll ponder how best to coordinate work, and I'll see about scheduling resources for getting this done.)

An official feature branch sounds good to me. Keep me up to date on how we should progress incubating the persistent collections.

(The draft PR was a suggestion by @kylemacomber and was actually a good thing for getting the draft implementation out and creating momentum. Though it may not be ideal acting as a long running feature branch.)

We'll need to figure out how to test & benchmark these, and carefully evaluate API decisions.

Sure. I plan to add more test coverage (and eventually benchmarks) for the persistent data structures along the way.

I didn't investigate the state of the conformance checkers in swift-collections yet, but having good coverage for Dictionary, Set, Array and entailed protocols would help a lot.

I'll also reach out to discuss API decisions and idiomatic Swift usage when time is due, but first I'll work on dialing in the data structure design (e.g., what concepts translate best to Swift) and feature completeness.

I think there is a bunch of interesting low-level optimization work we can do on the internal representations

The same goes for low-level optimizations. I'm looking forward to tackle those as well, but first the data structure design needs to settle. Feel free to make suggestions anytime if you happen to notice something.

things like replacing Array storage with tail-allocated typed buffers

The Array<Any> store disguises a lot of complexity, since its content is type-heterogeneous, akin to several (differently) typed buffers concatenated (therefore elements are currently typed as Any).

Can you provide me some references on what you had in mind? I will then have a look at it.

@ktoso
Copy link
Member

ktoso commented May 11, 2021

Oh man, this is great~! Fantastic to have your expertise here @msteindorfer! 🥳
I regularly miss persistent data structures so this'll be a lovely and very welcome addition!

@msteindorfer msteindorfer force-pushed the capsule-collections branch from 1866b04 to 62658f8 Compare May 15, 2021 10:21
@msteindorfer msteindorfer force-pushed the capsule-collections branch 2 times, most recently from af069c9 to 37e957f Compare June 4, 2021 15:03
Sources/Capsule/_Common.swift Outdated Show resolved Hide resolved
Comment on lines 51 to 53
guard expectedCount == builder.count else {
preconditionFailure("Duplicate key: '\(key)'")
}

Choose a reason for hiding this comment

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

I think this can be replaced with

precondition(expectedCount == builder.count, "Duplicate key: '\(key)'")

Although, I don't know if there is any performance disadvantage with the auto closure in precondition.

Comment on lines 116 to 118
public func get(_ key: Key) -> Value? {
rootNode.get(key, computeHash(key), 0)
}

Choose a reason for hiding this comment

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

I think it's more idiomatic in Swift to name this function as value(at key: Key) -> Value?.

Also, maybe this function can be internal or private? There is already a subscript for retrieving the value by key.

@lorentey lorentey mentioned this pull request Dec 9, 2021
7 tasks
@kielgillard
Copy link
Contributor

@lorentey @msteindorfer is there anything we in The Community can do to help get this along?

@msteindorfer
Copy link
Contributor Author

@kielgillard, this contribution will be actively worked on to be readied for inclusion. Stay tuned.

@msteindorfer msteindorfer force-pushed the capsule-collections branch from 1955a63 to bd6a864 Compare June 15, 2022 19:00
Further add missing items to the benchmark library.
Note, always tracking discardable result negatively impacts batch
use cases.
Necessary due to removal of unchecked initializer variants.
@lorentey lorentey marked this pull request as ready for review September 7, 2022 16:15
@lorentey lorentey self-requested a review as a code owner September 7, 2022 16:15
@lorentey lorentey changed the base branch from main to feature/PersistentCollections September 7, 2022 16:16
@lorentey
Copy link
Member

lorentey commented Sep 7, 2022

I'm landing this on a feature branch to start integration & performance work. 💯

@lorentey lorentey merged commit de5fad7 into apple:feature/PersistentCollections Sep 7, 2022
@lorentey lorentey added the HashTreeCollections Hash-array mapped prefix tree implementations label Nov 15, 2022
cgrindel-self-hosted-renovate bot referenced this pull request in cgrindel/rules_swift_package_manager Feb 8, 2024
…v1.1.0 (#906)

This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
|
[com_github_apple_swift_collections](https://github.com/apple/swift-collections)
| http_archive | minor | `1.0.6` -> `1.1.0` |

---

### Release Notes

<details>
<summary>apple/swift-collections
(com_github_apple_swift_collections)</summary>

###
[`v1.1.0`](https://github.com/apple/swift-collections/releases/tag/1.1.0):
Swift Collections 1.1.0

[Compare
Source](https://github.com/apple/swift-collections/compare/1.0.6...1.1.0)

This feature release adds a number of new data structure
implementations, along with minor changes to existing constructs.

##### New Data Structures

- `Heap` implements a min-max heap, backed by a native array.
(Contributed by [@&#8203;AquaGeek](https://github.com/AquaGeek))
- `BitSet` and `BitArray` are two alternate representations of a bitmap
type, backed by dynamically allocated storage. (Contributed by
[@&#8203;MahanazAtiqullah](https://github.com/MahanazAtiqullah))
- `TreeSet` and `TreeDictionary` are hashed collections implementing
Compressed Hash-Array Mapped Prefix Trees (CHAMP). They provide similar
API as `Set`/`Dictionary` in the Standard Library, but as persistent
data structures, supporting incremental mutations of shared instances
and efficient structural diffing. (Contributed by
[@&#8203;msteindorfer](https://github.com/msteindorfer))

##### Other Changes

- This version of the package can only be built using Swift 5.7 or
later.
- New methods: the `OrderedSet.isEqualSet` family of functions provide a
way to test that two containers contain the same members, ignoring the
order of elements.
([https://github.com/apple/swift-collections/issues/183](https://github.com/apple/swift-collections/issues/183),
[https://github.com/apple/swift-collections/pull/234](https://github.com/apple/swift-collections/pull/234))
- New method: `OrderedSet.filter` implements a version of the standard
filter operation that returns an `OrderedSet` instead of an `Array`.
([https://github.com/apple/swift-collections/pull/159](https://github.com/apple/swift-collections/pull/159))
- `debugDescription` implementations have been updated to follow Swift
best practice. (These are called by container types like `Array` to
print their elements, so they work best when they're succinct variants
of `description` that are suitable for embedding in structured output:
specifically, they must not produce unpaired delimiter characters
(`[`/`]`, `(`/`)`, `{`/`}`, `<`/`>` etc), raw top level commas,
semicolons, colons, unquoted strings etc. `debugDescription` should not
needlessly print type names etc.)

##### New Contributors

- [@&#8203;AquaGeek](https://github.com/AquaGeek) made their first
contribution in
[https://github.com/apple/swift-collections/pull/61](https://github.com/apple/swift-collections/pull/61)
- [@&#8203;ejmarchant](https://github.com/ejmarchant) made their first
contribution in
[https://github.com/apple/swift-collections/pull/82](https://github.com/apple/swift-collections/pull/82)
- [@&#8203;just-gull](https://github.com/just-gull) made their first
contribution in
[https://github.com/apple/swift-collections/pull/115](https://github.com/apple/swift-collections/pull/115)
- [@&#8203;jPaolantonio](https://github.com/jPaolantonio) made their
first contribution in
[https://github.com/apple/swift-collections/pull/121](https://github.com/apple/swift-collections/pull/121)
- [@&#8203;MahanazAtiqullah](https://github.com/MahanazAtiqullah) made
their first contribution in
[https://github.com/apple/swift-collections/pull/83](https://github.com/apple/swift-collections/pull/83)
- [@&#8203;hectormatos2011](https://github.com/hectormatos2011) made
their first contribution in
[https://github.com/apple/swift-collections/pull/155](https://github.com/apple/swift-collections/pull/155)
- [@&#8203;ktoso](https://github.com/ktoso) made their first
contribution in
[https://github.com/apple/swift-collections/pull/159](https://github.com/apple/swift-collections/pull/159)
- [@&#8203;CTMacUser](https://github.com/CTMacUser) made their first
contribution in
[https://github.com/apple/swift-collections/pull/116](https://github.com/apple/swift-collections/pull/116)
- [@&#8203;hassila](https://github.com/hassila) made their first
contribution in
[https://github.com/apple/swift-collections/pull/297](https://github.com/apple/swift-collections/pull/297)

Many thanks to our contributors for their great work (and patience)!

##### List of Pull Requests

**Full Changelog**:
apple/swift-collections@1.0.6...1.1.0

- Add a min-max heap implementation that can be used to back a priority
queue by [@&#8203;AquaGeek](https://github.com/AquaGeek) in
[https://github.com/apple/swift-collections/pull/61](https://github.com/apple/swift-collections/pull/61)
- \[benchmark] Review and extend Heap benchmarks by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/76](https://github.com/apple/swift-collections/pull/76)
- Add reference benchmarks for bit vector implementations by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/79](https://github.com/apple/swift-collections/pull/79)
- Fix Markdown link in README by
[@&#8203;AquaGeek](https://github.com/AquaGeek) in
[https://github.com/apple/swift-collections/pull/77](https://github.com/apple/swift-collections/pull/77)
- Fix documentation for types conforming to ExpressibleByArrayLiteral o…
by [@&#8203;ejmarchant](https://github.com/ejmarchant) in
[https://github.com/apple/swift-collections/pull/82](https://github.com/apple/swift-collections/pull/82)
- \[Heap] Performance tweaks by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/78](https://github.com/apple/swift-collections/pull/78)
- Fix typos: missing subscript parameters by
[@&#8203;ejmarchant](https://github.com/ejmarchant) in
[https://github.com/apple/swift-collections/pull/81](https://github.com/apple/swift-collections/pull/81)
- \[Heap] Update implementation details section in docs by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/84](https://github.com/apple/swift-collections/pull/84)
- Update CMakeLists.txt by
[@&#8203;compnerd](https://github.com/compnerd) in
[https://github.com/apple/swift-collections/pull/85](https://github.com/apple/swift-collections/pull/85)
- Stop depending on swift-collections-benchmark by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/86](https://github.com/apple/swift-collections/pull/86)
- \[OrderedDictionary] modifyValue → updateValue by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/91](https://github.com/apple/swift-collections/pull/91)
- Add Benchmarks package to workspace by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/93](https://github.com/apple/swift-collections/pull/93)
- \[OrderedDictionary] Deprecate `subscript(offset:)` for now by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/92](https://github.com/apple/swift-collections/pull/92)
- Documentation: Remove in-place mutation comments by
[@&#8203;ejmarchant](https://github.com/ejmarchant) in
[https://github.com/apple/swift-collections/pull/96](https://github.com/apple/swift-collections/pull/96)
- \[main] Freeze some types for consistency with their inlinable
initializers by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/98](https://github.com/apple/swift-collections/pull/98)
- Follow stdlib's leading underscore rule by
[@&#8203;ejmarchant](https://github.com/ejmarchant) in
[https://github.com/apple/swift-collections/pull/95](https://github.com/apple/swift-collections/pull/95)
- \[Heap] Disable heap tests in release builds by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/100](https://github.com/apple/swift-collections/pull/100)
- \[NFC] Merge release/1.0 to main by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/105](https://github.com/apple/swift-collections/pull/105)
- Merge `release/1.0` into `main` by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/108](https://github.com/apple/swift-collections/pull/108)
- \[README] Note that `Heap` hasn't been tagged yet & list other
enhancements in progress by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/109](https://github.com/apple/swift-collections/pull/109)
- PriorityQueueModule: remove `import Foundation` by
[@&#8203;compnerd](https://github.com/compnerd) in
[https://github.com/apple/swift-collections/pull/118](https://github.com/apple/swift-collections/pull/118)
- \[Heap] Remove Heap's `ascending` and `descending` views by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/119](https://github.com/apple/swift-collections/pull/119)
- \[Heap] Enable heap tests in optimized builds
([#&#8203;101](https://github.com/apple/swift-collections/issues/101))
by [@&#8203;just-gull](https://github.com/just-gull) in
[https://github.com/apple/swift-collections/pull/115](https://github.com/apple/swift-collections/pull/115)
- Update CMakeLists.txt by
[@&#8203;compnerd](https://github.com/compnerd) in
[https://github.com/apple/swift-collections/pull/122](https://github.com/apple/swift-collections/pull/122)
- Fix link to package internal documentation by
[@&#8203;jPaolantonio](https://github.com/jPaolantonio) in
[https://github.com/apple/swift-collections/pull/121](https://github.com/apple/swift-collections/pull/121)
- Merge release/1.0 to main by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/130](https://github.com/apple/swift-collections/pull/130)
- BitArray and BitSet data structures by
[@&#8203;MahanazAtiqullah](https://github.com/MahanazAtiqullah) in
[https://github.com/apple/swift-collections/pull/83](https://github.com/apple/swift-collections/pull/83)
- Sorted collections by [@&#8203;vihanb](https://github.com/vihanb) in
[https://github.com/apple/swift-collections/pull/65](https://github.com/apple/swift-collections/pull/65)
- Merge `release/1.0` to `main` by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/141](https://github.com/apple/swift-collections/pull/141)
- Remove Swift PM Artifacts to avoid Generated Schemes in Xcode by
[@&#8203;hectormatos2011](https://github.com/hectormatos2011) in
[https://github.com/apple/swift-collections/pull/155](https://github.com/apple/swift-collections/pull/155)
- Reinstate custom schemes under Utils/swift-collections.xcworkspace by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/156](https://github.com/apple/swift-collections/pull/156)
- \+OrderedSet add filter
[#&#8203;158](https://github.com/apple/swift-collections/issues/158)
by [@&#8203;ktoso](https://github.com/ktoso) in
[https://github.com/apple/swift-collections/pull/159](https://github.com/apple/swift-collections/pull/159)
- \[Xcode] Update schemes & file template by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/161](https://github.com/apple/swift-collections/pull/161)
- \[OrderedCollection] Use standard temp allocation facility, if
available by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/160](https://github.com/apple/swift-collections/pull/160)
- \[OrderedSet] Work around weird name lookup issue in compiler by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/162](https://github.com/apple/swift-collections/pull/162)
- \=OrderedSet.filter Attempt to optimize filter impl by
[@&#8203;ktoso](https://github.com/ktoso) in
[https://github.com/apple/swift-collections/pull/163](https://github.com/apple/swift-collections/pull/163)
- Force-inline \_modify accessors to work around a performance issue by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/165](https://github.com/apple/swift-collections/pull/165)
- Merge release/1.0 branch to main by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/172](https://github.com/apple/swift-collections/pull/172)
- Incubate persistent data structures by
[@&#8203;msteindorfer](https://github.com/msteindorfer) in
[https://github.com/apple/swift-collections/pull/31](https://github.com/apple/swift-collections/pull/31)
- Persistent collections updates by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/174](https://github.com/apple/swift-collections/pull/174)
- Persistent collections updates by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/175](https://github.com/apple/swift-collections/pull/175)
- Persistent collections updates (part 3) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/176](https://github.com/apple/swift-collections/pull/176)
- Persistent collections updates (part 4) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/177](https://github.com/apple/swift-collections/pull/177)
- \[OrderedDictionary] Tiny documentation fix by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/178](https://github.com/apple/swift-collections/pull/178)
- Persistent collections updates (part 5) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/179](https://github.com/apple/swift-collections/pull/179)
- Integrate PriorityQueueModule, BitCollections, PersistentCollections,
SortedCollections into release/1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/181](https://github.com/apple/swift-collections/pull/181)
- Persistent collections updates (part 6) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/180](https://github.com/apple/swift-collections/pull/180)
- Persistent collections updates (part 7) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/182](https://github.com/apple/swift-collections/pull/182)
- \[BitSet] Fix decoding format on 32 bit architectures by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/185](https://github.com/apple/swift-collections/pull/185)
- Persistent collections updates (part 8) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/184](https://github.com/apple/swift-collections/pull/184)
- Persistent collections updates (part 9) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/188](https://github.com/apple/swift-collections/pull/188)
- Add Sendable conformances to all public types by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/191](https://github.com/apple/swift-collections/pull/191)
- \[test] Check baseline API expectations for set-like types by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/192](https://github.com/apple/swift-collections/pull/192)
- Fleshing out `PersistentSet` by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/193](https://github.com/apple/swift-collections/pull/193)
- Rename `PriorityQueueModule` to `HeapModule` by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/194](https://github.com/apple/swift-collections/pull/194)
- \[BitSet] Fix invariant violation in member subscript by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/195](https://github.com/apple/swift-collections/pull/195)
- \[1.1.0] Bump minimum required Swift toolchain to 5.5 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/196](https://github.com/apple/swift-collections/pull/196)
- Restore support for building with Swift 5.5 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/198](https://github.com/apple/swift-collections/pull/198)
- Merge release/1.0 to release/1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/199](https://github.com/apple/swift-collections/pull/199)
- Update CMake configuration in preparation for 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/200](https://github.com/apple/swift-collections/pull/200)
- Update CMakeLists.txt by
[@&#8203;compnerd](https://github.com/compnerd) in
[https://github.com/apple/swift-collections/pull/202](https://github.com/apple/swift-collections/pull/202)
- \[1.1]\[SortedCollections] Remove for now by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/205](https://github.com/apple/swift-collections/pull/205)
- \[Heap] Change value of minimum or maximum element by
[@&#8203;CTMacUser](https://github.com/CTMacUser) in
[https://github.com/apple/swift-collections/pull/116](https://github.com/apple/swift-collections/pull/116)
- \[Heap] Prerelease preparations by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/210](https://github.com/apple/swift-collections/pull/210)
- Update README files by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/212](https://github.com/apple/swift-collections/pull/212)
- \[manifest] Exclude CMakeLists.txt; remove unnecessary path settings;
reindent file by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/213](https://github.com/apple/swift-collections/pull/213)
- Review and finalize (?) set relation predicates for 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/216](https://github.com/apple/swift-collections/pull/216)
- Merge.1.0→1.1 by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/217](https://github.com/apple/swift-collections/pull/217)
- Update CMake configuration by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/218](https://github.com/apple/swift-collections/pull/218)
- Cherry pick changes from main to release/1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/219](https://github.com/apple/swift-collections/pull/219)
- Fix unusual build problems by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/221](https://github.com/apple/swift-collections/pull/221)
- Review & update descriptions throughout the package by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/222](https://github.com/apple/swift-collections/pull/222)
- Review and finalize (?) binary set operations for 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/223](https://github.com/apple/swift-collections/pull/223)
- \[Xcode] Disable implicit dependencies by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/227](https://github.com/apple/swift-collections/pull/227)
- \[OrderedSet] Improve sequence-taking initializer by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/226](https://github.com/apple/swift-collections/pull/226)
- \[OrderedSet, BitSet] Fix custom mirror display style by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/225](https://github.com/apple/swift-collections/pull/225)
- Finalize persistent collections API by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/224](https://github.com/apple/swift-collections/pull/224)
- Start working on DocC support by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/228](https://github.com/apple/swift-collections/pull/228)
- Update CMake build configuration by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/230](https://github.com/apple/swift-collections/pull/230)
- \[PersistentSet] Iterator.next(): Make inlinable by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/233](https://github.com/apple/swift-collections/pull/233)
- \[SetAlgebra types] isEqual(to:) → isEqualSet(to:) by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/234](https://github.com/apple/swift-collections/pull/234)
- \[PersistentCollections] Doc & benchmark updates in preparation of API
review by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/235](https://github.com/apple/swift-collections/pull/235)
- Apply changes from in-progress review thread by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/237](https://github.com/apple/swift-collections/pull/237)
- \[ShareableHashedCollections] API Review: add missing `mutating`
keywords by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/238](https://github.com/apple/swift-collections/pull/238)
- \[Benchmarks] Split default huge library up into individual files, one
per type by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/240](https://github.com/apple/swift-collections/pull/240)
- \[ShareableHashedCollections] Add missing import by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/243](https://github.com/apple/swift-collections/pull/243)
- Unify unsafe bit set implementations by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/244](https://github.com/apple/swift-collections/pull/244)
- Fix warnings in development versions of Swift by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/245](https://github.com/apple/swift-collections/pull/245)
- \[HashTreeCollections] Change prefix `Shareable` to `Tree` by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/242](https://github.com/apple/swift-collections/pull/242)
- \[TreeDictionary] Fix in-place merge operation to properly update the
count by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/247](https://github.com/apple/swift-collections/pull/247)
- \[cmake] Update CMake configuration by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/249](https://github.com/apple/swift-collections/pull/249)
- Add not so experimental rope implementation by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/264](https://github.com/apple/swift-collections/pull/264)
- Fix off by one error in BitSet by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/267](https://github.com/apple/swift-collections/pull/267)
- Monomodule support by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/266](https://github.com/apple/swift-collections/pull/266)
- Expose a handful of BigString.Index methods by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/269](https://github.com/apple/swift-collections/pull/269)
- BitArray API refinements & additions by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/263](https://github.com/apple/swift-collections/pull/263)
- Make most of Rope inlinable by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/270](https://github.com/apple/swift-collections/pull/270)
- BigString: Fix String.Index.\_knownScalarAligned by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/272](https://github.com/apple/swift-collections/pull/272)
- Rope: Fix `Sendable` conformance by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/271](https://github.com/apple/swift-collections/pull/271)
- Require Swift 5.6 by [@&#8203;lorentey](https://github.com/lorentey)
in
[https://github.com/apple/swift-collections/pull/273](https://github.com/apple/swift-collections/pull/273)
- \[OrderedDictionary] Explicitly mention in documentation that
keys/values are ordered by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/275](https://github.com/apple/swift-collections/pull/275)
- \[HashCollections] Ensure `self` doesn’t get destroyed before we’re
done working with it by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/276](https://github.com/apple/swift-collections/pull/276)
- Remove obsolete swift(>=5.5)/swift(>=5.6) checks by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/277](https://github.com/apple/swift-collections/pull/277)
- \[Xcode] Update Xcode project by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/278](https://github.com/apple/swift-collections/pull/278)
- Minor rope updates by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/279](https://github.com/apple/swift-collections/pull/279)
- \[Rope] remove(at:): Fix assertion when removing the last item creates
a deficiency by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/280](https://github.com/apple/swift-collections/pull/280)
- Merge changes from release 1.0 to release 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/283](https://github.com/apple/swift-collections/pull/283)
- \[CollectionUtilities] Silence a warning on 32 bit platforms by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/286](https://github.com/apple/swift-collections/pull/286)
- \[BitSet] Fix a thinko in BitSet.isEqualSet by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/287](https://github.com/apple/swift-collections/pull/287)
- Grab bag of fixes for small test issues by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/288](https://github.com/apple/swift-collections/pull/288)
- \[Xcode] Set a code sign identity in the Xcode project by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/285](https://github.com/apple/swift-collections/pull/285)
- Rope: Fix trap when replaceSubrange is called on an empty rope by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/290](https://github.com/apple/swift-collections/pull/290)
- `Rope.find` returns a bogus remainder for the end position by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/291](https://github.com/apple/swift-collections/pull/291)
- Update TreeSet.md by [@&#8203;hassila](https://github.com/hassila)
in
[https://github.com/apple/swift-collections/pull/297](https://github.com/apple/swift-collections/pull/297)
- Fix CustomStringConvertible/CustomDebugStringConvertible conformances
by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/302](https://github.com/apple/swift-collections/pull/302)
- \[RopeModule] Fix issues in Swift's ABI stable dialect by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/318](https://github.com/apple/swift-collections/pull/318)
- \[CMake, Xcode] Update configurations for alternate build systems by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/319](https://github.com/apple/swift-collections/pull/319)
- \[RopeModule] Remove unnecessary typealiases by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/320](https://github.com/apple/swift-collections/pull/320)
- \[Heap] Improve type-level doc comment by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/326](https://github.com/apple/swift-collections/pull/326)
- \[Heap] insert(contentsOf:) Switch to Floyd’s if we’re inserting too
many items by [@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/327](https://github.com/apple/swift-collections/pull/327)
- \[1.1] build: support building in Debug mode on Windows by
[@&#8203;compnerd](https://github.com/compnerd) in
[https://github.com/apple/swift-collections/pull/336](https://github.com/apple/swift-collections/pull/336)
- Merge release/1.0 to release/1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/348](https://github.com/apple/swift-collections/pull/348)
- \[Heap] Convert min() and max() to properties by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/328](https://github.com/apple/swift-collections/pull/328)
- \[BitArray] Disable bitwise operators for now by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/353](https://github.com/apple/swift-collections/pull/353)
- \[Heap] Final(?) Heap API adjustments for 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/354](https://github.com/apple/swift-collections/pull/354)
- \[Benchmarks] Add Collection Equality Benchmarks by
[@&#8203;vanvoorden](https://github.com/vanvoorden) in
[https://github.com/apple/swift-collections/pull/351](https://github.com/apple/swift-collections/pull/351)
- Release preparations for 1.1 by
[@&#8203;lorentey](https://github.com/lorentey) in
[https://github.com/apple/swift-collections/pull/355](https://github.com/apple/swift-collections/pull/355)
- \[1.1] Fix typos by [@&#8203;lorentey](https://github.com/lorentey)
in
[https://github.com/apple/swift-collections/pull/357](https://github.com/apple/swift-collections/pull/357)
- \[TreeDictionary]\[Keys] Add Equatable and Hashable Conformance to
TreeDictionary.Keys by
[@&#8203;vanvoorden](https://github.com/vanvoorden) in
[https://github.com/apple/swift-collections/pull/352](https://github.com/apple/swift-collections/pull/352)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR is behind base branch, or you tick the
rebase/retry checkbox.

👻 **Immortal**: This PR will be recreated if closed unmerged. Get
[config help](https://github.com/renovatebot/renovate/discussions) if
that's undesired.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://github.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNi4xMDAuMCIsInVwZGF0ZWRJblZlciI6IjM2LjEwMC4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9-->

Co-authored-by: Self-hosted Renovate Bot <361546+cgrindel-self-hosted-renovate[bot]@users.noreply.github.enterprise.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
HashTreeCollections Hash-array mapped prefix tree implementations
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants