Skip to content
New issue

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

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

Already on GitHub? # to your account

return to a symbolgraph-extract based model, and pass -fmodule-map #408

Merged
merged 12 commits into from
Feb 13, 2025
Merged
5 changes: 3 additions & 2 deletions .github/workflows/test.yml → .github/workflows/Test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ jobs:
run: |
swift --version
swift build -c release \
--build-tests \
--product ssgc \
--explicit-target-dependency-import-check=error \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift/Block
Expand All @@ -71,7 +71,7 @@ jobs:
- name: Validate packages
run: |
swift test -c release \
--skip-build \
--no-parallel \
--filter SymbolGraphValidationTests \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift/Block
Expand Down Expand Up @@ -102,4 +102,5 @@ jobs:
- name: Validate packages
run: |
swift test -c release \
--no-parallel \
--filter SymbolGraphValidationTests
20 changes: 10 additions & 10 deletions Package.resolved
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
{
"originHash" : "e55ab1bd27ee2fd5913a1597116db214d4284763763234fedd67e53da4f4a1a7",
"originHash" : "7bb6ebf87d5168c153ffa23c4ba2aaac599d53da4735e0203ed072df49cdaa3c",
"pins" : [
{
"identity" : "indexstore-db",
"kind" : "remoteSourceControl",
"location" : "https://github.com/swiftlang/indexstore-db",
"state" : {
"branch" : "main",
"revision" : "b610e664675a7ae95276313725e80d3191e46dd1"
"revision" : "e08105badfbea2ff27cc4519c4ebb287b91c3cb8"
}
},
{
Expand All @@ -16,7 +16,7 @@
"location" : "https://github.com/apple/swift-argument-parser",
"state" : {
"branch" : "main",
"revision" : "41d58ffe702cfe7b00b2c4c6a6611d9d25a0adc1"
"revision" : "1248cc4bda29753883de0685ab350267a50f3f18"
}
},
{
Expand Down Expand Up @@ -60,8 +60,8 @@
"kind" : "remoteSourceControl",
"location" : "https://github.com/tayloraswift/swift-dom",
"state" : {
"revision" : "8d98e89a23f48e58d25b530dfabb3d00d3075da2",
"version" : "1.1.1"
"revision" : "9920611b7ba050912bf6e7f7083067aa14816bc0",
"version" : "1.1.2"
}
},
{
Expand Down Expand Up @@ -115,7 +115,7 @@
"location" : "https://github.com/swiftlang/swift-lmdb.git",
"state" : {
"branch" : "main",
"revision" : "35f243462cbb13f43f277e44ce15a7dbc07831a3"
"revision" : "29e6ac814f4f5138576bcb3d3995ed900aa8714e"
}
},
{
Expand All @@ -141,8 +141,8 @@
"kind" : "remoteSourceControl",
"location" : "https://github.com/apple/swift-nio",
"state" : {
"revision" : "ba72f31e11275fc5bf060c966cf6c1f36842a291",
"version" : "2.79.0"
"revision" : "dff45738d84a53dbc8ee899c306b3a7227f54f89",
"version" : "2.80.0"
}
},
{
Expand All @@ -159,8 +159,8 @@
"kind" : "remoteSourceControl",
"location" : "https://github.com/apple/swift-nio-ssl",
"state" : {
"revision" : "c7e95421334b1068490b5d41314a50e70bab23d1",
"version" : "2.29.0"
"revision" : "0cc3528ff48129d64ab9cab0b1cd621634edfc6b",
"version" : "2.29.3"
}
},
{
Expand Down
5 changes: 1 addition & 4 deletions Package.swift
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,6 @@ let package:Package = .init(
from: "1.33.0")),
.package(url: "https://github.com/apple/swift-markdown", .upToNextMinor(
from: "0.4.0")),
.package(url: "https://github.com/apple/swift-system", .upToNextMinor(
from: "1.4.0")),
.package(url: "https://github.com/apple/swift-syntax",
from: "600.0.1"),
],
Expand Down Expand Up @@ -651,10 +649,9 @@ let package:Package = .init(
.target(name: "SymbolGraphLinker"),
]),

