The Package.swift looks like this:
// swift-tools-version:5.0
// The swift-tools-version declares the minimum version of Swift required to build this package.
import PackageDescription
let package = Package(
name: "SDWebImage",
platforms: [
.macOS(.v10_10),
.iOS(.v8),
.tvOS(.v9),
.watchOS(.v2)
],
products: [
// Products define the executables and libraries produced by a package, and make them visible to other packages.
.library(
name: "SDWebImage",
targets: ["SDWebImage"]),
.library(
name: "SDWebImageMapKit",
targets: ["SDWebImageMapKit"])
],
dependencies: [
// Dependencies declare other packages that this package depends on.
// .package(url: /* package url */, from: "1.0.0"),
],
targets: [
// Targets are the basic building blocks of a package. A target can define a module or a test suite.
// Targets can depend on other targets in this package, and on products in packages which this package depends on.
.target(
name: "SDWebImage",
dependencies: [],
path: ".",
sources: ["SDWebImage/Core", "SDWebImage/Private"],
publicHeadersPath: "SDWebImage/Core",
cSettings: [
.headerSearchPath("SDWebImage/Core"),
.headerSearchPath("SDWebImage/Private")
]
),
.target(
name: "SDWebImageMapKit",
dependencies: ["SDWebImage"],
path: ".",
sources: ["SDWebImage/MapKit"],
publicHeadersPath: "SDWebImage/MapKit",
cSettings: [
.headerSearchPath("SDWebImage/Core"),
.headerSearchPath("SDWebImage/Private")
]
)
]
)
The folder structure looks like this:
- SDWebImage
-- Core
--- xxx.h
--- xxx.m
-- Private
--- yyy.h
--- yyy.m
-- MapKit
--- MKAnnotationView+WebCache.h
--- MKAnnotationView+WebCache.m
This Package.swift DSL previously works fine on Xcode 11.3.1 via SwiftPM, however, when using Xcode 11.4-Beta2, this through error with:
target 'SDWebImageMapKit' referenced in product 'SDWebImageMapKit' is empty
.
As I imagine, the SDWebImageMapKit
should match the MKAnnotationView+WebCache.h/.m
files. Does the category only source files cause the issue ?
I've already fired Apple Feedback report via FB7571208, but I remember that Xcode use the SwiftPM dynamic lib, so they should share the same codebase. Is some internel changes break this ?