mirror of
https://github.com/realm/SwiftLint.git
synced 2026-05-07 20:12:49 +00:00
3eb3772022
* Compile with `-strict-concurrency=complete` Only in Bazel for now, because this is considered an unsafe flag in SwiftPM which would lead to warnings for downstream consumers of SwiftLint using SwiftPM. Some imports of SwiftSyntax need the `@preconcurrency` annotation until https://github.com/apple/swift-syntax/pull/2322 is available in a release. The following SwiftLint libraries have `-strict-concurrency=complete` applied: * SwiftLintCoreMacros * SwiftLintBuiltInRules * SwiftLintExtraRules The following SwiftLint libraries don't have the flag applied and need to be migrated: * SwiftLintCore * swiftlint (CLI target) So really the rules and macros are now being compiled with `-strict-concurrency=complete`, but the core infrastructure of SwiftLint is not. Still, given that Swift 6 will eventually make these warnings errors by default, it's good to prevent issues from creeping in earlier rather than later. * Add CI job to build with strict concurrency
224 lines
5.4 KiB
Python
224 lines
5.4 KiB
Python
load("@build_bazel_rules_apple//apple:apple.bzl", "apple_universal_binary")
|
|
load(
|
|
"@build_bazel_rules_swift//swift:swift.bzl",
|
|
"swift_binary",
|
|
"swift_compiler_plugin",
|
|
"swift_library",
|
|
)
|
|
|
|
config_setting(
|
|
name = "strict_concurrency_builtin_rules",
|
|
values = {"define": "strict_concurrency_builtin_rules=true"},
|
|
)
|
|
|
|
copts = [
|
|
"-enable-upcoming-feature",
|
|
"ExistentialAny",
|
|
]
|
|
|
|
strict_concurrency_copts = [
|
|
"-Xfrontend",
|
|
"-strict-concurrency=complete",
|
|
]
|
|
|
|
# Targets
|
|
|
|
swift_library(
|
|
name = "SwiftLintCoreMacrosLib",
|
|
srcs = glob(["Source/SwiftLintCoreMacros/*.swift"]),
|
|
copts = copts + strict_concurrency_copts,
|
|
module_name = "SwiftLintCoreMacros",
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
"@SwiftSyntax//:SwiftCompilerPlugin_opt",
|
|
"@SwiftSyntax//:SwiftSyntaxMacros_opt",
|
|
],
|
|
)
|
|
|
|
swift_compiler_plugin(
|
|
name = "SwiftLintCoreMacros",
|
|
srcs = glob(["Source/SwiftLintCoreMacros/*.swift"]),
|
|
copts = copts + strict_concurrency_copts,
|
|
deps = [
|
|
"@SwiftSyntax//:SwiftCompilerPlugin_opt",
|
|
"@SwiftSyntax//:SwiftSyntaxMacros_opt",
|
|
],
|
|
)
|
|
|
|
swift_library(
|
|
name = "SwiftLintCore",
|
|
srcs = glob(["Source/SwiftLintCore/**/*.swift"]),
|
|
copts = copts, # TODO: strict_concurrency_copts
|
|
module_name = "SwiftLintCore",
|
|
plugins = [
|
|
":SwiftLintCoreMacros",
|
|
],
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
"@SwiftSyntax//:SwiftIDEUtils_opt",
|
|
"@SwiftSyntax//:SwiftOperators_opt",
|
|
"@SwiftSyntax//:SwiftParserDiagnostics_opt",
|
|
"@SwiftSyntax//:SwiftSyntaxBuilder_opt",
|
|
"@SwiftSyntax//:SwiftSyntax_opt",
|
|
"@com_github_jpsim_sourcekitten//:SourceKittenFramework",
|
|
"@sourcekitten_com_github_jpsim_yams//:Yams",
|
|
"@swiftlint_com_github_scottrhoyt_swifty_text_table//:SwiftyTextTable",
|
|
] + select({
|
|
"@platforms//os:linux": ["@com_github_krzyzanowskim_cryptoswift//:CryptoSwift"],
|
|
"//conditions:default": [":DyldWarningWorkaround"],
|
|
}),
|
|
)
|
|
|
|
swift_library(
|
|
name = "SwiftLintBuiltInRules",
|
|
srcs = glob(["Source/SwiftLintBuiltInRules/**/*.swift"]),
|
|
copts = copts + select({
|
|
":strict_concurrency_builtin_rules": strict_concurrency_copts,
|
|
"//conditions:default": [],
|
|
}),
|
|
module_name = "SwiftLintBuiltInRules",
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
":SwiftLintCore",
|
|
],
|
|
)
|
|
|
|
swift_library(
|
|
name = "SwiftLintExtraRules",
|
|
srcs = [
|
|
"Source/SwiftLintExtraRules/Exports.swift",
|
|
"@swiftlint_extra_rules//:extra_rules",
|
|
],
|
|
copts = copts + strict_concurrency_copts,
|
|
module_name = "SwiftLintExtraRules",
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
":SwiftLintCore",
|
|
],
|
|
)
|
|
|
|
swift_library(
|
|
name = "SwiftLintFramework",
|
|
srcs = glob(
|
|
["Source/SwiftLintFramework/**/*.swift"],
|
|
),
|
|
copts = copts + strict_concurrency_copts,
|
|
module_name = "SwiftLintFramework",
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
":SwiftLintBuiltInRules",
|
|
":SwiftLintCore",
|
|
":SwiftLintExtraRules",
|
|
],
|
|
)
|
|
|
|
swift_library(
|
|
name = "swiftlint.library",
|
|
srcs = glob(["Source/swiftlint/**/*.swift"]),
|
|
copts = copts, # TODO: strict_concurrency_copts
|
|
module_name = "swiftlint",
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
":SwiftLintFramework",
|
|
"@com_github_johnsundell_collectionconcurrencykit//:CollectionConcurrencyKit",
|
|
"@sourcekitten_com_github_apple_swift_argument_parser//:ArgumentParser",
|
|
"@swiftlint_com_github_scottrhoyt_swifty_text_table//:SwiftyTextTable",
|
|
],
|
|
)
|
|
|
|
swift_binary(
|
|
name = "swiftlint",
|
|
copts = copts + strict_concurrency_copts,
|
|
visibility = ["//visibility:public"],
|
|
deps = [
|
|
":swiftlint.library",
|
|
],
|
|
)
|
|
|
|
apple_universal_binary(
|
|
name = "universal_swiftlint",
|
|
binary = ":swiftlint",
|
|
forced_cpus = [
|
|
"x86_64",
|
|
"arm64",
|
|
],
|
|
minimum_os_version = "12.0",
|
|
platform_type = "macos",
|
|
visibility = ["//visibility:public"],
|
|
)
|
|
|
|
filegroup(
|
|
name = "DyldWarningWorkaroundSources",
|
|
srcs = [
|
|
"Source/DyldWarningWorkaround/DyldWarningWorkaround.c",
|
|
"Source/DyldWarningWorkaround/include/objc_dupclass.h",
|
|
],
|
|
)
|
|
|
|
cc_library(
|
|
name = "DyldWarningWorkaround",
|
|
srcs = ["//:DyldWarningWorkaroundSources"],
|
|
includes = ["Source/DyldWarningWorkaround/include"],
|
|
alwayslink = True,
|
|
)
|
|
|
|
# Linting
|
|
|
|
filegroup(
|
|
name = "LintInputs",
|
|
srcs = glob(["Source/**/*.swift"]) + [
|
|
".swiftlint.yml",
|
|
"//Tests:SwiftLintFrameworkTestsData",
|
|
],
|
|
visibility = ["//Tests:__subpackages__"],
|
|
)
|
|
|
|
# Release
|
|
|
|
filegroup(
|
|
name = "release_files",
|
|
srcs = [
|
|
"BUILD",
|
|
"LICENSE",
|
|
"MODULE.bazel",
|
|
"//:DyldWarningWorkaroundSources",
|
|
"//:LintInputs",
|
|
"//Tests:BUILD",
|
|
"//bazel:release_files",
|
|
],
|
|
)
|
|
|
|
# TODO: Use rules_pkg
|
|
genrule(
|
|
name = "release",
|
|
srcs = [":release_files"],
|
|
outs = [
|
|
"bazel.tar.gz",
|
|
"bazel.tar.gz.sha256",
|
|
],
|
|
cmd = """\
|
|
set -euo pipefail
|
|
|
|
outs=($(OUTS))
|
|
|
|
COPYFILE_DISABLE=1 tar czvfh "$${outs[0]}" \
|
|
--exclude ^bazel-out/ \
|
|
--exclude ^external/ \
|
|
*
|
|
shasum -a 256 "$${outs[0]}" > "$${outs[1]}"
|
|
""",
|
|
)
|
|
|
|
# Analyze
|
|
|
|
sh_test(
|
|
name = "analyze",
|
|
srcs = ["//tools:test-analyze.sh"],
|
|
data = [
|
|
"Package.resolved",
|
|
"Package.swift",
|
|
":LintInputs",
|
|
":swiftlint",
|
|
],
|
|
)
|