CocoaPodsを使ってObjective-Cのライブラリを管理する
最近iOSアプリの開発を始めたので, まずはライブラリ管理周りを調べ始めた. とりあえず一番有名そうなCocoaPadsを使って管理しようと思ったので, メモ代わりにブログ書いてみた.
CocoaPadsとは?
Objective-C向けのバージョン管理ツール. RubyのBundlerのObjective-C版.
CocoaPadsのインストール
CocoaPadsをインストールするには, Rubyがインストールされている必要がある. Mavericks以降だと, デフォルトでRubyの2.0がインストールされているので特に用意するものはない.
以下のコマンドでインストールする. 必要に応じてsudo
を利用する.
sudo gem install cocoapods
これでpod
コマンドがインストールされる.
CocoaPadsでのライブラリ管理
Podfile
というファイルを記述してライブラリ管理を行う.
RubyだとGemfile
で, 記述形式もほとんどGemfile
と一緒.
platform :ios, '8.0' pod 'ObjectiveSugar', '~> 0.5'
1行目でプラットフォームを指定する. 上記の場合はiOSの8.0であることを指定している.
2行目がバージョン管理を行う行で, 上記の場合はObjectiveSugarというライブラリを 0.5以降から2.0以前に制限してインストールすることを表す.
バージョンの制限には以下の方法がある. Gemfile
の記述と同じ.
記述 | 対象バージョン |
---|---|
(記述なし) | 最新版 |
0.5 | 0.5(固定) |
~> 0.5 | 0.5以降1.0以前 |
>= 0.5 | 0.5以降 |
> 0.5 | 0.5より後 |
< 0.5 | 0.5より前 |
<= 0.5 | 0.5以前 |
また, gitのレポジトリを指定することもできる.
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git'
上記の場合は, master
ブランチのheadがインストールされる. ブランチを変更したい場合は以下のようにする.
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git', :branch => 'dev'
タグを指定する場合は以下のようにする.
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git', :tag => '0.7.0'
また, コミットを明示的に指定することもできる.
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git', :commit => '082f8319af'