.executableTarget(name: "SymbolGraphPartTests",
.testTarget(name: "SymbolGraphPartTests",
dependencies: [
.target(name: "SymbolGraphParts"),
.target(name: "Testing_"),
.product(name: "SystemIO", package: "swift-io"),
]),

Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

<strong><em><code>unidoc</code></em></strong>

[![ci build status](https://github.com/tayloraswift/swift-unidoc/actions/workflows/test.yml/badge.svg)](https://github.com/tayloraswift/swift-unidoc/actions/workflows/test.yml)
[![ci build status](https://github.com/tayloraswift/swift-unidoc/actions/workflows/Test.yml/badge.svg)](https://github.com/tayloraswift/swift-unidoc/actions/workflows/Test.yml)
[![ci build status](https://github.com/tayloraswift/swift-unidoc/actions/workflows/docs.yml/badge.svg)](https://github.com/tayloraswift/swift-unidoc/actions/workflows/docs.yml)
[![ci build status](https://github.com/tayloraswift/swift-unidoc/actions/workflows/Deploy.yml/badge.svg)](https://github.com/tayloraswift/swift-unidoc/actions/workflows/Deploy.yml)

Expand Down
63 changes: 32 additions & 31 deletions Scripts/Linux/GenerateTestSymbolGraphs
Original file line number Diff line number Diff line change
Expand Up @@ -3,42 +3,43 @@
set -e

swift --version
swift build \
--package-path TestModules \
-Xswiftc -emit-symbol-graph \
-Xswiftc -emit-symbol-graph-dir -Xswiftc SymbolGraphs \
-Xswiftc -symbol-graph-minimum-access-level -Xswiftc internal \
-Xswiftc -emit-extension-block-symbols \
-Xswiftc -include-spi-symbols \
-Xswiftc -skip-inherited-docs \
-Xswiftc -pretty-print \
-Xswiftc -swift-version -Xswiftc 6

swift build --package-path TestModules
swift package --package-path TestModules dump-package > TestModules/Package.swift.json

for TARGET in Swift _Concurrency
for output in SymbolGraphs Determinism
do
swift symbolgraph-extract \
-target x86_64-unknown-linux-gnu \
-minimum-access-level internal \
-output-dir TestModules/SymbolGraphs \
-skip-inherited-docs \
-emit-extension-block-symbols \
-include-spi-symbols \
-pretty-print \
-module-name $TARGET
mkdir -p TestModules/$output
for module in Swift _Concurrency _Differentiation
do
swift symbolgraph-extract \
-target x86_64-unknown-linux-gnu \
-minimum-access-level internal \
-output-dir TestModules/$output \
-skip-inherited-docs \
-emit-extension-block-symbols \
-include-spi-symbols \
-pretty-print \
-module-name $module
done
done

swift symbolgraph-extract \
-target x86_64-unknown-linux-gnu \
-minimum-access-level internal \
-output-dir TestModules/Determinism \
-skip-inherited-docs \
-emit-extension-block-symbols \
-include-spi-symbols \
-pretty-print \
-module-name Swift

for include in TestModules/.build/debug/Modules
do
for file in $include/*.swiftmodule
do
swift symbolgraph-extract \
-target x86_64-unknown-linux-gnu \
-minimum-access-level internal \
-output-dir TestModules/SymbolGraphs \
-skip-inherited-docs \
-emit-extension-block-symbols \
-include-spi-symbols \
-pretty-print \
-module-name $(basename $file .swiftmodule) \
-experimental-allowed-reexported-modules=ACL \
-I $include
done
done

.build/release/ssgc -u $SWIFT_INSTALLATION \
-n swift \
Expand Down
4 changes: 1 addition & 3 deletions Scripts/Linux/TestAll
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,7 @@ swift --version
swift build -c release \
--explicit-target-dependency-import-check=error \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift/Block \
--build-tests
-Xcxx -I$SWIFT_INSTALLATION/lib/swift/Block

Scripts/Linux/GenerateTestSymbolGraphs

Expand All @@ -17,7 +16,6 @@ swift test -c release \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift \
-Xcxx -I$SWIFT_INSTALLATION/lib/swift/Block \
--no-parallel \
--skip-build \
--skip SymbolGraphValidationTests \
--disable-testable-imports

Expand Down
25 changes: 25 additions & 0 deletions Sources/PackageGraphs/Packages/PackageNode.Densified.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import SymbolGraphs
import Symbols

extension PackageNode
{
@frozen public
struct Densified
{
public
let dependencies:[any Identifiable<Symbol.Package>]
public
let products:[SymbolGraph.Product]
public
let modules:[SymbolGraph.Module]

init(dependencies:[any Identifiable<Symbol.Package>],
products:[SymbolGraph.Product],
modules:[SymbolGraph.Module])
{
self.dependencies = dependencies
self.products = products
self.modules = modules
}
}
}
92 changes: 47 additions & 45 deletions Sources/PackageGraphs/Packages/PackageNode.swift
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@ struct PackageNode:Identifiable
public
var dependencies:[any Identifiable<Symbol.Package>]

/// The name of the snippets directory.
public
var snippets:String
public
var products:[SymbolGraph.Product]
public
Expand All @@ -26,13 +29,15 @@ struct PackageNode:Identifiable
@inlinable public
init(id:Symbol.Package,
dependencies:[any Identifiable<Symbol.Package>],
snippets:String,
products:[SymbolGraph.Product],
modules:[SymbolGraph.Module],
exclude:[[String]],
root:Symbol.FileBase)
{
self.id = id
self.dependencies = dependencies
self.snippets = snippets
self.products = products
self.modules = modules
self.exclude = exclude
Expand All @@ -42,75 +47,72 @@ struct PackageNode:Identifiable
extension PackageNode
{
public consuming
func flattened(dependencies:[PackageNode]) throws -> Self
{
try self.flatten(dependencies: dependencies)
return self
}

mutating
func flatten(dependencies:[PackageNode]) throws
func joined(with dependencies:[PackageNode]) throws -> ([Densified], Densified)
{
var nodes:DigraphExplorer<ProductNode>.Nodes = .init()
for package:PackageNode in dependencies
let nodes:DigraphExplorer<ProductNode>.Nodes = try dependencies.reduce(into: .init())
{
for product:SymbolGraph.Product in package.products
for product:SymbolGraph.Product in $1.products
{
try nodes.index(.init(id: .init(name: product.name, package: package.id),
predecessors: product.dependencies))
let id:Symbol.Product = .init(name: product.name, package: $1.id)
try $0.index(.init(id: id, predecessors: product.dependencies))
}
}

let densifiedUpstream:[Densified] = try dependencies.map
{
try $0.densified(products: nodes, packages: dependencies)
}
let densifiedSink:Densified = try self.densified(
products: nodes,
packages: dependencies)

return (densifiedUpstream, densifiedSink)
}

private consuming
func densified(
products:DigraphExplorer<ProductNode>.Nodes,
packages:[PackageNode]) throws -> Densified
{
var cache:[Symbol.Product: [Symbol.Product]] = [:]

self.products = try self.products.map
for i:Int in self.products.indices
{
.init(name: $0.name, type: $0.type,
dependencies: try nodes.included(by: $0.dependencies, cache: &cache),
cultures: $0.cultures)
try
{
$0 = try products.included(by: $0, cache: &cache)
} (&self.products[i].dependencies)
}
self.modules = try self.modules.map
for i:Int in self.modules.indices
{
.init(name: $0.name, type: $0.type, dependencies: .init(
products: try nodes.included(by: $0.dependencies.products,
cache: &cache),
modules: $0.dependencies.modules),
location: $0.location)
try
{
$0 = try products.included(by: $0, cache: &cache)
} (&self.modules[i].dependencies.products)
}

let declared:[Symbol.Package: any Identifiable<Symbol.Package>] =
self.dependencies.reduce(into: [:]) { $0[$1.id] = $1 }

let actuallyUsed:Set<Symbol.Package> = cache.values.reduce(into: [])
let dependenciesActuallyUsed:Set<Symbol.Package> = cache.values.reduce(into: [])
{
for product:Symbol.Product in $1
{
$0.insert(product.package)
}
}

let directedEdges:[(Symbol.Package, Symbol.Package)] = dependencies.reduce(into: [])
let dependenciesDeclared:[Symbol.Package: any Identifiable<Symbol.Package>] =
self.dependencies.reduce(into: [:]) { $0[$1.id] = $1 }

let dependenciesBlamed:[any Identifiable<Symbol.Package>] = packages.reduce(
into: [])
{
for dependency:any Identifiable<Symbol.Package> in $1.dependencies
if dependenciesActuallyUsed.contains($1.id)
{
$0.append((dependency.id, $1.id))
$0.append(dependenciesDeclared[$1.id] ?? TransitiveDependency.init(id: $1.id))
}
}

// FIXME: in Swift 6, it will be legal to have cyclic package dependencies!
guard
let dependenciesOrdered:[PackageNode] = dependencies.sortedTopologically(
by: directedEdges)
else
{
throw DigraphCycleError<PackageNode>.init()
}

self.dependencies = dependenciesOrdered.compactMap
{
actuallyUsed.contains($0.id)
? declared[$0.id] ?? TransitiveDependency.init(id: $0.id)
: nil
}
return .init(dependencies: dependenciesBlamed,
products: self.products,
modules: self.modules)
}
}
Loading