Add support for systemLibrary and executableTarget types #16
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR extends the PackageGeneratorPlugin to support all Swift Package Manager target types, addressing the limitation where only
.targetand.testTargetwere previously supported.Changes Made
Core Implementation
TargetTypeenum with support for all five target types:target,testTarget,executableTarget,systemLibrary, andbinaryTargetParsedPackagestruct to include atargetTypefield with backward-compatible auto-detection based on the existingisTestflagfakeTargetToSwiftCodeto generate appropriate Swift Package Manager target declarationsSmart Detection & Configuration
main.swiftfiletargetTypesconfiguration field allowing manual specification of target types for specific targets.executableproducts for executable targets and.libraryproducts for regular targets, while excluding system libraries and binary targets from product generationValidation & Error Handling
Documentation & Examples
Updated README with comprehensive documentation including:
targetTypesconfiguration optionExample Usage
{ "targetTypes": { "MyApp": "executableTarget", "SystemWrapper": "systemLibrary", "PrecompiledFramework": "binaryTarget" }, "targetsParameters": { "SystemWrapper": [ "pkgConfig: \"libxml-2.0\"", "providers: [.brew([\"libxml2\"]), .apt([\"libxml2-dev\"])]" ] } }This generates appropriate Swift Package Manager declarations:
Backward Compatibility
All existing configurations continue to work without modification. The implementation uses sensible defaults and maintains the existing behavior for projects that don't specify custom target types.
Fixes #8.
💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.