Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mattmassicotte/xclint
Xcode project linting
https://github.com/mattmassicotte/xclint
lint linter linting objective-c spm swift xcode
Last synced: 5 days ago
JSON representation
Xcode project linting
- Host: GitHub
- URL: https://github.com/mattmassicotte/xclint
- Owner: mattmassicotte
- License: bsd-3-clause
- Created: 2023-10-14T11:33:22.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-07-10T15:24:31.000Z (6 months ago)
- Last Synced: 2024-12-24T00:09:17.942Z (5 days ago)
- Topics: lint, linter, linting, objective-c, spm, swift, xcode
- Language: Swift
- Homepage:
- Size: 133 KB
- Stars: 115
- Watchers: 3
- Forks: 2
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![Build Status][build status badge]][build status]
[![Platforms][platforms badge]][platforms]# XCLint
Xcode project lintingThis project is still pretty young, and has rough edges. However, it kinda works! So, please do give it a shot.
## Installation
XCLint is available as both a commandline tool and a library.
Tool:
```
brew tap mattmassicotte/XCLint https://github.com/mattmassicotte/XCLint.git
brew install xclint
```Package:
```swift
dependencies: [
.package(url: "https://github.com/mattmassicotte/XCLint", branch: "main")
],
targets: [
.testTarget(name: "MyTarget", dependencies: ["XCLinting"]),
]
```## Tool Usage
Just run the `xclint` binary in your project directory. Check out its `-h` flag for more usage.
```
# cd my/project
# xclint
```This will run a default set of rules. But, you can customize its behavior with a `.xclint.yml` file. The basic structure borrows a lot from [SwiftLint](https://github.com/realm/SwiftLint).
```yaml
# Some rules may not be appropriate for all projects. You must opt-in those.
opt_in_rules:
- embedded_build_setting # checks for build settings in the project file
- groups_sorted # checks that all group contents are alphabetically sorted
- implicit_dependencies # checks for any schemes that have "Find Implicit Dependencies" enabled
- targets_use_xcconfig # checks for any targets without a XCConfig file set
- projects_use_xcconfig # checks for any projects without a XCConfig file set
- shared_scheme_skips_tests # checks for any shared schemes that have disabled tests
- shared_schemes # checks that all targets have a shared scheme present# Other rules make sense for all projects by default. You must opt-out of those.
disabled_rules:
- build_files_ordered # checks that the ordering of techincally-unordered collections Xcode writes out is preserved
- validate_build_settings # checks that build settings have valid values
- relative_paths # checks for any absolute file references
```## Alternatives
I was kind of hoping that some else had built something like this. And they have! However, none of the things I found are maintained any more.
- [ProjLint](https://github.com/JamitLabs/ProjLint)
- [XcodeProjLint](https://github.com/RocketLaunchpad/XcodeProjLint)
- [xcprojectlint](https://github.com/americanexpress/xcprojectlint)## Contributing and Collaboration
I'd love to hear from you! Get in touch via [mastodon](https://mastodon.social/@mattiem), an issue, or a pull request.
I prefer collaboration, and would love to find ways to work together if you have a similar project.
I prefer indentation with tabs for improved accessibility. But, I'd rather you use the system you want and make a PR than hesitate because of whitespace.
By participating in this project you agree to abide by the [Contributor Code of Conduct](CODE_OF_CONDUCT.md).
[build status]: https://github.com/mattmassicotte/XCLint/actions
[build status badge]: https://github.com/mattmassicotte/XCLint/workflows/CI/badge.svg
[platforms]: https://swiftpackageindex.com/mattmassicotte/XCLint
[platforms badge]: https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2Fmattmassicotte%2FXCLint%2Fbadge%3Ftype%3Dplatforms
[documentation]: https://swiftpackageindex.com/mattmassicotte/XCLint/main/documentation
[documentation badge]: https://img.shields.io/badge/Documentation-DocC-blue