【CarthageとCocoapods】 2種類のライブラリ管理ツールとその使い分けについて解説

使い分けはCarthageを優先する

まず両者の運用やパフォーマンスについての要点を簡単にまとめるとこうなるよ

  • CocoaPodsとCarthageは併用可能
  • CocoaPodsでしかインストールできないライブラリも存在する
  • Carthageの方がCocoaPodsと比較して軽量である

両者の使い分けについて明確な正解があるわけではないけど、上記のことを鑑みると一般に「Carthageで導入できるライブラリは優先的にCarthageで導入し、それ以外はCocoaPodsで導入する」という使い分けが良いとされているよ

Carthage・CocoaPodsの導入方法

CarthageはHomebrew、CocoaPodsはGemでインストールすることができるよよ。

・Carthageの導入

brewコマンドが使えない場合はhomebrewの解説を参考にインストールを済ませておこう。

brew install carthage

・CocoaPodsの導入

CocoaPodsはgemを使ってインストールする。gemコマンドが使えない場合は、

sudo gem install cocoapods
pod setup

付随してコマンドラインツールのインストールも必要だよ。まだの人はやっておこう

xcode-select --install

次にそれぞれの仕様と使い方についてまとめておくよ

CocoaPodsの仕様と使い方

CocoaPodsはCarthageと比べて比較的楽に導入できるので、先に解説してしまうよ

・CocoaPodsの仕様

まずCocoaPodsの主な仕様をまとめるとこんな感じだよ

  • 導入するライブラリの情報はPodfileに記述する
  • 各ライブラリのバージョン情報はインストール時に自動生成されるPodfile.lockに保存されている
  • インストール時に拡張子.xworkspaceのファイルが自動生成される。CocoaPodsでインストールしたライブラリをインポートし使うことができる
  • ライブラリのソースファイルはPods/内に保存されるが、gitの管理対象からは外す

・CocoaPodsの使い方

仕様がわかったところで次に実際の使い方について説明するよ

1. Podfileの編集

まずプロジェクトのルートディレクトリ下で以下のコマンドを実行するよ

pod init

するとPodfileというファイルが自動生成されるよ。このPodfileにインポートしたいライブラリの情報を記述するよ。例えば定番ライブラリのRealmSwiftをインストールしたい時はPodfileはこのようになるよ

# Uncomment the next line to define a global platform for your project
# platform :ios, '9.0'

target 'Sample' do
  # Comment the next line if you don't want to use dynamic frameworks
  use_frameworks!

  # Pods for Sample
  pod 'RealmSwift'  #追記
end

まぁ簡単だね

2. インストール

Podfileの編集が完了したら、以下のコマンドでライブラリのインストールを行うよ

pod install

インストールが終了すると拡張子が.xcworkspaceというファイルが自動生成されるよね。以後、cocoapodsでインストールしたライブラリを使って開発する際はこのファイルをプロジェクトファイルとして使うよ。

3. .gitignoreファイルの編集

最後にインストールが完了するとPodsというフォルダが生成されているはず。このフォルダの中にはライブラリのソースファイルが格納されているけど、このソースファイルはgitで管理しないよ。
ではどうするかというと.gitignoreを編集し、「Pods」以下のファイル群はgit管理下から外しておけばおkだよ。その代わりにライブラリとそのバージョン情報が記述されているPodfilePodfile.lock のみを管理するようにするのが良いよ。

vim .gitignore

等のコマンドでエディタを開いて追記

Pods/*

Carthageの仕様と使い方

続いてCarharthageの仕様と使い方について説明していくよ。Cocoapodsと比べると若干工数がかかるよ

・Carthageの仕様

まずCarthageの主な仕様をまとめるとこうなるよ

  • 導入するライブラリの情報はCartfileに記述する
  • 各ライブラリのバージョン情報はライブラリのビルド時に自動生成されるCartfile.resolvedに保存される
  • ライブラリのソースファイルたちはCarthage/内に保存されるが、gitの管理対象からは外す

・Carthageの使い方

続いてCarthageの使い方について説明するよ。まずプロジェクトファイルのルートディレクトリに移動します。

1. Cartfileの作成と記述

touchコマンドでCartfileを作成するよ。

touch Cartfile

Cartfileには下のように導入したいライブラリのgithubレポジトリ名を記述するよ。

github "ishkawa/APIKit"
github "onevcat/Kingfisher"

2. ビルド

Cartfileへの記述が終わったら次はビルドコマンドを打ち込むよ。

carthage update --platform iOS --no-use-binaries

ビルドする際はcarthage installにオプションを2つつけておくと良いです。簡単に解説すると--platform iOSのようにデバイスを指定することでビルド時間を短縮できます。--no-use-binariesを付けるとバイナリデータからのビルドではなく、ソースコードからコンパイルすることでビルドを行うことができます。そこそこ時間はかかります。

3. Build Phasesの設定で.frameworkファイルのインポートを行う

CocoaPodsと違いCarthageでビルドしたライブラリをインポートするためにはxcodeでプロジェクトファイルを選択し「TARGETS」→「Build Phases」の項目にいくつか設定を追加する必要があります。

「Link Binary with Libaries」の欄を選択し、「+ボタン」→「add other...」→「add Files」と進み、「Carthage/Build/iOS」フォルダ内にある拡張子が.frameworkのものを選択します。下の画像を例にするとAPIKit.frameworkというライブラリが追加されているのがわかると思います

import framework file

続いて左上の「+ボタン」→「New Run Script Phase」を選択します。すると「Run Script」という項目が追加されるので、まずShellの欄に以下のスクリプトを記入します

/usr/local/bin/carthage copy-frameworks

次に「Input files」の欄でファイルパスを記入します。hogehoge.frameworkのところは導入するライブラリに応じて適宜変更してください。

$(SRCROOT)/Carthage/Build/iOS/hogehoge.framework

例えばAPIKitというライブラリを導入したい時は下のように設定します。 input files example

4 .gitignoreファイルの編集

最後に、ビルドが完了するとCarthageというフォルダが生成されているはず。このフォルダの中にはライブラリのソースファイルが格納されているけど、このソースファイルをgitで管理しないよ。.gitignoreを編集し、Carthage以下のファイル群はgit管理下から外しておけばおkだよ。その代わりにライブラリの情報が記述されているCartfileCartfile.resolved のみを管理するようにしよう

vim .gitignore

等のコマンドでエディタを開いて以下を追記

Carthage/*

まとめ

  • CarthageはCocoapodsに比べて軽量。よってCarthageでインストールできるライブラリはCarthageを使おう
  • 両者ともにライブラリのソースファイル自体を管理するのではなく、CartfilePodfileのような各ライブラリのバージョン情報が記述されたファイルのみ管理しよう

Published under  on .

Last updated on .

サクプロ

プログラミング初心者に向けて、体系的なサイト作りを心がけて情報発信していくよ
当サイト、あるいは僕に興味のある人はこのページを見て欲しいよ