0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

macOS上でVLCをソースからビルドする

Last updated at Posted at 2018-11-04

本記事は東京大学工学部電子情報・電気電子工学科の「大規模ソフトウェアを手探る」という実習の報告書を兼ねています。

はじめに

VLCは非常に多くのフォーマットに対応したマルチメディアプレーヤーです。我々の班は実習で「VLCで字幕を2言語同時に表示できるよう改造する」ことを目標にVLCを手探ることにしました。(詳しくはこの記事)本記事では、自分のPC上でVLCをビルドし、デバッガで手探れる状態にするところまでを解説します。

VLCは大規模なソフトウェアですが、(何事もなければ)簡単にビルドすることができます。早速、ビルドの方法を見ていきましょう。

環境

本記事では以下の環境を前提としています。

ソースコードの取得

まずはソースコードを取得してきましょう。Gitリポジトリが公開されているので、gitコマンドを用いてソースコードを落とします。

git clone https://git.videolan.org/git/vlc.git

ビルド

クローンが終わったら、vlcディレクトリに移動しビルド用のディレクトリbuildを作成します。作業ファイルを置いたり、ビルドされた実行ファイルやVLC.appなどを配置するためのディレクトリです。

mkdir vlc/build
cd vlc/build

VLCでは、コマンド1発で全てのビルドを行なってくれる便利なスクリプトがあるので、今回はこれを利用することにします。

VLC_CONFIGURE_ARGS="--enable-debug --disable-optimizations"  ../extras/package/macosx/build.sh -C .

../extras/package/macosx/build.shというのが、便利スクリプトです。各オプションの意味は次の通りです。

VLC_CONFIGURE_ARGS
VLC本体のビルドを行う直前に実行されるconfigureスクリプトに対するオプションはここに代入します。
--enable-debug
ランタイムアサーションが行われるようになり、自分のした変更によりおかしな挙動をしたら(orする直前に)実行を止めてくれます。これによってデバッグしやすくなります。
--disable-optimizations
コード最適化を抑制します。これにより、デバッガで追跡する際、最適化により変数の値が見えなくなったり、実行順序がソースコード通りで無くなることが防げます。
-C .
ビルドの成果物を置くディレクトリを指定します。ここでは`build`ディレクトリの中でカレントディレクトリを指定しているので、`build`ディレクトリ以下に実行ファイルなどが置かれます。

何事もなければ以上でビルドは終了です。お疲れ様でした。

macOS 10.14 Mojaveの場合

build.shを実行すると、

  • ビルドに必要なコマンド群(extras/tools)
  • VLCが利用している依存パッケージ群(contrib)
  • VLC本体

の3つがビルドされます。このうちcontribは通常、時間短縮のためビルド済みのものが利用されるのですが、Mojave用のビルド済みアーカイブが本稿執筆時点ではまだ存在していません。1仕方がないので、全部自前でビルドしましょう。この場合、build.sh-cオプションを与えればOKです。コマンドは以下のようになります。

VLC_CONFIGURE_ARGS="--enable-debug --disable-optimizations"  ../extras/package/macosx/build.sh -C . -c

困った時は

何事もなくビルドが済めば良いのですが、そうもいかないこともあります。私たちが遭遇したトラブルとその対処法を紹介しておきますので、参考にしてみてください。

ビルドが失敗した! しかし何処でエラーになったのかわからない...

VLCのビルドに失敗した時最も多くの人が抱くであろう感想はこれだと思います。ビルド用のツールや依存パッケージのビルドをする際、build.shは複数のソフトウェアのビルドを並列に走らせます。このため互いに関係のないログ同士が同時に流れることになり、問題の把握を困難にしています。

このような時は、並列度を1にするオプションを活用しましょう。build.sh-j1というオプションを与えればOKです。

VLC_CONFIGURE_ARGS="--enable-debug --disable-optimizations"  ../extras/package/macosx/build.sh -C . -c -j1

ちなみに、contribのビルドでコケるという状況で原因を探るため並列度を1にしたら、なぜかビルドに成功してしまった事例もありました。2

原因を潰してビルドをやり直しても成功しない

一度リポジトリを全て消して、クローンし直してから再度ビルドするとうまくいくことがあります。build.shを走らせるとあちこちにファイルがばら撒かれるので、全部消したほうが早いです。

どのパッケージのビルドでコケているかはわかるが、それ以上の情報を得たい

contribのビルドにおいて、どのパッケージのビルドで失敗しているかはわかったが、実行されているコマンドなどを逐一確認して原因を探りたい、という場合もあると思います。その場合はcontribディレクトリ以下から所望のパッケージを探します。Makefileなどが生成されているはずなので、make V=13などすれば、詳細なログを見ることができます。

参考

  1. Mojaveに対応するdarwinのバージョンは18ですが、x86_64-apple-darwin17 までしか存在してません。https://download.videolan.org/videolan/contrib/

  2. きちんと調べていないため推測ですが、(ビルドの順序が適切に指定されておらず)並列にビルドすることで依存元のパッケージが出来上がる前に依存先のビルドが始まってしまった、ということがあったのかもしれません。

  3. https://qiita.com/koara-local/items/4e047e47b8cde52919a6

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?