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
振り返りながら学ぶPackage Manager
Search
jollyjoester
September 17, 2021
Programming
2
1.8k
振り返りながら学ぶPackage Manager
iOSDC2021にて
https://fortee.jp/iosdc-japan-2021/proposal/1d9f4c94-21c2-4e38-a440-fcd01b3a5826
jollyjoester
September 17, 2021
Tweet
Share
More Decks by jollyjoester
See All by jollyjoester
AIコードアシスタントとiOS開発
jollyjoester
1
320
市民のためのセキュリティ講座
jollyjoester
0
44
コミュニティMTG in WWDC24
jollyjoester
0
310
BengaluruでLTしてきた
jollyjoester
0
350
try! Swift Tokyo 2024
jollyjoester
0
340
エンジニアが直接会う場の価値について
jollyjoester
8
4.4k
来年Proposalを出すつもりで参加するときっともっと楽しい!
jollyjoester
0
370
My favorite sessions in WWDC 23
jollyjoester
0
660
みんなでAIと戯れよう
jollyjoester
0
150
Other Decks in Programming
See All in Programming
Introducing ReActionView: A new ActionView-Compatible ERB Engine @ Kaigi on Rails 2025, Tokyo, Japan
marcoroth
3
860
開発者への寄付をアプリ内課金として実装する時の気の使いどころ
ski
0
340
そのpreloadは必要?見過ごされたpreloadが技術的負債として爆発した日
mugitti9
2
2.8k
GraphQL×Railsアプリのデータベース負荷分散 - 月間3,000万人利用サービスを無停止で
koxya
1
1k
monorepo の Go テストをはやくした〜い!~最小の依存解決への道のり~ / faster-testing-of-monorepos
convto
2
130
Go Conference 2025: Goで体感するMultipath TCP ― Go 1.24 時代の MPTCP Listener を理解する
takehaya
7
1.5k
uniqueパッケージの内部実装を支えるweak pointerの話
magavel
0
880
いま中途半端なSwift 6対応をするより、Default ActorやApproachable Concurrencyを有効にしてからでいいんじゃない?
yimajo
2
310
Serena MCPのすすめ
wadakatu
4
860
PostgreSQLで手軽にDuckDBを使う!DuckDB&pg_duckdb入門/osk2025-duckdb
takahashiikki
1
230
Django Ninja による API 開発効率化とリプレースの実践
kashewnuts
0
870
なぜGoのジェネリクスはこの形なのか? Featherweight Goが明かす設計の核心
ryotaros
7
1k
Featured
See All Featured
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.4k
Raft: Consensus for Rubyists
vanstee
139
7.1k
Optimising Largest Contentful Paint
csswizardry
37
3.4k
The Language of Interfaces
destraynor
162
25k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Fireside Chat
paigeccino
40
3.7k
KATA
mclloyd
32
14k
GitHub's CSS Performance
jonrohan
1032
460k
How to train your dragon (web standard)
notwaldorf
96
6.3k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
15k
Testing 201, or: Great Expectations
jmmastey
45
7.7k
Embracing the Ebb and Flow
colly
88
4.8k
Transcript
振り返りながら学ぶPackage Manager 2021/09/17 iOSDC2021 jollyjoester
自己紹介 jollyjoesterです。 iPhoneに魅せられてiOSエンジニアに。 Swift愛好会やってます🍻 4年ぶり2回目のiOSDC発表で嬉しい🙌
このセッションではPackage Managerまだ詳しくない勢の方が 基本的な概念や仕組みといった知識を得て より適切にPackage Managerとお付き合いできるようになること を目標としています。 「なんかCarthageでエラーが出てるけどわからん→爆死」 「Swift PMが流行ってる!よくわからないけど早く移行しなきゃ→爆死」 みたい悲劇に適切に立ち向かえるようにしていきましょう💪
このセッションについて
• Package Managerとは? • iOSにおけるPackage Manager • 各Package Managerの仕組み •
周辺技術の歴史と進化 • まとめ アジェンダ
Package Managerとは
Package Manager > 各種のソフトウェアの導入と削除、そしてソフトウェア同士やライブラリとの依存関係を 管理するシステムである。by パッケージ管理システム:wikipedia いろいろな範囲を対象としたPackage Managerがある • Linux
: APT • Ruby : RubyGems • iOS: ◦ CocoaPods ◦ Carthage ◦ Swift Package Manager
Package Managerの機能 おおよそのPackage Managerが持っている機能 • どんなパッケージがあるのかを探す • 必要なパッケージのインストール・削除 • 依存関係の解決
• 設定管理
iOSにおけるPackage Manager
代表的なものは下記の3つ • CocoaPods • Carthage • Swift Package Manager iOSにおけるPackage
Manager
CocoaPodsの概要 登場 : 2011年 Platform : iOS, macOS, watchOS, tvOS
開発 : オープンソース、Ruby製 基本的な特徴 : • ソースベースの利用 ◦ アプリのビルド時にライブラリのビルドも行う • Xcode projectとの自動統合 • Centralized
Carthage 登場 : 2014年 Platform : iOS, macOS, watchOS, tvOS
開発 : オープンソース、Swift製 基本的な特徴 : • バイナリベースの利用 ◦ 事前にビルドしてライブラリを使う • Xcode projectは基本触らないよ • シンプル(依存解決とビルドのみ) • Decentralized
Swift Package Manager(Swift PM or SPM) 登場 : 2017年 •
Xcode11からiOSでも使いやすく Platform : iOS, macOS, watchOS, tvOS, Linux 開発 : オープンソース、Swift製、Apple製 基本的な特徴 : • 動きはCarthageに近い印象を受けるがManual運用は不要 • 標準!SwiftのビルドシステムやXcodeに組み込まれている • Cocoaアプリを超えてSwift言語のためのあらゆる環境で使える
各Package Managerの仕組み
③ライブラリのメタ データ(podspec) Specsに格納 CocoaPodsの使い方 ~ 提供者側 ~ GitHub等 Specs ①開発
②リポジトリに ソース等を格納 CocaPods/Specs c.f. Using Pod Lib Create
CocoaPodsの仕組み ~ 使用者側 ~ $ pod init $ pod install
①Podfile作る ②Podfile書く ③インストールする App.xcworkspace Podfile ④xcworkspace開く ⑤実行 ビルド▶
CocoaPodsの仕組み ~ 使用者側 ~ $ pod init $ pod install
①Podfile作る ②Podfile書く ③インストールする App.xcworkspace Specs GitHub Pods Podfile Spec見る ソース ダウンロード xcworkspace作る App.xcodeproj Pods.xcodeproj 統合 Podfile.lock ④xcworkspace開く 作成 ⑤実行 ビルド▶
Carthageの使い方 ~ 提供者側 ~ GitHub ①開発 ②リポジトリに ソース等を格納
Carthageの使い方 ~ 使用者側 ~ Cartfile ②インストールする $ carthage update --platform
iOS --use-xcframeworks ①Cartfile書く ③Xcodeprojに 紐付ける ④実行 ビルド▶ xcframework Manual
Carthageの仕組み ~ 使用者側 ~ Cartfile ②インストールする $ carthage update --platform
iOS --use-xcframeworks ①Cartfile書く ③Xcodeprojに 紐付ける Carthage GitHub Build checkouts ダウンロード ビルド▶ ④実行 ビルド▶ Manual xcframework Cartfile.resolved
Swift Package Managerの使い方 ~ 提供者 ~ GitHub ②開発 ③リポジトリに Package.swiftと
ソース等を格納 Package.swift ①Package.swift書く
Swift Package Managerの使い方 ~ 使用者側 ~ ①Xcodeで追加する Xcodeproj ②実行 ビルド▶
Swift Package Managerの仕組み ~ 使用者側 ~ ①Xcodeで追加する Xcodeproj ②実行 ビルド▶
DerivedData GitHub Build SourcePackage ダウンロード ビルド リンク
基本的な共通の仕組み ライブラリ提供者側 • ソースをGitHubに置く ◦ メタデータ的なものも置く場合も ライブラリ使用者側 • 何かしらの設定ファイルにライブラリの場所&バージョンを指定して •
ダウンロードしてきて(ソース?バイナリ?) • ビルドして(事前?アプリビルド時?) • プロジェクトにリンクして(自動?手動?) • 使う
周辺技術の歴史と進化
10 0.0.1 iOSアプリ開発におけるPackage Managerの歴史 2007 2008 2009 2010 2011 2012
2013 2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 0.38.0
10 0.0.1 Before CocoaPods 2007 2008 2009 2010 2011 2012
2013 2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 0.38.0 ◯Before CocoaPodsの時代 .aファイルとかを手動で入れてたりした記 憶がある 1.5.0 1.9.0
10 0.0.1 CocoaPods浸透 2007 2008 2009 2010 2011 2012 2013
2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 0.38.0 1.5.0 1.9.0 ◯CocoaPods浸透の時代 Package ManagerというものがiOS界隈 にも浸透 多くのライブラリがCocoaPodsに対応 このときはまだstatic libraryが主
10 0.0.1 Swiftの登場 2007 2008 2009 2010 2011 2012 2013
2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 ◯Swiftの登場 Swift登場! iOS dynamic frameworkサポート CocoaPods use_framework!サポート (dynamic framework) Carthage登場! 0.38.0 1.5.0 1.9.0
10 0.0.1 Swiftの浸透 2007 2008 2009 2010 2011 2012 2013
2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 ◯Swiftの浸透 Swift 多くのアプリで使われるように 課題: • アプリ肥大化 ◦ ビルド遅い • frameworkの多用 ◦ アプリの起動速度遅い • CI普及 Swift Package Manager 登場! 0.38.0 1.5.0 1.9.0
10 0.0.1 Swift周辺のビルド環境の進化 2007 2008 2009 2010 2011 2012 2013
2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 ◯Swift周辺の進化 Swift5.1 モジュールの安定化 Xcode10 SwiftのモジュールをStatic frameworkとしてビルドできる ように Xcode12 xcframeworkサポート Xcode11 XcodeからSwift Package Managerを使えるように 0.38.0 1.5.0 1.9.0
10 0.0.1 そして現在へ 2007 2008 2009 2010 2011 2012 2013
2014 2015 2016 2017 2018 2019 2020 2021 iOS Xcode CocoaPods Carthage SwiftPM Swift iPhone OS 1.0 iOS 4.0 iOS 8.0 iOS15 Swift 5.1 11 Swift 1.0 0.1 6 0.1 0.6.0 12 Swift 3.0 0.36.0 1.11.0 0.38.0 1.5.0 1.9.0 ◯成熟してきた? Swift Package Manager • リソースを含められるように CocoaPods, Carthage, Swift PM • xcframework対応 様々な課題が解決しつつある・・・
今後のPackage Managerについての私見 CocoaPods, Carthageも現役で使えることを確認しつつ、特に実用的になってきたSwift Package Managerに期待が高まった。 特にSwiftやXcodeと深く統合されていることを活かしてこれまでのPackage Manager が超えられなかった変化を期待したい。 e.g.
• xcodeprojという古い仕組みからの脱却 • CI利用を前提とした機能 各Package Managerは併用できるのでSwift Package Managerの検証を始めるちょう ど良いタイミングではないか。
まとめ
このセッションでは • Package Managerとは何かをおさらいしました。 • iOSにおける代表的なPackage Managerの仕組みをおさらいしました。 • Package Managerの周辺技術の発展の歴史をおさらいしました。
Package Managerとより良くお付き合いするヒントになれば幸いです。 変化していくiOS界隈を一緒に楽しんでいきましょう〜🍻 まとめ
メモ
おまけ:私見 • CocoaPods, Carthage, Swift Package Managerはそれぞれ進化していて 有用になった • Swift
Package Managerは急激に進化していて実用レベルに • そろそろ標準のSwift Package Managerだけサポートしたいというライブラリ 提供者が出てくるだろう • 各Package Managerは併用できるのでSwift Package Managerを試しはじ めておくと良いだろう • たぶん1, 2年単位で変化が来ると予想。 • あせらず自身のProjectとの状況を踏まえあせらず準備していこう。 🤔