Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/giginet/Scipio
A new build tool to generate XCFramework
https://github.com/giginet/Scipio
Last synced: 2 months ago
JSON representation
A new build tool to generate XCFramework
- Host: GitHub
- URL: https://github.com/giginet/Scipio
- Owner: giginet
- License: mit
- Created: 2022-08-05T14:11:44.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-05-28T16:06:37.000Z (7 months ago)
- Last Synced: 2024-05-29T01:14:46.236Z (7 months ago)
- Language: Swift
- Homepage: https://giginet.github.io/Scipio/documentation/scipio
- Size: 1.01 MB
- Stars: 399
- Watchers: 11
- Forks: 25
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-ios - Scipio
README
# Scipio
![GitHub Workflow Status (with event)](https://img.shields.io/github/actions/workflow/status/giginet/Scipio/tests.yml?style=flat-square&logo=github)
![Swift 6.0](https://img.shields.io/badge/Swift-6.0-FA7343?logo=swift&style=flat-square)
[![Xcode 16.0](https://img.shields.io/badge/Xcode-16.0-147EFB?style=flat-square&logo=xcode&link=https%3A%2F%2Fdeveloper.apple.com%2Fxcode%2F)](https://developer.apple.com/xcode/)
[![SwiftPM](https://img.shields.io/badge/SwiftPM-compatible-green?logo=swift&style=flat-square)](https://swift.org/package-manager/)
[![Documentation](https://img.shields.io/badge/Documentation-available-green?style=flat-square)](https://giginet.github.io/Scipio/documentation/scipio/)
![Platforms](https://img.shields.io/badge/Platform-iOS%7CmacOS%7CwatchOS%7CtvOS%7CvisionOS-lightgray?logo=apple&style=flat-square)
[![License](https://img.shields.io/badge/License-MIT-darkgray?style=flat-square)
](https://github.com/giginet/Scipio/blob/main/LICENSE.md)## Carthago delenda est
Scipio proposes a new workflow to integrate dependencies into your applications.
This product is highly inspired by [Carthage](https://github.com/Carthage/Carthage) and [swift-create-xcframework](https://github.com/unsignedapps/swift-create-xcframework).
## Abstract
SwiftPM is the best way to integrate dependencies into your app.
However, build artifacts built by Xcode are difficult to cache.On the other hand, [XCFramework](https://developer.apple.com/videos/play/wwdc2019/416/) is a good way to keep binaries portable.
Scipio provides a new hybrid way to manage dependencies.
First, use SwiftPM to resolve dependencies and checkout repositories. After that, this tool converts each dependency into XCFramework.
## Usage
See [Scipio Official Documentation](https://giginet.github.io/Scipio/documentation/scipio) for detail.
### Prepare all dependencies for your application
The concept of Scipio, all dependencies wanted to be used in your application should be defined in one Package manifest.
prepare command is to build all dependencies as XCFrameworks in the manifest.
This mode is called `prepare` mode. See [Prepare All Dependencies for Your Application](https://giginet.github.io/Scipio/documentation/scipio/prepare-cache-for-applications) for detail.
#### Define `Package.swift` to describe your application's dependencies
```swift
// swift-tools-version: 6.0
// The swift-tools-version declares the minimum version of Swift required to build this package.import PackageDescription
let package = Package(
name: "MyAppDependencies",
platforms: [
// Specify platforms to build
.iOS(.v14),
],
products: [],
dependencies: [
// Add dependencies
.package(url: "https://github.com/onevcat/APNGKit.git", exact: "2.2.1"),
],
targets: [
.target(
name: "MyAppDependency",
dependencies: [
// List all dependencies to build
.product(name: "APNGKit", package: "APNGKit"),
]),
]
)```
#### Run `prepare` command
```
$ scipio prepare path/to/MyAppDependencies
> 🔁 Resolving Dependencies...
> 🗑️ Cleaning MyAppDependencies...
> 📦 Building APNGKit for iOS
> 🚀 Combining into XCFramework...
> 📦 Building Delegate for iOS
> 🚀 Combining into XCFramework...
> ❇️ Succeeded.
```All XCFrameworks are generated into `MyAppDependencies/XCFramework` by default.
#### Library Evolution support
Scipio disables to support [Library Evolution](https://www.swift.org/blog/library-evolution/) feature by default.
It means built frameworks can be used only from products built with the same Swift version.
The primary reason why is Library Evolution limitation.
In fact, some packages can't build with enabling Library Evolution. (https://developer.apple.com/forums/thread/123253, https://github.com/apple/swift-collections/issues/94, https://github.com/apple/swift-nio/issues/1257)If you want to distribute generated XCFrameworks, it's recommended to enable Library Evolution. Pass `--enable-library-evolution` flag if you need.
However, it means some packages can't be built.#### Build Cache System
By default, Scipio checks whether re-building is required or not for existing XCFrameworks.
```
$ swift run scipio prepare --cache-policy project path/to/MyAppDependencies
> 🔁 Resolving Dependencies...
> 🗑️ Cleaning MyAppDependency...
> ✅ Valid APNGKit.xcframework is exists. Skip building.
> ✅ Valid Delegate.xcframework is exists. Skip building.
> ❇️ Succeeded.
```Scipio supports Project/Local Disk/Remote Disk cache backends.
Using a remote cache, share built XCFrameworks among developers.
See [Learn the Cache System](https://giginet.github.io/Scipio/documentation/scipio/cache-system) for details.
### Create XCFramework from a single Swift Package
Scipio also can generate XCFrameworks from a specific Swift Package. This feature is similar to swift-create-xcframework.
```
$ scipio create path/to/MyPackage
> 🔁 Resolving Dependencies...
> 🗑️ Cleaning MyPackage...
> 📦 Building MyPackage for iOS
> 🚀 Combining into XCFramework...
> ❇️ Succeeded.
```See [Convert Single Swift Package to XCFramework](https://giginet.github.io/Scipio/documentation/scipio/create-frameworks) for detail.
## Supported Xcode and Swift version
Currently, we support Swift 6.0.
| | Xcode | Swift |
|----|------------|-------|
| ✅ | 16.0 | 6.0 |## Reliability
Scipio only builts with standard dependencies and Apple official tools to keep reliability.
### How to resolve dependencies
Just run `swift package resolve`.
### How to parse package manifests and generate Xcode projects
Scipio depends on [swift-package-manager](https://github.com/apple/swift-package-manager) as a library.
Parsing package manifests and generating Xcode project is provided from the package. So it will be maintained in the future.
### How to build XCFrameworks
Scipio only uses `xcodebuild` to build Frameworks and XCFrameworks.
## Why Scipio
Scipio names after a historical story about Carthage.