-
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0893939
commit c4314ab
Showing
6 changed files
with
253 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,23 +1,29 @@ | ||
import Foundation | ||
|
||
func embeddedBuildSettingsRule(_ environment: XCLinter.Environment) -> [Violation] { | ||
var violations = [Violation]() | ||
import XcodeProj | ||
|
||
for target in environment.project.pbxproj.legacyTargets { | ||
for config in target.buildConfigurationList?.buildConfigurations ?? [] { | ||
if config.buildSettings.isEmpty == false { | ||
violations.append(.init("found some settings for \(target.name), \(config.name)")) | ||
struct EmbeddedBuildSettingsRule { | ||
func run(_ environment: XCLinter.Environment) throws -> [Violation] { | ||
var violations = [Violation]() | ||
|
||
// check top-level | ||
for project in environment.project.pbxproj.projects { | ||
for config in project.buildConfigurationList?.buildConfigurations ?? [] { | ||
if config.buildSettings.isEmpty == false { | ||
violations.append(.init("found settings for project \(project.name), \(config.name)")) | ||
} | ||
} | ||
} | ||
} | ||
|
||
for target in environment.project.pbxproj.nativeTargets { | ||
for config in target.buildConfigurationList?.buildConfigurations ?? [] { | ||
if config.buildSettings.isEmpty == false { | ||
violations.append(.init("found some settings for \(target.name), \(config.name)")) | ||
// check targets | ||
environment.project.pbxproj.enumerateBuildConfigurations { name, configList in | ||
for config in configList.buildConfigurations { | ||
if config.buildSettings.isEmpty == false { | ||
violations.append(.init("found settings for target \(name), \(config.name)")) | ||
} | ||
} | ||
} | ||
} | ||
|
||
return violations | ||
return violations | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
200 changes: 200 additions & 0 deletions
200
Tests/XCLintTests/TestData/ProjectOnlyBuildSettings.xcodeproj/project.pbxproj
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,200 @@ | ||
// !$*UTF8*$! | ||
{ | ||
archiveVersion = 1; | ||
classes = { | ||
}; | ||
objectVersion = 56; | ||
objects = { | ||
|
||
/* Begin PBXBuildFile section */ | ||
C965BD2C2AE6E5D700E5836A /* StockMacOSAppApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = C965BD2B2AE6E5D700E5836A /* StockMacOSAppApp.swift */; }; | ||
C965BD2E2AE6E5D700E5836A /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C965BD2D2AE6E5D700E5836A /* ContentView.swift */; }; | ||
C965BD302AE6E5D800E5836A /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = C965BD2F2AE6E5D800E5836A /* Assets.xcassets */; }; | ||
C965BD332AE6E5D800E5836A /* Preview Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = C965BD322AE6E5D800E5836A /* Preview Assets.xcassets */; }; | ||
/* End PBXBuildFile section */ | ||
|
||
/* Begin PBXFileReference section */ | ||
C965BD282AE6E5D700E5836A /* .app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = .app; sourceTree = BUILT_PRODUCTS_DIR; }; | ||
C965BD2B2AE6E5D700E5836A /* StockMacOSAppApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StockMacOSAppApp.swift; sourceTree = "<group>"; }; | ||
C965BD2D2AE6E5D700E5836A /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; }; | ||
C965BD2F2AE6E5D800E5836A /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; }; | ||
C965BD322AE6E5D800E5836A /* Preview Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = "Preview Assets.xcassets"; sourceTree = "<group>"; }; | ||
C965BD342AE6E5D800E5836A /* StockMacOSApp.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = StockMacOSApp.entitlements; sourceTree = "<group>"; }; | ||
/* End PBXFileReference section */ | ||
|
||
/* Begin PBXFrameworksBuildPhase section */ | ||
C965BD252AE6E5D700E5836A /* Frameworks */ = { | ||
isa = PBXFrameworksBuildPhase; | ||
buildActionMask = 2147483647; | ||
files = ( | ||
); | ||
runOnlyForDeploymentPostprocessing = 0; | ||
}; | ||
/* End PBXFrameworksBuildPhase section */ | ||
|
||
/* Begin PBXGroup section */ | ||
C965BD1F2AE6E5D700E5836A = { | ||
isa = PBXGroup; | ||
children = ( | ||
C965BD2A2AE6E5D700E5836A /* StockMacOSApp */, | ||
C965BD292AE6E5D700E5836A /* Products */, | ||
); | ||
sourceTree = "<group>"; | ||
}; | ||
C965BD292AE6E5D700E5836A /* Products */ = { | ||
isa = PBXGroup; | ||
children = ( | ||
C965BD282AE6E5D700E5836A /* .app */, | ||
); | ||
name = Products; | ||
sourceTree = "<group>"; | ||
}; | ||
C965BD2A2AE6E5D700E5836A /* StockMacOSApp */ = { | ||
isa = PBXGroup; | ||
children = ( | ||
C965BD2B2AE6E5D700E5836A /* StockMacOSAppApp.swift */, | ||
C965BD2D2AE6E5D700E5836A /* ContentView.swift */, | ||
C965BD2F2AE6E5D800E5836A /* Assets.xcassets */, | ||
C965BD342AE6E5D800E5836A /* StockMacOSApp.entitlements */, | ||
C965BD312AE6E5D800E5836A /* Preview Content */, | ||
); | ||
path = StockMacOSApp; | ||
sourceTree = "<group>"; | ||
}; | ||
C965BD312AE6E5D800E5836A /* Preview Content */ = { | ||
isa = PBXGroup; | ||
children = ( | ||
C965BD322AE6E5D800E5836A /* Preview Assets.xcassets */, | ||
); | ||
path = "Preview Content"; | ||
sourceTree = "<group>"; | ||
}; | ||
/* End PBXGroup section */ | ||
|
||
/* Begin PBXNativeTarget section */ | ||
C965BD272AE6E5D700E5836A /* StockMacOSApp */ = { | ||
isa = PBXNativeTarget; | ||
buildConfigurationList = C965BD372AE6E5D800E5836A /* Build configuration list for PBXNativeTarget "StockMacOSApp" */; | ||
buildPhases = ( | ||
C965BD242AE6E5D700E5836A /* Sources */, | ||
C965BD252AE6E5D700E5836A /* Frameworks */, | ||
C965BD262AE6E5D700E5836A /* Resources */, | ||
); | ||
buildRules = ( | ||
); | ||
dependencies = ( | ||
); | ||
name = StockMacOSApp; | ||
productName = StockMacOSApp; | ||
productReference = C965BD282AE6E5D700E5836A /* .app */; | ||
productType = "com.apple.product-type.application"; | ||
}; | ||
/* End PBXNativeTarget section */ | ||
|
||
/* Begin PBXProject section */ | ||
C965BD202AE6E5D700E5836A /* Project object */ = { | ||
isa = PBXProject; | ||
attributes = { | ||
BuildIndependentTargetsInParallel = 1; | ||
LastSwiftUpdateCheck = 1510; | ||
LastUpgradeCheck = 1510; | ||
TargetAttributes = { | ||
C965BD272AE6E5D700E5836A = { | ||
CreatedOnToolsVersion = 15.1; | ||
}; | ||
}; | ||
}; | ||
buildConfigurationList = C965BD232AE6E5D700E5836A /* Build configuration list for PBXProject "ProjectOnlyBuildSettings" */; | ||
compatibilityVersion = "Xcode 14.0"; | ||
developmentRegion = en; | ||
hasScannedForEncodings = 0; | ||
knownRegions = ( | ||
en, | ||
Base, | ||
); | ||
mainGroup = C965BD1F2AE6E5D700E5836A; | ||
productRefGroup = C965BD292AE6E5D700E5836A /* Products */; | ||
projectDirPath = ""; | ||
projectRoot = ""; | ||
targets = ( | ||
C965BD272AE6E5D700E5836A /* StockMacOSApp */, | ||
); | ||
}; | ||
/* End PBXProject section */ | ||
|
||
/* Begin PBXResourcesBuildPhase section */ | ||
C965BD262AE6E5D700E5836A /* Resources */ = { | ||
isa = PBXResourcesBuildPhase; | ||
buildActionMask = 2147483647; | ||
files = ( | ||
C965BD332AE6E5D800E5836A /* Preview Assets.xcassets in Resources */, | ||
C965BD302AE6E5D800E5836A /* Assets.xcassets in Resources */, | ||
); | ||
runOnlyForDeploymentPostprocessing = 0; | ||
}; | ||
/* End PBXResourcesBuildPhase section */ | ||
|
||
/* Begin PBXSourcesBuildPhase section */ | ||
C965BD242AE6E5D700E5836A /* Sources */ = { | ||
isa = PBXSourcesBuildPhase; | ||
buildActionMask = 2147483647; | ||
files = ( | ||
C965BD2E2AE6E5D700E5836A /* ContentView.swift in Sources */, | ||
C965BD2C2AE6E5D700E5836A /* StockMacOSAppApp.swift in Sources */, | ||
); | ||
runOnlyForDeploymentPostprocessing = 0; | ||
}; | ||
/* End PBXSourcesBuildPhase section */ | ||
|
||
/* Begin XCBuildConfiguration section */ | ||
C965BD352AE6E5D800E5836A /* Debug */ = { | ||
isa = XCBuildConfiguration; | ||
buildSettings = { | ||
ONLY_ACTIVE_ARCH = YES; | ||
}; | ||
name = Debug; | ||
}; | ||
C965BD362AE6E5D800E5836A /* Release */ = { | ||
isa = XCBuildConfiguration; | ||
buildSettings = { | ||
ONLY_ACTIVE_ARCH = YES; | ||
}; | ||
name = Release; | ||
}; | ||
C965BD382AE6E5D800E5836A /* Debug */ = { | ||
isa = XCBuildConfiguration; | ||
buildSettings = { | ||
}; | ||
name = Debug; | ||
}; | ||
C965BD392AE6E5D800E5836A /* Release */ = { | ||
isa = XCBuildConfiguration; | ||
buildSettings = { | ||
}; | ||
name = Release; | ||
}; | ||
/* End XCBuildConfiguration section */ | ||
|
||
/* Begin XCConfigurationList section */ | ||
C965BD232AE6E5D700E5836A /* Build configuration list for PBXProject "ProjectOnlyBuildSettings" */ = { | ||
isa = XCConfigurationList; | ||
buildConfigurations = ( | ||
C965BD352AE6E5D800E5836A /* Debug */, | ||
C965BD362AE6E5D800E5836A /* Release */, | ||
); | ||
defaultConfigurationIsVisible = 0; | ||
defaultConfigurationName = Release; | ||
}; | ||
C965BD372AE6E5D800E5836A /* Build configuration list for PBXNativeTarget "StockMacOSApp" */ = { | ||
isa = XCConfigurationList; | ||
buildConfigurations = ( | ||
C965BD382AE6E5D800E5836A /* Debug */, | ||
C965BD392AE6E5D800E5836A /* Release */, | ||
); | ||
defaultConfigurationIsVisible = 0; | ||
defaultConfigurationName = Release; | ||
}; | ||
/* End XCConfigurationList section */ | ||
}; | ||
rootObject = C965BD202AE6E5D700E5836A /* Project object */; | ||
} |
7 changes: 7 additions & 0 deletions
7
.../TestData/ProjectOnlyBuildSettings.xcodeproj/project.xcworkspace/contents.xcworkspacedata
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
8 changes: 8 additions & 0 deletions
8
...jectOnlyBuildSettings.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | ||
<plist version="1.0"> | ||
<dict> | ||
<key>IDEDidComputeMac32BitWarning</key> | ||
<true/> | ||
</dict> | ||
</plist> |