Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/DimaRU/PackageBuildInfo

Automated Swift Package version and build numbering via Git. A Swift Package Manager build plugin.
https://github.com/DimaRU/PackageBuildInfo

git manager package plugin spm swift xcode-plugin

Last synced: 3 months ago
JSON representation

Automated Swift Package version and build numbering via Git. A Swift Package Manager build plugin.

Awesome Lists containing this project

README

        

![swift-version](https://img.shields.io/badge/swift-5.6-brightgreen.svg?style=for-the-badge)
![Mac OS](https://img.shields.io/badge/-platform-gray?style=for-the-badge)![Mac OS](https://img.shields.io/badge/mac%20os-000000?style=for-the-badge&logo=Apple&logoColor=F0F0F0)![Linux](https://img.shields.io/badge/Linux-FCC624?style=for-the-badge&logo=linux&logoColor=black)![Windows](https://img.shields.io/badge/Windows-0078D6?style=for-the-badge&logo=windows&logoColor=white)
[![License](https://img.shields.io/github/license/DimaRU/PackageBuildInfo.svg?style=for-the-badge)](LICENSE)

# PackageBuildInfo

#### Automated Swift Package version and build numbering via Git. A Swift Package Manager plugin.

Wouldn't it be great if your Swift Package-based projects just take their version and build number automatically from git? Well, now it can!

Using a new amazing feature - Swift Package Manager prebuild plugin, you can generate .swift file with current build info from git. It will never modify your local project.

## Requirements

* SwiftPM 5.6 or later.
* git
* bash

## Usage

* Add to package dependencies:

```
.package(url: "https://github.com/DimaRU/PackageBuildInfo", branch: "master")
```

* Add to target:

```
plugins: [
.plugin(name: "PackageBuildInfoPlugin", package: "PackageBuildInfo")
]
```

## Sample project

Sample project here:
[https://github.com/DimaRU/PackageBuildInfoExample](https://github.com/DimaRU/PackageBuildInfoExample)

## Generated file example:

```swift
/////
//// Package Build info
/// Code generated by PackageBuildInfo. DO NOT EDIT.
//
import Foundation

public struct PackageBuild {
public let isDirty: Bool // Dirty build - git directory is't clean.
public let timeStamp: Date // Time of last commit
public let timeZone: TimeZone // Time Zone
public let count: Int // Total commit count
public let tag: String? // Tag, if exist
public let countSinceTag: Int // Commit count since tag
public let branch: String? // Git branch name
public let digest: [UInt8] // Latest commit sha1 digest (20 bytes)

public var commit: String {
digest.reduce("") { $0 + String(format: "%02x", $1) }
}
public static let info = PackageBuild(
isDirty: false,
timeStamp: Date(timeIntervalSince1970: 1728751843),
timeZone: TimeZone(secondsFromGMT: 10800) ?? TimeZone.current,
count: 10,
tag: "1.0.0",
countSinceTag: 6,
branch: "master",
digest: [0xa3, 0xf9, 0xa7, 0x1a, 0xab, 0x55, 0x20, 0x91, 0xc3, 0x7f, 0x32, 0x60, 0x11, 0x70, 0xa9, 0x97, 0xd9, 0xf5, 0x21, 0x91])
}
```

## Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

## License

[MIT](LICENSE)