Build Information
Successful build of SwiftTerm, reference v1.5.1 (0b8d99
), with Swift 6.0 for macOS (SPM) on 9 Aug 2025 07:34:34 UTC.
Swift 6 data race errors: 0
Build Command
env DEVELOPER_DIR=/Applications/Xcode-16.2.0.app xcrun swift build --arch arm64
Build Log
========================================
RunAll
========================================
Builder version: 4.65.0
Interrupt handler set up.
========================================
Checkout
========================================
Clone URL: https://github.com/migueldeicaza/SwiftTerm.git
Reference: v1.5.1
Initialized empty Git repository in /Users/admin/builder/spi-builder-workspace/.git/
From https://github.com/migueldeicaza/SwiftTerm
* tag v1.5.1 -> FETCH_HEAD
HEAD is now at 0b8d99b Do not compile HeadlessTerminal on Windows as it uses LocalProcess, we should upgrade at some point to the new subprocess API in Swift
Cloned https://github.com/migueldeicaza/SwiftTerm.git
Revision (git rev-parse @):
0b8d99bd19b694df44e1ccaa3891309719d34330
SUCCESS checkout https://github.com/migueldeicaza/SwiftTerm.git at v1.5.1
========================================
Build
========================================
Selected platform: macosSpm
Swift version: 6.0
Building package at path: $PWD
https://github.com/migueldeicaza/SwiftTerm.git
Running build ...
env DEVELOPER_DIR=/Applications/Xcode-16.2.0.app xcrun swift build --arch arm64
[1/1] Compiling plugin GenerateDoccReference
[2/2] Compiling plugin GenerateManual
Building for debugging...
[2/16] Write sources
[4/16] Write SwiftTermFuzz-entitlement.plist
[8/16] Write termcast-entitlement.plist
[9/16] Write swift-version-5BDAB9E9C0126B9D.txt
[11/55] Emitting module ArgumentParserToolInfo
[12/55] Compiling ArgumentParserToolInfo ToolInfo.swift
[13/101] Compiling ArgumentParser CommandConfiguration.swift
[14/101] Compiling ArgumentParser CommandGroup.swift
[15/101] Compiling ArgumentParser EnumerableFlag.swift
[16/101] Compiling ArgumentParser ExpressibleByArgument.swift
[17/101] Compiling ArgumentParser ParsableArguments.swift
[18/105] Compiling ArgumentParser InputKey.swift
[19/105] Compiling ArgumentParser InputOrigin.swift
[20/105] Compiling ArgumentParser Name.swift
[21/105] Compiling ArgumentParser Parsed.swift
[22/105] Compiling ArgumentParser ParsedValues.swift
[23/105] Emitting module ArgumentParser
[24/105] Compiling ArgumentParser SequenceExtensions.swift
[25/105] Compiling ArgumentParser StringExtensions.swift
[26/105] Compiling ArgumentParser SwiftExtensions.swift
[27/105] Compiling ArgumentParser Tree.swift
[28/105] Compiling ArgumentParser CodingKeyValidator.swift
[29/105] Compiling ArgumentParser NonsenseFlagsValidator.swift
[30/105] Compiling ArgumentParser ParsableArgumentsValidation.swift
[31/105] Compiling ArgumentParser PositionalArgumentsValidator.swift
[32/105] Compiling ArgumentParser UniqueNamesValidator.swift
[33/105] Compiling ArgumentParser BashCompletionsGenerator.swift
[34/105] Compiling ArgumentParser CompletionsGenerator.swift
[35/105] Compiling ArgumentParser FishCompletionsGenerator.swift
[36/105] Compiling ArgumentParser ZshCompletionsGenerator.swift
[37/105] Compiling ArgumentParser Argument.swift
[38/105] Compiling ArgumentParser ArgumentDiscussion.swift
[39/105] Compiling ArgumentParser ArgumentHelp.swift
[40/105] Compiling ArgumentParser ArgumentVisibility.swift
[41/105] Compiling ArgumentParser CompletionKind.swift
[42/105] Compiling ArgumentParser Errors.swift
[43/105] Compiling ArgumentParser Flag.swift
[44/105] Compiling ArgumentParser NameSpecification.swift
[45/105] Compiling ArgumentParser Option.swift
[46/105] Compiling ArgumentParser OptionGroup.swift
[47/105] Compiling ArgumentParser AsyncParsableCommand.swift
[48/105] Compiling ArgumentParser MessageInfo.swift
[49/105] Compiling ArgumentParser UsageGenerator.swift
[50/105] Compiling ArgumentParser CollectionExtensions.swift
[51/105] Compiling ArgumentParser Mutex.swift
[52/105] Compiling ArgumentParser Platform.swift
[53/105] Compiling ArgumentParser ParserError.swift
[54/105] Compiling ArgumentParser SplitArguments.swift
[55/105] Compiling ArgumentParser DumpHelpGenerator.swift
[56/105] Compiling ArgumentParser HelpCommand.swift
[57/105] Compiling ArgumentParser HelpGenerator.swift
[58/105] Compiling ArgumentParser ParsableCommand.swift
[59/105] Compiling ArgumentParser ArgumentDecoder.swift
[60/105] Compiling ArgumentParser ArgumentDefinition.swift
[61/105] Compiling ArgumentParser ArgumentSet.swift
[62/105] Compiling ArgumentParser CommandParser.swift
[67/109] Emitting module SwiftTerm
[68/109] Compiling SwiftTerm iOSKeyboardView.swift
[69/109] Compiling SwiftTerm iOSTerminalView.swift
[70/109] Compiling SwiftTerm iOSTextInput.swift
[71/109] Compiling SwiftTerm iOSTextStorage.swift
/Users/admin/builder/spi-builder-workspace/Sources/SwiftTerm/Apple/AppleTerminalView.swift:473:21: warning: variable 'extra' was never mutated; consider changing to 'let' constant
471 | // last row
472 | if startRow < row && endRow == row {
473 | var extra = endCol == terminal.cols-1 ? 1 : 0
| `- warning: variable 'extra' was never mutated; consider changing to 'let' constant
474 | selectionRange = NSRange(location: 0, length: endCol + extra)
475 | }
/Users/admin/builder/spi-builder-workspace/Sources/SwiftTerm/Apple/AppleTerminalView.swift:473:21: warning: variable 'extra' was never mutated; consider changing to 'let' constant
471 | // last row
472 | if startRow < row && endRow == row {
473 | var extra = endCol == terminal.cols-1 ? 1 : 0
| `- warning: variable 'extra' was never mutated; consider changing to 'let' constant
474 | selectionRange = NSRange(location: 0, length: endCol + extra)
475 | }
/Users/admin/builder/spi-builder-workspace/Sources/SwiftTerm/Apple/AppleTerminalView.swift:473:21: warning: variable 'extra' was never mutated; consider changing to 'let' constant
471 | // last row
472 | if startRow < row && endRow == row {
473 | var extra = endCol == terminal.cols-1 ? 1 : 0
| `- warning: variable 'extra' was never mutated; consider changing to 'let' constant
474 | selectionRange = NSRange(location: 0, length: endCol + extra)
475 | }
/Users/admin/builder/spi-builder-workspace/Sources/SwiftTerm/Apple/AppleTerminalView.swift:473:21: warning: variable 'extra' was never mutated; consider changing to 'let' constant
471 | // last row
472 | if startRow < row && endRow == row {
473 | var extra = endCol == terminal.cols-1 ? 1 : 0
| `- warning: variable 'extra' was never mutated; consider changing to 'let' constant
474 | selectionRange = NSRange(location: 0, length: endCol + extra)
475 | }
[104/116] Compiling SwiftTermFuzz main.swift
[105/116] Emitting module SwiftTermFuzz
[105/116] Write Objects.LinkFileList
[107/116] Compiling Termcast main.swift
[108/116] Compiling Termcast AsciicastFormat.swift
[109/116] Emitting module Termcast
[110/116] Compiling Termcast TermcastPlayer.swift
[111/116] Compiling Termcast TermcastRecorder.swift
/Users/admin/builder/spi-builder-workspace/Sources/Termcast/TermcastRecorder.swift:265:17: warning: result of call to 'fcntl' is unused
263 | // Use blocking read with a timeout by setting stdin to non-blocking temporarily
264 | let originalFlags = fcntl(STDIN_FILENO, F_GETFL)
265 | fcntl(STDIN_FILENO, F_SETFL, originalFlags | O_NONBLOCK)
| `- warning: result of call to 'fcntl' is unused
266 |
267 | var buffer = [UInt8](repeating: 0, count: 1)
/Users/admin/builder/spi-builder-workspace/Sources/Termcast/TermcastRecorder.swift:271:17: warning: result of call to 'fcntl' is unused
269 |
270 | // Restore blocking mode
271 | fcntl(STDIN_FILENO, F_SETFL, originalFlags)
| `- warning: result of call to 'fcntl' is unused
272 |
273 | if bytesRead > 0 {
[111/116] Write Objects.LinkFileList
[112/116] Linking SwiftTermFuzz
[113/116] Applying SwiftTermFuzz
[114/116] Linking termcast
[115/116] Applying termcast
Build complete! (18.78s)
Fetching https://github.com/apple/swift-argument-parser
[1/15630] Fetching swift-argument-parser
Fetched https://github.com/apple/swift-argument-parser from cache (1.51s)
Computing version for https://github.com/apple/swift-argument-parser
Computed https://github.com/apple/swift-argument-parser at 1.6.1 (0.47s)
Creating working copy for https://github.com/apple/swift-argument-parser
Working copy of https://github.com/apple/swift-argument-parser resolved at 1.6.1
warning: 'spi-builder-workspace': found 1 file(s) which are unhandled; explicitly declare them as resources or exclude from the target
/Users/admin/builder/spi-builder-workspace/Sources/SwiftTerm/Mac/README.md
Build complete.
{
"dependencies" : [
{
"identity" : "swift-argument-parser",
"requirement" : {
"range" : [
{
"lower_bound" : "1.0.0",
"upper_bound" : "2.0.0"
}
]
},
"type" : "sourceControl",
"url" : "https://github.com/apple/swift-argument-parser"
}
],
"manifest_display_name" : "SwiftTerm",
"name" : "SwiftTerm",
"path" : "/Users/admin/builder/spi-builder-workspace",
"platforms" : [
{
"name" : "ios",
"version" : "13.0"
},
{
"name" : "macos",
"version" : "10.15"
},
{
"name" : "tvos",
"version" : "13.0"
},
{
"name" : "visionos",
"version" : "1.0"
}
],
"products" : [
{
"name" : "SwiftTermFuzz",
"targets" : [
"SwiftTermFuzz"
],
"type" : {
"executable" : null
}
},
{
"name" : "termcast",
"targets" : [
"Termcast"
],
"type" : {
"executable" : null
}
},
{
"name" : "SwiftTerm",
"targets" : [
"SwiftTerm"
],
"type" : {
"library" : [
"automatic"
]
}
}
],
"swift_languages_versions" : [
"5"
],
"targets" : [
{
"c99name" : "Termcast",
"module_type" : "SwiftTarget",
"name" : "Termcast",
"path" : "Sources/Termcast",
"product_dependencies" : [
"ArgumentParser"
],
"product_memberships" : [
"termcast"
],
"sources" : [
"AsciicastFormat.swift",
"TermcastPlayer.swift",
"TermcastRecorder.swift",
"main.swift"
],
"target_dependencies" : [
"SwiftTerm"
],
"type" : "executable"
},
{
"c99name" : "SwiftTermTests",
"module_type" : "SwiftTarget",
"name" : "SwiftTermTests",
"path" : "Tests/SwiftTermTests",
"sources" : [
"ColorTests.swift",
"FuzzerTests.swift",
"ImageTests.swift",
"MeanTests.swift",
"Memory.swift",
"OscTests.swift",
"PerformanceTest.swift",
"ReflowTests.swift",
"SelectionTests.swift",
"SwiftTermTests.swift",
"UnicodeTests.swift",
"XCTestManifests.swift"
],
"target_dependencies" : [
"SwiftTerm"
],
"type" : "test"
},
{
"c99name" : "SwiftTermFuzz",
"module_type" : "SwiftTarget",
"name" : "SwiftTermFuzz",
"path" : "Sources/SwiftTermFuzz",
"product_memberships" : [
"SwiftTermFuzz"
],
"sources" : [
"main.swift"
],
"target_dependencies" : [
"SwiftTerm"
],
"type" : "executable"
},
{
"c99name" : "SwiftTerm",
"module_type" : "SwiftTarget",
"name" : "SwiftTerm",
"path" : "Sources/SwiftTerm",
"product_memberships" : [
"SwiftTermFuzz",
"termcast",
"SwiftTerm"
],
"sources" : [
"Apple/AppleTerminalView.swift",
"Apple/CaretView.swift",
"Apple/Extensions.swift",
"Apple/TerminalViewDelegate.swift",
"Buffer.swift",
"BufferLine.swift",
"BufferSet.swift",
"CharData.swift",
"CharSets.swift",
"CircularList.swift",
"Colors.swift",
"EscapeSequenceParser.swift",
"EscapeSequences.swift",
"ExternsionsTerminal.swift",
"File.swift",
"HeadlessTerminal.swift",
"Line.swift",
"LocalProcess.swift",
"Mac/MacAccessibilityService.swift",
"Mac/MacCaretView.swift",
"Mac/MacDebugView.swift",
"Mac/MacExtensions.swift",
"Mac/MacLocalTerminalView.swift",
"Mac/MacTerminalView.swift",
"Position.swift",
"Pty.swift",
"SearchService.swift",
"SelectionService.swift",
"SixelDcsHandler.swift",
"Terminal.swift",
"TerminalOptions.swift",
"Utilities.swift",
"iOS/iOSAccessoryView.swift",
"iOS/iOSCaretView.swift",
"iOS/iOSDoubleButton.swift",
"iOS/iOSExtensions.swift",
"iOS/iOSKeyboardView.swift",
"iOS/iOSTerminalView.swift",
"iOS/iOSTextInput.swift",
"iOS/iOSTextStorage.swift"
],
"type" : "library"
}
],
"tools_version" : "5.9"
}
Done.