swift-collections: Fails to compile (Abort trap: 6)
Failed to compile using SPM.
TLDR (log file attached below)
Abort Trap: 6
<unknown>:0: error: fatal error encountered while reading from module 'OrderedCollections'; please file a bug report with your project and the crash log
<unknown>:0: note: module 'OrderedCollections' full misc version is '5.3.2(5.3.2)/Apple Swift version 5.3.2 (swiftlang-1200.0.45 clang-1200.0.32.28)'
*** DESERIALIZATION FAILURE (please include this section in any bug report) ***
result not found
Cross-reference to module 'OrderedCollections'
... OrderedSet
... in an extension in module 'OrderedCollections'
... Element
Information
- Package version: What tag or branch of swift-collections are you using?
0.0.1
- Platform version: Please tell us the version number of your operating system.
- macOS:
11.2.1 (20D74)
- Xcode:
12.4 (12D4e)
- Simulator/device: Doesn’t seem to matter
- macOS:
- Swift version: Paste the output of
swift --version
here.Apple Swift version 5.3.2 (swiftlang-1200.0.45 clang-1200.0.32.28)
Target: x86_64-apple-darwin20.3.0
EDIT: Adding more details today
~ > sw_vers system
ProductName: macOS
ProductVersion: 11.2.3
BuildVersion: 20D91
~ > uname -a system
Darwin ****.local 20.3.0 Darwin Kernel Version 20.3.0: Thu Jan 21 00:07:06 PST 2021; root:xnu-7195.81.3~1/RELEASE_X86_64 x86_64
~ > swift --version system
Apple Swift version 5.3.2 (swiftlang-1200.0.45 clang-1200.0.32.28)
Target: x86_64-apple-darwin20.3.0
~ > clang --version system
Apple clang version 12.0.0 (clang-1200.0.32.29)
Target: x86_64-apple-darwin20.3.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin`
Checklist
- If possible, I’ve reproduced the issue using the
main
branch of this package. - I’ve searched for existing GitHub issues.
Steps to Reproduce
- Create new iOS app in Xcode (just default code)
- Set up SPM to include this repo at v 0.0.1 (same for main)
- Build
- iOS app target fails (log file attached below)
- Collections target fails
- CollectionsBenchmark target fails
- DequeModule succeeds
- OrderedCollections target fails
- swift-collections-benchmark fails
- swift-collections-benchmark-Package succeeds
- swift-collections-Package fails
Expected behavior
Expect SPM to compile the targets in this repo
Actual behavior
Build fails. see attached build log
About this issue
- Original URL
- State: closed
- Created 3 years ago
- Reactions: 3
- Comments: 18 (15 by maintainers)
Update for anyone affected by this: I figured out a way to reliably reproduce this issue, and I’m developing a workaround that has minimal effect on future development.
The assertion is a (known, rare) issue with swiftc’s
-merge-modules
action (used by SwiftPM’s default debug configuration), which by itself would be easy to work around. However, the issue seems to be somehow only triggered by some specific orderings in which the OrderedSet source files happen to be listed in theSources/OrderedCollections/OrderedSet
directory: the assertion is reproducible with a small subset of orderings, but not others. If this is indeed the trigger, this neatly explains why this issue only hits certain machines, and why it’s so reliably reproducible on them. (If this was caused by something accidentally iterating over an unsorted hash table within SwiftPM or the compiler, then I’d expect the bug to trigger with the same frequency on all machines.)After we have the workaround in place, and we have a working swift-collection release, I’ll spend some time on tracking down the exact source of this nondeterminism, and fixing it so that future compilers won’t produce such unpleasant surprises. The order of directory entries should have no effect on the build process of a Swift package.
(The actual
-merge-modules
assertion is going to get fixed by replacing it with a better mechanism. This work is already underway, but it will take some time.)One amusing aspect of this is that filesystem directories are just another dictionary implementation – so it seems the
OrderedCollections
module, including theOrderedDictionary
implementation, may have been broken by some code accidentally relying on the order of items in an unordered dictionary – exactly the sort of thing thatOrderedDictionary
is designed to prevent.workaround solves it for me as well, thank you for tracking down that subtle issue and getting us a fix!
@lorentey it works! 🎉 good job!
OK, I merged a workaround for the build assertion.
The exact source of the nondeterminism still eludes me, so this is something of an “it works on my machine” situation, but I’ve let my shuffle-the-sources-then-do-a-clean-rebuild script run for a day now, and it is yet to surface any issues.
@Sajjon, @heckj: Thanks for all the helpful assistance (& patience!). When convenient, could you please check if the current
main
branch (as of commit 2d719d75a2065f213e58a5164384a3d2fcf9b59a) resolves the issue for you? If so, I’ll tag a release, and we can move on to happier matters. 😝@lorentey trivial PR: https://github.com/apple/swift-collections/pull/15
I just checked my system, and I’ve got the same list as @Sajjon.
@lorentey seems I get the same ouput that you get:
Want me to check something else?
Btw, seems like
Package.resolved
isn’t git commited? using latest commit on main,5a2a6841fd60d01ea2f0365314a062672304d0b1
when I runswift test
(CLI), git status shows change inPackage.resolved
:Awesome, great job @lorentey as always! I’m very much looking forward to playing around with Swift-Collections, but Benchmark package specifically!
Feel free to ping me if you want me to try some release candidate or something since I seem to hit this bug every time.
Have a nice weekend!
@lorentey some more details on my machine/environment
Machine
Environment
I hit the same - reported is as bug https://bugs.swift.org/browse/SR-14448.
Others have reported this too. Evidently it is only triggered on some unknown condition but when it is triggered, it remains easily reproducible. We’re looking into it!
https://forums.swift.org/t/compiler-failure-when-trying-to-build-the-new-swift-collections/47170
I get the same error, also using Xcode
12.4 (12D4e)
, but on macOS11.2.3 (20D91)
.