Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
SwiftPMのプラグイン機能をiOSアプリ開発に活用する / Development App...
Search
USAMI Kosuke
September 10, 2022
Programming
1
5.3k
SwiftPMのプラグイン機能をiOSアプリ開発に活用する / Development App With SwiftPM Plugins
※ Docswell に移行しました
https://www.docswell.com/s/usami-k/ZRXYJN-development-app-with-swiftpm-plugins
USAMI Kosuke
September 10, 2022
Tweet
Share
More Decks by USAMI Kosuke
See All by USAMI Kosuke
Onsager代数とその周辺 / Onsager algebra tsudoi
usamik26
0
640
Apple HIG 正式名称クイズ結果発表 / HIG Quiz Result
usamik26
0
190
ゆめみ大技林製作委員会の立ち上げの話 / daigirin project
usamik26
0
330
@ViewLoadingプロパティラッパの紹介と自前で実装する方法 / @ViewLoading property wrapper implementation
usamik26
0
480
これからUICollectionViewを実践活用する人のためのガイド / Guide to UICollectionView
usamik26
1
750
Xcodeとの最近の付き合い方のはなし / Approach To Xcode
usamik26
2
670
UICollectionView Compositional Layout
usamik26
0
800
Coding Swift with Visual Studio Code and Docker
usamik26
0
520
Swift Extension for Visual Studio Code
usamik26
2
1k
Other Decks in Programming
See All in Programming
MDN Web Docs に日本語翻訳でコントリビュートしたくなる
ohmori_yusuke
1
130
MCPで実現できる、Webサービス利用体験について
syumai
7
1.9k
Startups on Rails in Past, Present and Future–Irina Nazarova, RailsConf 2025
irinanazarova
0
290
202507_ADKで始めるエージェント開発の基本 〜デモを通じて紹介〜(奥田りさ)
risatube
PRO
3
550
11年かかって やっとVibe Codingに 時代が追いつきましたね
yimajo
0
150
The Modern View Layer Rails Deserves: A Vision For 2025 And Beyond @ RailsConf 2025, Philadelphia, PA
marcoroth
2
790
初学者でも今すぐできる、Claude Codeの生産性を10倍上げるTips
s4yuba
16
13k
「App Intent」よくわからんけどすごい!
rinngo0302
1
120
リッチエディターを安全に開発・運用するために
unachang113
1
240
No Install CMS戦略 〜 5年先を見据えたフロントエンド開発を考える / no_install_cms
rdlabo
0
190
AIコーディングエージェント全社導入とセキュリティ対策
hikaruegashira
12
7.2k
CIを整備してメンテナンスを生成AIに任せる
hazumirr
0
190
Featured
See All Featured
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
53k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
47
9.6k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
8
850
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
126
53k
Why You Should Never Use an ORM
jnunemaker
PRO
58
9.5k
Practical Orchestrator
shlominoach
189
11k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
3.9k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
229
22k
Thoughts on Productivity
jonyablonski
69
4.7k
YesSQL, Process and Tooling at Scale
rocio
173
14k
Faster Mobile Websites
deanohume
308
31k
A designer walks into a library…
pauljervisheath
207
24k
Transcript
SwiftPM のプラグイン機能を iOS アプリ開発に活用する 宇佐見公輔 / 株式会社ゆめみ
自己紹介 宇佐見公輔(うさみこうすけ) 株式会社ゆめみ / iOS テックリード このトーク以外にも、パンフレット記事を2 つ書きました。
このトークの内容 SwiftPM (Swift Package Manager )とは iOS アプリ開発でSwiftPM を活用する SwiftPM
のプラグイン機能とは iOS アプリ開発でSwiftPM プラグインを活用する ※ Swift Package Manager を略してSwiftPM と呼ぶことにする。
Swift Package Manager とは
Swift Package Manager とは Swift コードをパッケージとして管理する パッケージをビルドしてライブラリや実行プログラムを生成する ライブラリ:他のSwift コードでインポートできるモジュール 実行プログラム:シェル上で実行できるCLI
ツールなど 他のパッケージを依存物として利用できる
パッケージ パッケージはSwift ソースファイルと Package.swift で構成される ` `
Package.swift import PackageDescription let package = Package( name: "MyLibrary", products:
[ .library(name: "MyLibrary", targets: ["MyLibrary"]), ], dependencies: [], targets: [ .target(name: "MyLibrary", dependencies: []), ] )
配布されているパッケージの利用 dependencies: [ .package(url: "https://example.com/AwesomePackage", from: "1.0.0"), ], import PackageDescription
let package = Package( name: "MyLibrary", products: [ .library(name: "MyLibrary", targets: ["MyLibrary"]), ], targets: [ .target(name: "MyLibrary", dependencies: []), ] )
iOS アプリ開発で SwiftPM を活用する
Xcode プロジェクト iOS アプリはXcode プロジェクトを使って開発する
余談: Swift Playgrounds App Swift Playgrounds でも開発可能、プロジェクト形式が異なる 「ゆめみ大技林 '22 」に書いた(技術書典で配布)
※ これも面白いが、このトークではこれ以上述べない。
Xcode プロジェクトと SwiftPM 配布されているパッケージを利用する CocoaPods やCarthage で配布ライブラリを利用する代わりに、 SwiftPM で配布ライブラリを利用する アプリのコード(の一部)をパッケージ化する
コードをXcode プロジェクトの管理外に置ける
Xcode で配布パッケージを利用する Xcode の「File →Add Packages… 」で依存パッケージを追加できる ※ ライブラリ管理の手法として有益だが、このトークではこれ以上述べない。
アプリのコードをパッケージ化する ローカルのSwift パッケージをアプリでインポートする ※ このトークでは、こちらの手法を扱う。
アプリのコードをパッケージ化する 一部だけでなく、ほとんどのコードをパッケージに入れても良い
Xcode プロジェクト内のソース App.swift import UIKit import AppFeature @main final class
AppDelegate: AppFeature.AppDelegate {} final class SceneDelegate: AppFeature.SceneDelegate {}
Swift パッケージ内のソース AppDelegate.swift import UIKit open class AppDelegate: UIResponder, UIApplicationDelegate
{ public final func application(_ application: UIApplication, ...) -> Bool { return true } }
パッケージ化のメリット Xcode プロジェクト(xcodeproj )でのソースコード管理が減る xcodeproj は、ファイルの追加や削除などでGit のコンフリクトを招く Swift パッケージ管理だと、Git のコンフリクトを起こしにくい
アプリ内のモジュール分割が容易になる Swift パッケージのほうが簡単に扱える
パッケージ化で未解決の問題 ビルドスクリプトはXcode プロジェクトで管理する必要がある SwiftGen でコード生成 SwiftLint でコードチェック 実はこの問題は、SwiftPM のプラグイン機能で解決できる
SwiftPM のプラグイン 機能とは
SwiftPM のプラグイン機能 2022 年3 月のSwift 5.6 で追加された機能 コマンドプラグイン ビルド以外のタスクを定義できる ビルドツールプラグイン
ビルド時に行う処理を追加できる
プラグイン機能の活用方法 配布されているプラグインを使う 配布されているものは、現時点では多くはない プラグインを自分で実装する 独自の処理を行いたい場合はこの方法になる ※ プラグインの実装方法はパンフレット記事を参照。
ビルドツールプラグイン let package = Package( targets: [ .target( name: "MyTarget",
plugins: [ .plugin(name: "MyPlugin"), ] ), .plugin( name: "MyPlugin", capability: .buildTool() ), ] )
ビルドツールプラグインの処理内容 以下の2 つのタイミングで処理が実行される ビルド前(pre-build ) ビルド中(in-build ) プラグインであらかじめ定義された処理が実行される 処理内容を自分で決めたい場合は、プラグインを自分で実装する
外部ツールを使う プラグイン外のツールを実行できる Mac 内のコマンドを実行できる 公開されているコマンドラインツールをダウンロードできる artifact bundle 形式で公開されているバイナリが使える
iOS アプリ開発で SwiftPM プラグインを 活用する
Xcode と SwiftPM プラグイン Xcode でもSwiftPM プラグインは動作する Xcode 13.3 以降で動作する
Xcode 14 でSwiftPM 対応が改善されている(ビルドログなど) ただし、一部の動作に問題がある(後述)
事例: SwiftGen プラグイン SwiftGen 公式から、プラグインとartifact bundle が提供されている ビルド前(pre-build )にソースコード生成処理が行われる 生成先は
${DERIVED_SOURCES_DIR} 以下となる swiftgen.yml で定義する なお、ビルドツールだけでなくコマンドプラグインも提供されている ` ` ` `
SwiftGen プラグインの利用 (1) 注意:この方法が正式だが、現時点では問題がある let package = Package( dependencies: [
.package(url: "https://github.com/SwiftGen/SwiftGenPlugin", from: "6.6.2") ], targets: [ .target( name: "MyTarget", plugins: [ .plugin(name: "SwiftGenPlugin", package: "SwiftGenPlugin") ] ), ] )
Xcode で発生する問題 外部プラグイン利用時、Xcode が重くなる Xcode のCPU 使用率が100% 以上になる Xcode のエディタの動きがもたつく
外部プラグインの中でartifact bundle を使っていると発生する 外部ツールをダウンロードする機能 SwiftGen プラグインは swiftgen コマンドをartifact bundle で使用 ` `
Xcode で発生する問題の回避方法 Xcode の問題を回避するには、プラグインを自分で実装する artifact bundle の利用自体は問題ない 外部プラグインの中でartifact bundle が使われているとダメ
ローカルプラグインの中でartifact bundle を使うのは大丈夫
SwiftGen プラグインの利用 (2) let package = Package( targets: [ .plugin(
name: "SwiftGenPlugin", capability: .buildTool(), dependencies: ["swiftgen"]), .binaryTarget( name: "swiftgen", url: "https://github.com/SwiftGen/SwiftGen/releases/...", checksum: "..." ), ] )
事例: SwiftLint プラグイン SwiftLint 公式から、artifact bundle が提供されている これを利用して、自分でプラグインを実装すればよい
SwiftLint プラグインの実装 struct SwiftLintPlugins: BuildToolPlugin { func createBuildCommands(context: PluginContext, target:
Target) async throws -> [Command] { return [buildCommand( displayName: "Linting \(target.name)", executable: try context.tool(named: "swiftlint").path, arguments: [ "lint", "--in-process-sourcekit", target.directory.string ], environment: [:])] } }
SwiftLint プラグインの利用 let package = Package( targets: [ .plugin( name:
"SwiftLintXcode", capability: .buildTool(), dependencies: ["SwiftLintBinary"] ), .binaryTarget( name: "SwiftLintBinary", url: "https://github.com/realm/SwiftLint/releases/...", checksum: "..." ), ] )
まとめ Swift Package Manager (SwiftPM )とは iOS アプリ開発でSwiftPM を活用する SwiftPM
のプラグイン機能とは iOS アプリ開発でSwiftPM プラグインを活用する サンプル: https://github.com/usami-k/XcodeSwiftPMSample