Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shibapm/komondor
Git Hooks for Swift projects 🐩
https://github.com/shibapm/komondor
git-hooks husky swift swift-package-manager
Last synced: 3 days ago
JSON representation
Git Hooks for Swift projects 🐩
- Host: GitHub
- URL: https://github.com/shibapm/komondor
- Owner: shibapm
- License: mit
- Created: 2018-11-24T03:50:45.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-02T19:05:18.000Z (almost 2 years ago)
- Last Synced: 2025-01-08T11:04:43.288Z (10 days ago)
- Topics: git-hooks, husky, swift, swift-package-manager
- Language: Swift
- Homepage:
- Size: 307 KB
- Stars: 552
- Watchers: 8
- Forks: 32
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Komondor
Git Hook automation for Swift and Xcode projects. A port of [Husky](https://github.com/typicode/husky) to Swift.
### TL:DR
1. Add or amend a `Package.swift`
2. Add this dependency `.package(url: "https://github.com/shibapm/Komondor.git", from: "1.0.0"),`
3. Run the install command: `swift run komondor install`
4. Add a config section to your [`Package.swift`](https://github.com/shibapm/Komondor/blob/master/Package.swift)Then you'll get git-hooks consolidated and centralized so that everyone can work with the same tooling.
### Why?
> If you care about something, you should automate it.
Git Hooks like what Komondor provides gives you more surface area for per-project automation. Komondor provides
an easily understood way to see how all the git automation touch-points in your project will come together. These
hooks allow for much faster feedback during development and let different team-members to use different tools
but still have the same bar of quality.For example, adding [SwiftFormat](https://github.com/nicklockwood/SwiftFormat) to your `pre-commit` hook means that
no-one will ever need to discuss formatting in code review again. Perfect. It won't slow down your Xcode builds,
because it lives outside of your project and you can verify it on CI if you'd like to be 100% that everyone conforms.Another example, running tests before pushing - this means you don't have to come back 10-15m later once CI has told
you that you have a failing test. This moves more validation to a point where you are still in-context.### An Example
This is from [the repo](https://github.com/shibapm/Komondor/blob/master/Package.swift) you're looking at:
```swift
#if canImport(PackageConfig)
import PackageConfiglet config = PackageConfiguration([
"komondor": [
"pre-push": "swift test",
"pre-commit": [
"swift test",
"swift run swiftformat .",
"swift run swiftlint autocorrect --path Sources/",
"git add .",
],
],
]).write()
#endif
```See more about the [config here](./Documentation/config.md).
### Getting Set up
| [On a SwiftPM project](Documentation/with_swiftpm.md) | [On an Xcode Project](Documentation/only_xcode.md) |
| ----------------------------------------------------- | -------------------------------------------------- |### Deployment
Use `swift run rocket [patch]`