This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.1.
This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.7.
To start using it, add the `swiftpm` plugin to your `plugins` array in `~/.zshrc`:
To start using it, add the `swiftpm` plugin to your `plugins` array in `~/.zshrc`:
'--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/'
'--cache-path[Specify the shared cache directory path]:cache-path:_files -/'
'--config-path[Specify the shared configuration directory path]:config-path:_files -/'
'--security-path[Specify the shared security directory path]:security-path:_files -/'
'--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/'
'--enable-dependency-cache[Use a shared cache when fetching dependencies]'
'--disable-dependency-cache[Use a shared cache when fetching dependencies]'
'(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]'
'--skip-update[Skip updating dependencies from their remote during a resolution]'
'--disable-scm-to-registry-transformation[disable source control to registry transformation]'
'--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]'
'--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]'
'(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)'
'-Xcc[Pass flag through to all C compiler invocations]:Xcc:'
'-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:'
'-Xlinker[Pass flag through to all linker invocations]:Xlinker:'
'-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:'
'--triple:triple:'
'--sdk:sdk:_files -/'
'--toolchain:toolchain:_files -/'
'--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:'
'--auto-index-store[Enable or disable indexing-while-building feature]'
'--enable-index-store[Enable or disable indexing-while-building feature]'
'--disable-index-store[Enable or disable indexing-while-building feature]'
'--enable-parseable-module-interfaces'
'(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:'
'--emit-swift-module-separately'
'--use-integrated-swift-driver'
'--experimental-explicit-module-build'
'--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]'
'--build-system:build-system:(native xcode)'
'--enable-dead-strip[Disable/enable dead code stripping by the linker]'
'--disable-dead-strip[Disable/enable dead code stripping by the linker]'
'--static-swift-stdlib[Link Swift stdlib statically]'
'--no-static-swift-stdlib[Link Swift stdlib statically]'
'--repl[Launch Swift REPL for the package]'
'--debugger[Launch the executable in a debugger session]'
'--run[Launch the executable with the provided arguments]'
'--skip-build[Skip building the executable product]'
'--build-tests[Build both source and test targets]'
':executable:{local -a list; list=(${(f)"$(swift package completion-tool list-executables)"}); _describe '''' list}'
':arguments:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
# Generates completions for swift build
#
# In the final compdef file, set the following file header:
#
# #compdef _swift_build
# local context state state_descr line
# typeset -A opt_args
_swift_build() {
_swift_build() {
arguments=(
integer ret=1
"-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: "
local -a args
"-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: "
args+=(
"-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: "
'--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/'
"-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: "
'--cache-path[Specify the shared cache directory path]:cache-path:_files -/'
"(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}"
'--config-path[Specify the shared configuration directory path]:config-path:_files -/'
"--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]"
'--disable-prefetching'
"--enable-parseable-module-interfaces[]"
'(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]'
"--trace-resolver[]"
'--skip-update[Skip updating dependencies from their remote during a resolution]'
"(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: "
'--disable-scm-to-registry-transformation[disable source control to registry transformation]'
"--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]"
'--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]'
"--build-tests[Build both source and test targets]"
'--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]'
"--product[Build the specified product]:Build the specified product: "
'(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)'
"--target[Build the specified target]:Build the specified target: "
'-Xcc[Pass flag through to all C compiler invocations]:Xcc:'
"--show-bin-path[Print the binary output path]"
'-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:'
)
'-Xlinker[Pass flag through to all linker invocations]:Xlinker:'
_arguments $arguments && return
'-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:'
}
'--triple:triple:'
'--sdk:sdk:_files -/'
# Generates completions for swift run
'--toolchain:toolchain:_files -/'
#
'--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:'
# In the final compdef file, set the following file header:
'--auto-index-store[Enable or disable indexing-while-building feature]'
#
'--enable-index-store[Enable or disable indexing-while-building feature]'
# #compdef _swift_run
'--disable-index-store[Enable or disable indexing-while-building feature]'
# local context state state_descr line
'--enable-parseable-module-interfaces'
# typeset -A opt_args
'(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:'
_swift_run() {
'--emit-swift-module-separately'
arguments=(
'--use-integrated-swift-driver'
":The executable to run:_swift_executable"
'--experimental-explicit-module-build'
"-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: "
'--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]'
"-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: "
'--build-system:build-system:(native xcode)'
"-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: "
'--enable-dead-strip[Disable/enable dead code stripping by the linker]'
"-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: "
'--disable-dead-strip[Disable/enable dead code stripping by the linker]'
"(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}"
'--static-swift-stdlib[Link Swift stdlib statically]'
"--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]"
'--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/'
"--enable-parseable-module-interfaces[]"
'--cache-path[Specify the shared cache directory path]:cache-path:_files -/'
"--trace-resolver[]"
'--config-path[Specify the shared configuration directory path]:config-path:_files -/'
"(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: "
'--security-path[Specify the shared security directory path]:security-path:_files -/'
"--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]"
'--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/'
"--skip-build[Skip building the executable product]"
'--enable-dependency-cache[Use a shared cache when fetching dependencies]'
"--build-tests[Build both source and test targets]"
'--disable-dependency-cache[Use a shared cache when fetching dependencies]'
'(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]'
'--skip-update[Skip updating dependencies from their remote during a resolution]'
'--disable-scm-to-registry-transformation[disable source control to registry transformation]'
'--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]'
'--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]'
'(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)'
'-Xcc[Pass flag through to all C compiler invocations]:Xcc:'
'-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:'
'-Xlinker[Pass flag through to all linker invocations]:Xlinker:'
'-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:'
'--triple:triple:'
'--sdk:sdk:_files -/'
'--toolchain:toolchain:_files -/'
'--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:'
'--auto-index-store[Enable or disable indexing-while-building feature]'
'--enable-index-store[Enable or disable indexing-while-building feature]'
'--disable-index-store[Enable or disable indexing-while-building feature]'
'--enable-parseable-module-interfaces'
'(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:'
'--emit-swift-module-separately'
'--use-integrated-swift-driver'
'--experimental-explicit-module-build'
'--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]'
'--build-system:build-system:(native xcode)'
'--enable-dead-strip[Disable/enable dead code stripping by the linker]'
'--disable-dead-strip[Disable/enable dead code stripping by the linker]'
'--static-swift-stdlib[Link Swift stdlib statically]'
'--no-static-swift-stdlib[Link Swift stdlib statically]'
'--skip-build[Skip building the test target]'
'--parallel[Run the tests in parallel.]'
'--num-workers[Number of tests to execute in parallel.]:num-workers:'
'(--list-tests -l)'{--list-tests,-l}'[Lists test methods in specifier format]'
'--show-codecov-path[Print the path of the exported code coverage JSON file]'
'(-s --specifier)'{-s,--specifier}':specifier:'
'--filter[Run test cases matching regular expression, Format: <test-target>.<test-case> or <test-target>.<test-case>/<test>]:filter:'
'--skip[Skip test cases matching regular expression, Example: --skip PerformanceTests]:skip:'
'--xunit-output[Path where the xUnit xml file should be generated.]:xunit-output:_files -/'
'--test-product[Test the specified product.]:test-product:'
'--enable-testable-imports[Enable or disable testable imports. Enabled by default.]'
'--disable-testable-imports[Enable or disable testable imports. Enabled by default.]'
'--enable-code-coverage[Enable code coverage]'
'--disable-code-coverage[Enable code coverage]'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
_arguments -w -s -S $args[@] && ret=0
return ret
}
_swift_package() {
_swift_package() {
arguments=(
integer ret=1
"-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: "
local -a args
"-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: "
args+=(
"-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: "
'--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/'
"-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: "
'--cache-path[Specify the shared cache directory path]:cache-path:_files -/'
"(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}"
'--config-path[Specify the shared configuration directory path]:config-path:_files -/'
"--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]"
'--disable-prefetching'
"--enable-parseable-module-interfaces[]"
'(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]'
"--trace-resolver[]"
'--skip-update[Skip updating dependencies from their remote during a resolution]'
"(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: "
'--disable-scm-to-registry-transformation[disable source control to registry transformation]'
"--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]"
'--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]'
'--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]'
'(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)'
'-Xcc[Pass flag through to all C compiler invocations]:Xcc:'
'-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:'
'-Xlinker[Pass flag through to all linker invocations]:Xlinker:'
'-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:'
'--triple:triple:'
'--sdk:sdk:_files -/'
'--toolchain:toolchain:_files -/'
'--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:'
'--auto-index-store[Enable or disable indexing-while-building feature]'
'--enable-index-store[Enable or disable indexing-while-building feature]'
'--disable-index-store[Enable or disable indexing-while-building feature]'
'--enable-parseable-module-interfaces'
'(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:'
'--emit-swift-module-separately'
'--use-integrated-swift-driver'
'--experimental-explicit-module-build'
'--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]'
'--build-system:build-system:(native xcode)'
'--enable-dead-strip[Disable/enable dead code stripping by the linker]'
'--disable-dead-strip[Disable/enable dead code stripping by the linker]'
'--static-swift-stdlib[Link Swift stdlib statically]'
'--no-static-swift-stdlib[Link Swift stdlib statically]'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
'plugin:Invoke a command plugin or perform other actions on command plugins'
'default-command:'
)
)
_describe "mode" modes
_describe "subcommand" subcommands
;;
;;
(arg)
(arg)
case ${words[1]} in
case ${words[1]} in
(completion-tool)
(clean)
_swift_package_completion-tool
_swift_package_clean
;;
;;
(dump-package)
(purge-cache)
_swift_package_dump-package
_swift_package_purge-cache
;;
;;
(describe)
(reset)
_swift_package_describe
_swift_package_reset
;;
;;
(clean)
(update)
_swift_package_clean
_swift_package_update
;;
;;
(show-dependencies)
(describe)
_swift_package_show-dependencies
_swift_package_describe
;;
;;
(init)
(init)
_swift_package_init
_swift_package_init
;;
;;
(_format)
_swift_package__format
;;
(diagnose-api-breaking-changes)
_swift_package_diagnose-api-breaking-changes
;;
(experimental-api-diff)
_swift_package_experimental-api-diff
;;
(dump-symbol-graph)
_swift_package_dump-symbol-graph
;;
(dump-pif)
_swift_package_dump-pif
;;
(dump-package)
_swift_package_dump-package
;;
(edit)
_swift_package_edit
;;
(unedit)
(unedit)
_swift_package_unedit
_swift_package_unedit
;;
;;
(tools-version)
(config)
_swift_package_tools-version
_swift_package_config
;;
(resolve)
_swift_package_resolve
;;
;;
(fetch)
(fetch)
_swift_package_fetch
_swift_package_fetch
;;
;;
(resolve)
(show-dependencies)
_swift_package_resolve
_swift_package_show-dependencies
;;
;;
(reset)
(tools-version)
_swift_package_reset
_swift_package_tools-version
;;
;;
(generate-xcodeproj)
(generate-xcodeproj)
_swift_package_generate-xcodeproj
_swift_package_generate-xcodeproj
;;
;;
(edit)
(compute-checksum)
_swift_package_edit
_swift_package_compute-checksum
;;
;;
(config)
(archive-source)
_swift_package_config
_swift_package_archive-source
;;
;;
(update)
(completion-tool)
_swift_package_update
_swift_package_completion-tool
;;
(plugin)
_swift_package_plugin
;;
(default-command)
_swift_package_default-command
;;
;;
esac
esac
;;
;;
esac
esac
return ret
}
}
_swift_package_completion-tool() {
_swift_package_clean() {
arguments=(
integer ret=1
": :{_values '' 'generate-bash-script[generate Bash completion script]' 'generate-zsh-script[generate Bash completion script]' 'list-dependencies[list all dependencies' names]' 'list-executables[list all executables' names]'}"
local -a args
args+=(
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_dump-package() {
_swift_package_purge-cache() {
arguments=(
integer ret=1
local -a args
args+=(
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_describe() {
_swift_package_reset() {
arguments=(
integer ret=1
"--type[json|text]: :{_values '' 'text[describe using text format]' 'json[describe using JSON format]'}"
local -a args
args+=(
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_clean() {
_swift_package_update() {
arguments=(
integer ret=1
local -a args
args+=(
'(--dry-run -n)'{--dry-run,-n}'[Display the list of dependencies that can be updated]'
':packages:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_show-dependencies() {
_swift_package_describe() {
arguments=(
integer ret=1
"--format[text|dot|json|flatlist]: :{_values '' 'text[list dependencies using text format]' 'dot[list dependencies using dot format]' 'json[list dependencies using JSON format]'}"
local -a args
args+=(
'--type[json | text]:type:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_init() {
_swift_package_init() {
arguments=(
integer ret=1
"--type[empty|library|executable|system-module|manifest]: :{_values '' 'empty[generates an empty project]' 'library[generates project for a dynamic library]' 'executable[generates a project for a cli executable]' 'system-module[generates a project for a system module]'}"
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_unedit() {
_swift_package__format() {
arguments=(
integer ret=1
":The name of the package to unedit:_swift_dependency"
local -a args
"--force[Unedit the package even if it has uncommitted and unpushed changes.]"
args+=(
':swift-format-flags:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_tools-version() {
_swift_package_diagnose-api-breaking-changes() {
arguments=(
integer ret=1
"--set[Set tools version of package to the given value]:Set tools version of package to the given value: "
local -a args
"--set-current[Set tools version of package to the current tools version in use]"
args+=(
'--breakage-allowlist-path[The path to a text file containing breaking changes which should be ignored by the API comparison. Each ignored breaking change in the file should appear on its own line and contain the exact message to be ignored (e.g. '"'"'API breakage: func foo() has been removed'"'"').]:breakage-allowlist-path:_files -/'
':treeish:'
'--products[One or more products to include in the API comparison. If present, only the specified products (and any targets specified using `--targets`) will be compared.]:products:'
'--targets[One or more targets to include in the API comparison. If present, only the specified targets (and any products specified using `--products`) will be compared.]:targets:'
'--baseline-dir[The path to a directory used to store API baseline files. If unspecified, a temporary directory will be used.]:baseline-dir:_files -/'
'--regenerate-baseline[Regenerate the API baseline, even if an existing one is available.]'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_fetch() {
_swift_package_experimental-api-diff() {
arguments=(
integer ret=1
local -a args
args+=(
':args:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_resolve() {
_swift_package_dump-symbol-graph() {
arguments=(
integer ret=1
":The name of the package to resolve:_swift_dependency"
local -a args
"--version[The version to resolve at]:The version to resolve at: "
args+=(
"--branch[The branch to resolve at]:The branch to resolve at: "
'--pretty-print[Pretty-print the output JSON.]'
"--revision[The revision to resolve at]:The revision to resolve at: "
'--skip-synthesized-members[Skip members inherited through classes or default implementations.]'
'--minimum-access-level[Include symbols with this access level or more. Possible values: private | fileprivate | internal | public | open]:minimum-access-level:(private fileprivate internal public open)'
'--skip-inherited-docs[Skip emitting doc comments for members inherited through classes or default implementations.]'
'--include-spi-symbols[Add symbols with SPI information to the symbol graph.]'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_reset() {
_swift_package_dump-pif() {
arguments=(
integer ret=1
local -a args
args+=(
'--preserve-structure[Preserve the internal structure of PIF]'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_generate-xcodeproj() {
_swift_package_dump-package() {
arguments=(
integer ret=1
"--xcconfig-overrides[Path to xcconfig file]:Path to xcconfig file:_files"
local -a args
"--enable-code-coverage[Enable code coverage in the generated project]"
args+=(
"--output[Path where the Xcode project should be generated]:Path where the Xcode project should be generated:_files"
'--version[Show the version.]'
"--legacy-scheme-generator[Use the legacy scheme generator]"
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
"--watch[Watch for changes to the Package manifest to regenerate the Xcode project]"
"--skip-extra-files[Do not add file references for extra files to the generated Xcode project]"
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_edit() {
_swift_package_edit() {
arguments=(
integer ret=1
":The name of the package to edit:_swift_dependency"
local -a args
"--revision[The revision to edit]:The revision to edit: "
args+=(
"--branch[The branch to create]:The branch to create: "
'--revision[The revision to edit]:revision:'
"--path[Create or use the checkout at this path]:Create or use the checkout at this path:_files"
'--branch[The branch to create]:branch:'
'--path[Create or use the checkout at this path]:path:_files -/'
':package-name:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
return ret
}
_swift_package_unedit() {
integer ret=1
local -a args
args+=(
'--force[Unedit the package even if it has uncommitted and unpushed changes]'
':package-name:'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
_arguments -w -s -S $args[@] && ret=0
return ret
}
}
_swift_package_config() {
_swift_package_config() {
arguments=(
integer ret=1
local -a args
args+=(
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
'(-): :->command'
'(-): :->command'
'(-)*:: :->arg'
'(-)*:: :->arg'
)
)
_arguments $arguments && return
_arguments -w -s -S $args[@] && ret=0
case $state in
case $state in
(command)
(command)
local modes
local subcommands
modes=(
subcommands=(
'set-mirror:Set a mirror for a dependency'
'unset-mirror:Remove an existing mirror'
'unset-mirror:Remove an existing mirror'
'get-mirror:Print mirror configuration for the given package dependency'
'get-mirror:Print mirror configuration for the given package dependency'
"--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]"
args+=(
"--enable-parseable-module-interfaces[]"
'--xcconfig-overrides[Path to xcconfig file]:xcconfig-overrides:_files'
"--trace-resolver[]"
'--output[Path where the Xcode project should be generated]:output:_files -/'
"(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: "
'--legacy-scheme-generator[Use the legacy scheme generator]'
"--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]"
'--watch[Watch for changes to the Package manifest to regenerate the Xcode project]'
"--skip-build[Skip building the test target]"
'--skip-extra-files[Do not add file references for extra files to the generated Xcode project]'
"(--list-tests -l)"{--list-tests,-l}"[Lists test methods in specifier format]"
'--enable-code-coverage[Enable code coverage]'
"--generate-linuxmain[Generate LinuxMain.swift entries for the package]"
'--disable-code-coverage[Enable code coverage]'
"--parallel[Run the tests in parallel.]"
'--version[Show the version.]'
"--num-workers[Number of tests to execute in parallel.]:Number of tests to execute in parallel.: "
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
"(--specifier -s)"{--specifier,-s}"[]: : "
)
"--xunit-output[]: :_files"
_arguments -w -s -S $args[@] && ret=0
"--filter[Run test cases matching regular expression, Format: <test-target>.<test-case> or <test-target>.<test-case>/<test>]:Run test cases matching regular expression, Format: <test-target>.<test-case> or <test-target>.<test-case>/<test>: "
"--enable-code-coverage[Test with code coverage enabled]"
return ret
)
}
_arguments $arguments && return
}
_swift_package_compute-checksum() {
integer ret=1
_swift_compiler() {
local -a args
args+=(
':path:_files -/'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'
)
_arguments -w -s -S $args[@] && ret=0
return ret
}
_swift_package_archive-source() {
integer ret=1
local -a args
args+=(
'(-o --output)'{-o,--output}'[The absolute or relative path for the generated source archive]:output:_files -/'
'--version[Show the version.]'
'(-help -h --help)'{-help,-h,--help}'[Show help information.]'