Add '--swift-package-sources-path' option support #211
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.
Description
Xcode and
xcodebuild
resolve and check out Swift packages sources before building a project every time it's necessary. Sources include license files as well. ThusLicensePlist
may rely not only on GitHub API but directly on the sources.Motivation
In the sandbox mode, when the tool is used by the Swift package build tool plugin there is no way to use network requests. Using cloned sources is a workaround in this case.
Another example is a CI environment that builds apps with
xcodebuild
. The CI may specify a folder for cloned Swift package sources and use this folder for acknowledgments generation.Implementation
Reading licenses
Packages hold licenses in "LICENSE", "License", "LICENSE.md", or "LICENSE.txt" files. To read them the tool needs two pieces of data:
As a path to cloned sources, the tool uses
--package-sources-path
(or--swift-package-sources-path
) parameter.All possible license file names are also defined as a parameter whose name is
--license-file-names
. To simplify different path extensions let's support asterisks in names, ex.LICENSE.*
.Then if the path is specified
PlistInfo
reads licenses from disk instead of using GitHub API.Name specified
One another feature that accesses GitHub is resolving
nameSpecified
. As suggested above, if the tool knows cloned sources path let's not fetchPackage.resolved
from GitHub but read it from disk.Restriction
Unlike CocoaPods, Swift packages don't provide reach metadata. There are a couple of discussions on the swift forum about that but no proposals yet. Thus there is no simple way to determine the license type.
I was thinking about:
All these approaches involve too much overhead, in my opinion.
AFAIK, license type is required to filter out licenses using the
exclude
feature. So I added a warning that this feature is not supported in combination with--package-sources-path
.Fixes
--package-sources-path
and--license-file-names
,readCheckedOutLicenses()
method toPlistInfo.swift
,readFromDisk()
method toGitHubLicense.swift
,