「パッケージの作成」の版間の差分
1行目: | 1行目: | ||
[[Category:Arch について]] |
[[Category:Arch について]] |
||
[[Category:パッケージ管理]] |
[[Category:パッケージ管理]] |
||
− | [[cs:Creating |
+ | [[cs:Creating packages]] |
− | [[en:Creating |
+ | [[en:Creating packages]] |
− | [[es:Creating |
+ | [[es:Creating packages]] |
− | [[fr: |
+ | [[fr:Standard paquetage]] |
− | [[it:Creating |
+ | [[it:Creating packages]] |
− | [[ru:Creating |
+ | [[ru:Creating packages]] |
− | [[tr: |
+ | [[tr:Paket oluşturma]] |
− | [[zh- |
+ | [[zh-cn:Creating packages]] |
{{Related articles start}} |
{{Related articles start}} |
||
{{Related|Arch Build System}} |
{{Related|Arch Build System}} |
||
66行目: | 66行目: | ||
== PKGBUILDの作成 == |
== PKGBUILDの作成 == |
||
− | パッケージ作成に必要な情報は全て <code>PKGBUILD</code> に書かれています。<code>makepkg</code> は実行されると、カレントディレクトリに <code>PKGBUILD</code> ファイルがあるか探し、そこに書かれていることに従ってソフトウェアのソースコードをコンパイルします。{{ic|PKGBUILD}} に書かれている指示は、[[ |
+ | パッケージ作成に必要な情報は全て <code>PKGBUILD</code> に書かれています。<code>makepkg</code> は実行されると、カレントディレクトリに <code>PKGBUILD</code> ファイルがあるか探し、そこに書かれていることに従ってソフトウェアのソースコードをコンパイルします。{{ic|PKGBUILD}} に書かれている指示は、[[Bash]] として実行可能である必要があります。コンパイルが無事終了すれば、出来上がったバイナリと、バージョンや依存パッケージなどのパッケージのメタデータが <code>''パッケージ名''.pkg.tar.xz</code> にまとめられます。このパッケージファイルは <code>pacman -U ''パッケージファイル''</code> でインストールすることができます。 |
新しいパッケージを作るには、まず空の作業ディレクトリを用意します ({{ic|~/abs/''パッケージ名''}} が推奨です)。このディレクトリにファイル {{ic|PKGBUILD}} を作成します。プロトタイプとして、{{ic|/usr/share/pacman/PKGBUILD.proto}} や、類似パッケージの {{ic|PKGBUILD}} が使えます。オプションを変更するだけなどの場合、後者が便利になるかもしれません。 |
新しいパッケージを作るには、まず空の作業ディレクトリを用意します ({{ic|~/abs/''パッケージ名''}} が推奨です)。このディレクトリにファイル {{ic|PKGBUILD}} を作成します。プロトタイプとして、{{ic|/usr/share/pacman/PKGBUILD.proto}} や、類似パッケージの {{ic|PKGBUILD}} が使えます。オプションを変更するだけなどの場合、後者が便利になるかもしれません。 |
||
94行目: | 94行目: | ||
pacman 4.1 から採用され、makepkg の実行中に pkgver 変数を更新することができます。{{ic|pkgver()}} はソースが取得・展開されたすぐ後に実行されます。 |
pacman 4.1 から採用され、makepkg の実行中に pkgver 変数を更新することができます。{{ic|pkgver()}} はソースが取得・展開されたすぐ後に実行されます。 |
||
− | [[VCS |
+ | [[VCS パッケージガイドライン|git/svn/hg などのパッケージを作成する]]ときにこの関数は特に便利です。なぜならビルドプロセスは同じままでも、ソースは毎日・毎時間更新される可能性があるからです。昔は日時を pkgver フィールドに入れていたため、ソフトウェアが更新されていなくても、makepkg はバージョンが変更されたと考えてリビルドをしていました。この関数では {{ic|git describe}}, {{ic|hg identify -ni}} などのコマンドが有用です。PKGBUILD を投稿する前に、{{ic|pkgver()}} 関数がビルドを停止させないかテストしてください。 |
{{Note|pkgver には空白やハイフン ({{ic|-}}) を含めることができません。sed を使って対処してください。}} |
{{Note|pkgver には空白やハイフン ({{ic|-}}) を含めることができません。sed を使って対処してください。}} |
||
105行目: | 105行目: | ||
====関数 {{ic|build()}} ==== |
====関数 {{ic|build()}} ==== |
||
− | さて、{{ic|PKGBUILD}} ファイルの中に {{ic|build()}} 関数を定義しなくてはなりません。この関数、<code>build()</code> は [[ |
+ | さて、{{ic|PKGBUILD}} ファイルの中に {{ic|build()}} 関数を定義しなくてはなりません。この関数、<code>build()</code> は [[Bash]] の文法を使って、ソフトウェアを自動的にコンパイルします。そして {{ic|pkg}} ディレクトリを作成しここにソフトウェアをインストールします。これによって ''makepkg'' はファイルシステムをふるいにかけることなくファイルをパッケージにまとめることができます。 |
{{ic|build()}} 関数はまず展開されたソースコードのディレクトリに入ります。''makepkg'' は {{ic|build()}} を実行する前にカレントディレクトリを {{ic|$srcdir}} に移動するので、ほとんどの場合最初のコマンドは以下のようになるでしょう: |
{{ic|build()}} 関数はまず展開されたソースコードのディレクトリに入ります。''makepkg'' は {{ic|build()}} を実行する前にカレントディレクトリを {{ic|$srcdir}} に移動するので、ほとんどの場合最初のコマンドは以下のようになるでしょう: |
2015年11月9日 (月) 09:40時点における版
関連記事
この記事は、Arch Linux の ports 風のビルドシステムを使ってパッケージを自作するユーザーの助けになることを目的としています。この記事の扱う範囲は PKGBUILD (makepkg
によって読み込まれるパッケージ定義ファイル) の書き方についてです。すでに PKGBUILD が用意できている場合、makepkg の項目を参照してください。パッケージの質を向上させるためのルール・方法などの説明は Arch パッケージングスタンダードを参照してください。
目次
概要
Arch Linux のパッケージは、makepkg ユーティリティーと PKGBUILD に記載された情報からビルドされます。makepkg
が実行されると、カレントディレクトリの PKGBUILD
を見て、ソースをコンパイルするか必要なファイルをダウンロードするかの指示に従ってパッケージファイル (pkgname.pkg.tar.xz
) が作成されます。こうして出来上がったパッケージはバイナリとインストールの実行スクリプトが含まれ、pacman でインストールできるものになります。
Arch のパッケージは、以下のファイルが tar アーカイブ、つまり 'tarball' にまとめられ、xz で圧縮されたものです。
- インストールするバイナリやファイル。
.PKGINFO
: pacman でパッケージ管理や依存解決をするために必要なすべての情報が書かれたファイル。.MTREE
: ファイルのハッシュとタイムスタンプ。ローカルデータベースに含めることで pacman はパッケージの整合性を検証することができます。.INSTALL
: 任意のファイル。インストール/アップグレード/削除の後に実行される (PKGBUILD
で指定された場合のみ存在する)。.Changelog
: パッケージメンテナによるパッケージの更新についての覚え書き (必ず付属するとは限らない)。
準備
ソフトウェアの準備
まず、必要なツールがインストールされているか確認してください。 base-devel があれば十分です。このグループには make などのコンパイルに必要なツールが含まれています。
# pacman -S base-devel
pacman で提供される makepkg はパッケージ作成で最も重要なツールの一つです。makepkg は以下を行います:
- 依存パッケージがインストールされているかどうか確認する。
- ソースをサーバーからダウンロードする。
- 圧縮されたソースファイルを展開する。
- fakeroot 環境でコンパイルし、インストールする。
- バイナリやライブラリから不要シンボルを除去する (symbol stripping)。
- パッケージのメタデータを生成する。
- fakeroot 環境をパッケージに圧縮する。
- パッケージファイルを出力先ディレクトリに保存する。デフォルトでは作業ディレクトリ。
インストールのダウンロードとテスト
パッケージにしたいソフトウェアのソース tarball をダウンロードして、展開してください。その後ソフトウェアの作成者の指示に従ってプログラムをインストールしてください。ソフトウェアをコンパイル・インストールするのに必要なコマンド・手順を全て手控えておきましょう。PKGBUILD ファイルの中で同じコマンドを使うことになります。
ほとんどのソフトウェアは3ステップでビルドします:
./configure make make install
プログラムが正しく動作するか確認すると良いでしょう。
PKGBUILDの作成
パッケージ作成に必要な情報は全て PKGBUILD
に書かれています。makepkg
は実行されると、カレントディレクトリに PKGBUILD
ファイルがあるか探し、そこに書かれていることに従ってソフトウェアのソースコードをコンパイルします。PKGBUILD
に書かれている指示は、Bash として実行可能である必要があります。コンパイルが無事終了すれば、出来上がったバイナリと、バージョンや依存パッケージなどのパッケージのメタデータが パッケージ名.pkg.tar.xz
にまとめられます。このパッケージファイルは pacman -U パッケージファイル
でインストールすることができます。
新しいパッケージを作るには、まず空の作業ディレクトリを用意します (~/abs/パッケージ名
が推奨です)。このディレクトリにファイル PKGBUILD
を作成します。プロトタイプとして、/usr/share/pacman/PKGBUILD.proto
や、類似パッケージの PKGBUILD
が使えます。オプションを変更するだけなどの場合、後者が便利になるかもしれません。
PKGBUILD の変数を定義する
PKGBUILD のサンプルは /usr/share/pacman/
にあります。PKGBUILD
で利用できる変数は PKGBUILD の記事で説明されています。
パッケージをビルドするために必要な以下の三つの変数は、makepkg によってあらかじめ定義されます:
startdir
PKGBUILD
のあるディレクトリへの絶対パスです。$startdir/src
や$startdir/pkg
として$srcdir
や$pkgdir
の代わりに使われていましたが、今ではこれらが一致する保証はありません。この変数を使うことは非推奨です、使うべきでありません。srcdir
makepkg
がソースファイルを展開、またはコピーしてくるディレクトリです。pkgdir
- build() が終わった後、
makepkg
はここに生成されたファイルをパッケージに入れます。ここがパッケージのルートディレクトリになります。
これらの変数は全て絶対パスなので、適切にこれらの変数を使う限り作業ディレクトリについて心配する必要はありません。
PKGBUILD の関数
5つの関数が存在し、全て存在する場合ここに記載している順番どおりに実行されます。関数が存在しないときは、スキップされます。
関数 pkgver()
pacman 4.1 から採用され、makepkg の実行中に pkgver 変数を更新することができます。pkgver()
はソースが取得・展開されたすぐ後に実行されます。
git/svn/hg などのパッケージを作成するときにこの関数は特に便利です。なぜならビルドプロセスは同じままでも、ソースは毎日・毎時間更新される可能性があるからです。昔は日時を pkgver フィールドに入れていたため、ソフトウェアが更新されていなくても、makepkg はバージョンが変更されたと考えてリビルドをしていました。この関数では git describe
, hg identify -ni
などのコマンドが有用です。PKGBUILD を投稿する前に、pkgver()
関数がビルドを停止させないかテストしてください。
関数 prepare()
Pacman 4.1 から prepare()
関数が導入されました。この関数では、パッチなどの、ソースをビルドする前の準備に使われるコマンドを実行します。この関数は build 関数の前、パッケージの展開の後に実行されます。展開が省略された場合 (makepkg -e
)、prepare()
は実行されません。
関数 build()
さて、PKGBUILD
ファイルの中に build()
関数を定義しなくてはなりません。この関数、build()
は Bash の文法を使って、ソフトウェアを自動的にコンパイルします。そして pkg
ディレクトリを作成しここにソフトウェアをインストールします。これによって makepkg はファイルシステムをふるいにかけることなくファイルをパッケージにまとめることができます。
build()
関数はまず展開されたソースコードのディレクトリに入ります。makepkg は build()
を実行する前にカレントディレクトリを $srcdir
に移動するので、ほとんどの場合最初のコマンドは以下のようになるでしょう:
cd "$pkgname-$pkgver"
/usr/share/pacman/PKGBUILD.proto
ファイルでは上のコマンドの代わりに次のコマンドを使うことを提案しています:
cd "$srcdir/$pkgname-$pkgver"
ただし、$srcdir
は絶対パスなので違いはありません。
そして、手動でソフトウェアをコンパイルをするのと同じコマンドを書き連ねます。build()
関数は、煎じ詰めて言えば手でコンパイルするのに必要な操作を自動化したものなのです。今パッケージしているソフトウェアが configure を使っているのなら、--prefix=/usr
を使うのが良いでしょう。(多くのソフトウェアがファイルをインストールするのに使う) /usr/local
ディレクトリは、手動でインストールする場合のみに限って使われるべきです。すべての Arch Linux パッケージは、/usr
ディレクトリを使うべきです。/usr/share/pacman/PKGBUILD.proto
に書かれているように、次の2行はだいたい以下のようになるでしょう:
./configure --prefix=/usr make
関数 check()
ここでは make check
などのテストを動作させます。ソフトウェアが正しくビルドできたか確認したり依存関係が問題ないか調べるのに役立つので check()
を記述することは推奨されています。
テストの必要のないユーザー(や、時にはテストを通過させるようにパッケージを修正できないメンテナ)は、PKGBUILD や makepkg.conf で BUILDENV+=('!check')
オプションを指定する (もしくは --nocheck
フラグを付けて makepkg
を呼び出す) ことで、これをスキップできます。
関数 package()
最後に、コンパイルされたファイルを、makepkg がファイルを読み込むことができる(そしてパッケージを作成する)ディレクトリに置きます。デフォルトでは pkg
ディレクトリです。このディレクトリは単なる fakeroot 環境です。すなわち、このディレクトリはインストール先のファイルシステムの /
(root ファイルシステム) に相当します。インストールするファイルは全て pkg
以下に、ディレクトリ構造を保ったまま置かれる必要があります。例えば、ファイルを /usr/bin
にインストールさせたい場合は ${pkgdir}/usr/bin
にファイルを置きます。数ダースのファイルを手動でコピーしなくてはならない場合はほとんどありません。ほとんどのソフトウェアでは、代わりに make install
を呼び出すことでコピーが行われます。ソフトウェアを pkg
ディレクトリに正しくインストールするために、最後の行は以下のようになるでしょう:
make DESTDIR="$pkgdir/" install
稀に、一つのディレクトリの中にすべてのファイルが置かれ、ソフトウェアをそこから実行するようにされていることがあります。こうした場合には、そのディレクトリを $pkgdir/opt
にコピーするのが賢明です。
多くの場合では、pkg
下のサブディレクトリはインストールプロセスで自動的に作られます。しかし、そうでない場合は makepkg は大量のエラーを吐いて失敗します。この場合、必要なサブディレクトリを build()
関数内で mkdir -p
コマンドを実行することで、インストール作業の前にあらかじめ生成してください。
昔のパッケージでは package()
関数はなく、この操作は build()
でまとめて行われていました。PKGBUILD
に build()
がない場合は、build()
全体が fakeroot で実行されます。package()
が定義されている場合、build()
は makepkg
を実行したユーザで実行され、package()
だけが fakeroot で実行されます
また、makepkg --repackage
は package()
だけを呼び出します。パッケージの depends
変数をだけ変更したときなどに、ソースを再コンパイルせずパッケージを作成ができ、時間を節約することができます。
PKGBUILD とパッケージのテスト
build()
関数を記述している間、バグがないことを確認するために変更をテストしたくなるかもしれません。PKGBUILD
ファイルが含まれているディレクトリで makepkg
コマンドを実行してすることでテストすることができます。フォーマットが正しい PKGBUILD
なら、makepkg はパッケージを作成します。PKGBUILD
が壊れていたり未完成だと、エラーを吐きます。
makepkg は問題なく終了すると、作業ディレクトリに pkgname-pkgver.pkg.tar.xz
という名前のファイルを作成します。このパッケージは pacman -U
コマンドでインストールすることができます。ただし、パッケージファイルが作られたというだけでは完全に機能するとは言えません。あるいはディレクトリだけでファイルが全く含まれていない可能性もあります (例えば、prefix が間違って指定されているとか)。pacman の query 関数を使うことでパッケージに含まれているファイルのリスト、パッケージが必要とする依存パッケージを pacman -Qlp [package file]
と pacman -Qip [package file]
でそれぞれ表示することができます。
パッケージが問題ないようでしたら、これであなたの作業は終了です!ただし、PKGBUILD
ファイルを公開するつもりならば、depends
の中身を何度もチェックするべきです。
また、パッケージバイナリが完璧に動くことを確認しましょう!全ての必要なファイルが含まれているが、(システムの他の部分と問題を起こすような)度しがたい設定オプションによってクラッシュするパッケージを公開するのは迷惑です。勿論、あなた自身のためだけにパッケージをコンパイルするのなら、品質保証について心配しすぎる必要はありません。誤りによって苦しむのはあなただけなのですから。
パッケージの正常性のテスト
パッケージが機能するかテストした後 namcap を使ってエラーがないか確認してください:
$ namcap PKGBUILD $ namcap <package file name>.pkg.tar.xz
Namcap は以下を行います:
- PKGBUILD の中身を見て、よくある間違いやパッケージファイルの階層に不必要な・間違って置かれたファイルがないか確認します。
ldd
を使ってパッケージ内の全ての ELF ファイルをスキャンし、必要な共有ライブラリがあるパッケージがdepends
に欠けていることや、推移的な依存として省略できるパッケージを自動で報告します。- 欠けている、もしくは不要な依存パッケージのヒューリスティック検索。
などなど。パッケージを namcap でチェックする習慣を実践することでパッケージを投稿した後に単純な間違いを修正する手間が省けます。
AUR にパッケージを送信する
Arch User Repository#パッケージを投稿する に、投稿する方法について詳しい説明があります。
要約
- パッケージにしたいソフトウェアのソース tarball をダウンロードする。
- パッケージのコンパイルを試行し任意のディレクトリにインストールする。
- プロトタイプの
/usr/share/pacman/PKGBUILD.proto
をコピーしてPKGBUILD
に名前を変更して一時的な作業ディレクトリに置く --~/abs/
が推奨。 - パッケージの必要に応じて
PKGBUILD
を編集する。 makepkg
を実行して作られたパッケージが正しくビルドされているか確認する。- 正しくビルドされるまで、前の2つの手順を繰り返す。
注意点
- パッケージのビルドプロセスを自動化する前に、あらかじめ何をするのか正確にわかっている場合(その場合あなたはそもそもこの文章を読まないと思いますが)を除いて、少なくとも一度は手動でビルドを行なって下さい。残念ながら、大勢のプログラムの作者が "
./configure
;make
;make install
" のビルド3ステップに従っているにもかかわらず、これがいつも上手く行くとは限りません。下手をすると、全てを問題なく動かすにはパッチを適用する必要がある場合も考えられます。大雑把に言うと: プログラムをソース tarball からコンパイルして、規定の一時サブディレクトリにインストールすることができない場合、パッケージングを試行する必要さえありません。makepkg
にはソースの問題を解決してくれるような妖精の粉はないからです。 - In a few cases, the packages are not even available as source and you have to use something like
sh installer.run
to get it to work. You will have to do quite a bit of research (read READMEs, INSTALL instructions, man pages, perhaps ebuilds from Gentoo or other package installers, possibly even the MAKEFILEs or source code) to get it working. In some really bad cases, you have to edit the source files to get it to work at all. However,makepkg
needs to be completely autonomous, with no user input. Therefore if you need to edit the makefiles, you may have to bundle a custom patch with thePKGBUILD
and install it from inside theprepare()
function, or you might have to issue somesed
commands from inside theprepare()
function.
より詳細なガイドライン
32ビット – CLR – クロス – Eclipse – Electron – Free Pascal – GNOME – Go – Haskell – Java – KDE – カーネル – Lisp – MinGW – Node.js – ノンフリー – OCaml – Perl – PHP – Python – R – Ruby – Rust – VCS – ウェブ – Wine