「Arch User Repository」の版間の差分
(→歴史: 同期) |
(→FAQ: 同期) |
||
218行目: | 218行目: | ||
=== どのような種類のパッケージが AUR に置かれていますか? === |
=== どのような種類のパッケージが AUR に置かれていますか? === |
||
− | AUR にあるパッケージはたんに"ビルドスクリプト"、つまり pacman 用にバイナリをビルドするレシピにすぎません。ほとんどの場合、 |
+ | AUR にあるパッケージはたんに"ビルドスクリプト"、つまり pacman 用にバイナリをビルドするレシピにすぎません。ほとんどの場合、[[AUR 投稿ガイドライン#投稿の規則|有用性と範囲のガイドライン]]を条件として、コンテンツのライセンスの問題がない限り、すべてのものが置くことを許されています。他の場合、ダウンロードにリンクできない、つまり再配布が禁止されている時は、ソースとしてファイル名だけを使うことができます。よってパッケージをビルドするには、ユーザーによってビルドディレクトリにその制限されたソースを入れておく必要があります。どちらかわからない場合は、尋ねて下さい。 |
− | === |
+ | === どうすれば AUR 内のパッケージに投票できますか? === |
+ | [[#パッケージに投票する]] を見てください。 |
||
− | [[AUR Trusted User ガイドライン|TU (Trusted User)]] とは、AUR と [community] リポジトリを監督するように選ばれた人のことです。彼らは [community] に入っている人気の PKGBUILD を管理していて、みんなで AUR を運営し続けています。 |
||
− | === |
+ | === Trusted User / TU とは何ですか? === |
+ | [[AUR Trusted User ガイドライン|Trusted User]] (略して TU) とは、AUR と [[community リポジトリ]]を監督するように選ばれた人のことです。彼らは ''community'' に入っている人気の [[PKGBUILD]] を管理していて、みんなで AUR を運営し続けています。 |
||
− | Arch User Repository にはユーザーが投稿した全ての PKGBUILD が保存されており、利用するには手動で [[makepkg]] を使ってビルドしなくてはなりません。PKGBUILD に一定数の投票が入ると、パッケージは [community] リポジトリに移され TU が管理するバイナリパッケージとなり、[[pacman]] によってインストールできるようになります。 |
||
− | === |
+ | === Arch User Repository と community リポジトリの違いは何ですか? === |
+ | Arch User Repository にはユーザーが投稿した全ての [[PKGBUILD]] が保存されており、利用するには手動で [[makepkg]] を使ってビルドしなくてはなりません。{{ic|PKGBUILD}} にコミュニティの十分な関心が集まると、パッケージは [[community リポジトリ]]に移され TU が管理するバイナリパッケージとなり、[[pacman]] によってインストールできるようになります。 |
||
− | [https://aur.archlinux.org/ AUR のウェブサイト] で登録して、パッケージのページを開いて「このパッケージに投票する」を押してください。サイトに一度登録すれば {{AUR|aurvote}}, {{AUR|aurvote-git}}, {{AUR|aur-auto-vote-git}} などを使ってコマンドラインから投票することもできます。 |
||
+ | === AUR の Hoge が古くなっています、どうするべきでしょうか? === |
||
− | もしくは [[#認証|ssh 認証]]を設定して、ssh 鍵を使ってコマンドラインから直接投票することも可能です。AUR のパスワードを入力する手間を省けます。 |
||
+ | [[#パッケージに out-of-date フラグを立てる]] を見てください。 |
||
− | ssh aur@aur.archlinux.org vote <PACKAGE_NAME> |
||
+ | その間、ローカルで [[PKGBUILD]] を自分で編集してパッケージをアップデートしてみることもできます。アップデートにビルドプロセスの変更が必要ない場合もあり、この場合、{{ic|pkgver}} か {{ic|source}} 配列を更新するだけで十分です。 |
||
− | システムにインストールしている AUR パッケージ全てに投票するには: |
||
+ | === AUR の Hoge を makepkg でコンパイルすることができません。どうしたらいいですか? === |
||
− | for i in $(pacman -Qqm); do echo Voting for $i; ssh aur vote $i; done |
||
+ | 何か些細なことを見逃しているのかもしれません。[[#パッケージのビルドプロセスをデバッグする]] を見てください。 |
||
− | === どれくらいの投票で PKGBUILD が [community] に移されますか? === |
||
+ | === ERROR: One or more PGP signatures could not be verified! この場合、どうすればよいですか? === |
||
− | 通常、少なくとも 10 の投票が [community] に移されるのに必要です。しかし、TU がパッケージをサポートしたいと望んだ時は、投票数にかかわらず [community] に入ることがしばしばあります。 |
||
+ | |||
+ | 最もあり得るのは、ダウンロードしたファイルを検証するために必要な公開鍵があなたの個人キーリング内に存在しないことです。詳細は [[Makepkg#署名チェック]] を見てください。 |
||
=== どうやって PKGBUILD を作るのですか? === |
=== どうやって PKGBUILD を作るのですか? === |
||
+ | [[AUR 投稿ガイドライン#投稿の規則]] を見て、次に [[パッケージの作成]] を見てください。 |
||
− | 作り方は[[パッケージの作成]]にあります。同じものをダブらせてしまわないように PKGBUILD を作る前に AUR を調べるのを忘れないようにしましょう。 |
||
+ | === PKGBUILD を作って投稿したいと思っています。エラーがないか誰かチェックしてくれるでしょうか? === |
||
− | === [community] にあるパッケージを "pacman -S hoge" したのですがインストールされません === |
||
+ | パッケージをレビューのために提出できるチャネルが複数存在します。[[#パッケージのビルドプロセスをデバッグする]] を見てください。 |
||
− | おそらく {{ic|/etc/pacman.conf}} で [community] を有効にしていないのではないでしょうか。当該行をアンコメントしてください。 |
||
− | {{ic|/etc/pacman.conf}} の [community] が有効になっていたのなら、{{ic|pacman -Syu}} で pkgcache を同期してからパッケージを再度取得してみてください。 |
||
− | === |
+ | === どうすれば PKGBUILD が community リポジトリに移されるのですか? === |
+ | 通常、パッケージを [[community リポジトリ]] に移すには最低 10 票必要です。しかし、[[TU]] がパッケージをサポートしたいと望んだときは、''community'' リポジトリに入ることがしばしばあります。 |
||
− | 第一歩として、パッケージの out-of-date フラグを立てることができます。しばらく時間がたっても out-of-date のままの場合、最良の解決策はメンテナにメールをすることです。2週間たってもメンテナから何の反応も得られないときは、孤児リクエストを作成してください。3ヶ月以上 out-of-date のままでいっこうにアップデートされる気配のないパッケージがあるのならば、孤児リクエストに加えて下さい。 |
||
+ | 必要な最低投票数に到達することは唯一の要件ではありません。そのパッケージをメンテナンスしてもよいという TU がいなければなりません。たとえパッケージに数千もの投票があったとしても、TU は ''community'' リポジトリにそのパケージを移す必要はないのです。 |
||
− | {{Note|[[VCS パッケージガイドライン|VCS パッケージ]]は pkgver 以外に変更がない場合は out-of-date とはみなすべきではありません。VCS パッケージの out-of-date フラグを立ててもメンテナはフラグを降ろしてあなたを無視することでしょう。AUR のメンテナは |
||
− | VCS パッケージの pkgver だけを上げるコミットをしてはいけません。}} |
||
+ | 通常、非常に人気なパッケージが AUR に残っている理由としては: |
||
− | === PKGBUILD を作って投稿したいと思っています。エラーがないか誰かチェックしてくれるでしょうか? === |
||
+ | * Arch Linux のリポジトリ内にパッケージの他のバージョンがすでに存在するから |
||
− | あなたの PKGBUILD を批評してもらいたいのなら、aur-general メーリングリストに投稿して、TU や AUR メンバーからの反応をみてはいかがでしょう。[[IRC チャンネル]], #archlinux on irc.freenode.net からも助けを得ることができます。[[namcap]] を使って PKGBUILD や作られるパッケージにエラーがないかチェックすることも可能です。 |
||
+ | * ライセンスで再配布が禁止されているから |
||
+ | * そのパッケージが、ユーザによって投稿された [[PKGBUILD]] の取得を補助するものだから。[[AUR ヘルパー]] は、当然、[https://bbs.archlinux.org/viewtopic.php?pid=828310#p828310 サポートされていません]。 |
||
+ | [[AUR Trusted User ガイドライン#%5Bcommunity%5D リポジトリにパッケージを入れるときのルール| community リポジトリにパッケージを入れるときのルール]] も見てください。 |
||
− | === AUR の Hoge を makepkg でコンパイルすることができません。どうしたらいいですか? === |
||
+ | === 繰り返されるビルドプロセスを速めるにはどうすればよいですか? === |
||
− | おそらく些細なことを見逃していると思われます。 |
||
− | # |
+ | [[Makepkg#コンパイル時間を短縮する]] を見てください。 |
− | # {{Pkg|base}} と {{Grp|base-devel}} グループがインストール済みか確認してください。 |
||
− | # ビルドプロセスをはじめる前に {{ic|makepkg}} に "{{ic|-s}}" オプションを使って必要な依存パッケージがインストールされているかチェックしてみてください。 |
||
+ | === foo と foo-git パッケージは何が違うのですか? === |
||
− | まずはじめに PKGBUILD やパッケージの AUR ページのコメントを読むようにしてください。問題がカスタムした CFLAGS, LDFLAGS, MAKEFLAGS が問題を起こしているのかもしれません。その PKGBUILD が全ての人にとって壊れているかもしれません。もし自分で解決できない問題なら、AUR ページのコメントに書き込むなどしてメンテナにそれを報告してください。 |
||
+ | 多くの AUR パッケージには安定バージョン ("stable") と開発バージョン ("unstable") が存在します。開発版のパッケージには大抵、バージョン管理システムを示す[[VCS パッケージガイドライン|接尾辞]]が付いており、通常の使用を意図していません。しかし、それらは新しい機能やバグフィックスを提供している場合があります。 |
||
− | === ビルドの速度を速めるにはどうすればいいですか? === |
||
+ | {{ic|makepkg}} を実行した時、これらのパッケージは最新のソースをダウンロードするので、{{ic|pkgver()}} は必ずしも上流と合っていません。同じく、これらのパッケージは、如何なる [[VCS パッケージガイドライン#VCS ソース|VCS ソース]]のチェックサムの確認もできません。 |
||
− | gcc を使って頻繁にコードをコンパイルする場合 (git や SVN パッケージなど)、[[ccache]] ("compiler cache" の略) が役にたつかもしれません。 |
||
+ | [[システムメンテナンス#実績のあるソフトウェアパッケージを使用する]] も見てください。 |
||
− | === foo と foo-git パッケージは何が違うのですか? === |
||
+ | |||
+ | === Foo が AUR から消えたのはなぜですか? === |
||
+ | |||
+ | パッケージが [[TU]] によって引き取られ、現在は [[community リポジトリ]] に存在している可能性があります。 |
||
+ | |||
+ | また、[[AUR 投稿ガイドライン#投稿の規則|投稿の規則]]に違反していたため、削除されてしまった可能性もあります。削除の理由は、[https://lists.archlinux.org/archives/list/aur-requests@lists.archlinux.org/ aur-requests アーカイブ] を見てください。 |
||
+ | {{Note|削除されたパッケージの git リポジトリは、通常、利用可能なままになります。詳細は [[AUR 投稿ガイドライン#リクエスト]] を見てください。}} |
||
− | 多くの AUR パッケージには通常バージョン ("stable") と開発バージョン ("unstable") が存在します。開発版のパッケージには大抵 "-cvs", "-svn", "-git", "-hg", "-bzr", "-darcs" などが末尾に付きます。開発版のパッケージは通常の使用には適してしませんが、新しい機能やバグフィックスが含まれていることがあります。{{ic|makepkg}} を実行した時 {{ic|-git}}, {{ic|-svn}}, {{ic|-hg}}, {{ic|-bzr}} パッケージは最新のソースをダウンロードするので、パッケージのバージョンは必ずしも上流と合っていません。同じく、チェックサムの確認が出来ないので、git リポジトリのメンテナを信用することになります。 |
||
+ | そのパッケージが AUR3 に存在していた場合、[https://lists.archlinux.org/archives/list/aur-general@lists.archlinux.org/message/NJN6TPVF6MWGF7BCHBMBYFZ5JDAPOHP5/ AUR4 に移行]されなかったのかもしれません。そのようなパッケージが保存されている場所である [[#AUR3 パッケージの Git リポジトリ]] を見てください。 |
||
− | [[Arch Linux の安定化#開発中のパッケージを使わない]]も参照してください。 |
||
− | === |
+ | === インストール済みのパッケージが AUR から消えてしまっているかどうかを確かめるには? === |
+ | 最もシンプルな方法は、そのパッケージの AUR ページの HTTP ステータスをチェックすることです: |
||
− | [[#パッケージの投稿ルール|ルール違反]]によってパッケージが削除された可能性があります。削除理由は [https://lists.archlinux.org/pipermail/aur-requests/ aur-requests アーカイブ] を見てください。 |
||
+ | $ comm -23 <(pacman -Qqm | sort) <(curl https://aur.archlinux.org/packages.gz | gzip -cd | sort) |
||
− | AUR3 に存在していたパッケージの場合、[https://lists.archlinux.org/pipermail/aur-general/2015-August/031322.html AUR4 に移行] したときにパッケージが移行されなかった可能性があります。[[#AUR3 パッケージの Git リポジトリ]]を見てください。 |
||
=== 全ての AUR パッケージのリストを入手するには? === |
=== 全ての AUR パッケージのリストを入手するには? === |
||
* https://aur.archlinux.org/packages.gz |
* https://aur.archlinux.org/packages.gz |
||
− | * {{aur|python3-aur}} |
+ | * {{aur|python3-aur}} の {{ic|aurpkglist}} を使ってください |
== 参照 == |
== 参照 == |
2022年11月3日 (木) 19:08時点における版
関連記事
Arch User Repository (AUR) はコミュニティによって運営されている、Arch ユーザーのためのリポジトリです。パッケージのビルド方法が書かれたファイル (PKGBUILD) がまとめて置かれており、makepkg を使ってソースからパッケージを作り、生成したパッケージを pacman でインストールすることができます。人気のあるパッケージが community リポジトリに取り込まれるように、コミュニティの手で新しいパッケージを共有することを目的に AUR は作られました。このページでは AUR の使用方法を説明します。
AUR に投稿された新しいパッケージの一部は公式リポジトリに取り込まれています。AUR では、ユーザーはパッケージビルド (PKGBUILD と関連ファイル) を投稿することができます。AUR コミュニティには AUR に存在するパッケージに対して投票する機能があります。投票が十分に集まると (ライセンスに問題がなくきちんとパッケージ化されているならば) community リポジトリに取り込まれます (pacman や abs で直接入手できるようになります)。
目次
- 1 はじめに
- 2 歴史
- 3 パッケージをインストール・アップグレードする
- 4 アカウントステータス
- 5 フィードバック
- 6 パッケージのビルドプロセスをデバッグする
- 7 パッケージを投稿する
- 8 ウェブインターフェイスの翻訳
- 9 FAQ
- 9.1 どのような種類のパッケージが AUR に置かれていますか?
- 9.2 どうすれば AUR 内のパッケージに投票できますか?
- 9.3 Trusted User / TU とは何ですか?
- 9.4 Arch User Repository と community リポジトリの違いは何ですか?
- 9.5 AUR の Hoge が古くなっています、どうするべきでしょうか?
- 9.6 AUR の Hoge を makepkg でコンパイルすることができません。どうしたらいいですか?
- 9.7 ERROR: One or more PGP signatures could not be verified! この場合、どうすればよいですか?
- 9.8 どうやって PKGBUILD を作るのですか?
- 9.9 PKGBUILD を作って投稿したいと思っています。エラーがないか誰かチェックしてくれるでしょうか?
- 9.10 どうすれば PKGBUILD が community リポジトリに移されるのですか?
- 9.11 繰り返されるビルドプロセスを速めるにはどうすればよいですか?
- 9.12 foo と foo-git パッケージは何が違うのですか?
- 9.13 Foo が AUR から消えたのはなぜですか?
- 9.14 インストール済みのパッケージが AUR から消えてしまっているかどうかを確かめるには?
- 9.15 全ての AUR パッケージのリストを入手するには?
- 10 参照
はじめに
AUR ウェブインターフェイス で PKGBUILD を検索したり、ダウンロードしたりすることができます。makepkg を使って PKGBUILD
からパッケージを生成することができ、pacman でインストールできます。
- base-devel パッケージグループが完全にインストールされていることを確認してください (
pacman -S --needed base-devel
)。 - 一般的な質問に対する答えはほとんど #FAQ に載っています。
/etc/makepkg.conf
を調整することで、AUR からパッケージをビルドするときに、あなたの使用しているプロセッサに最適化することができます。マルチコアプロセッサを搭載しているシステム上では、MAKEFLAGS
変数を調整したり、圧縮に複数のコアを使ったり、別の圧縮アルゴリズムを使ったりすることで、パッケージのビルドタイムを劇的に短縮できる可能性があります。また、CFLAGS
変数を使うことでハードウェア固有のコンパイラ最適化を有効化することもできます。詳しくは makepkg#ヒントとテクニック を見てください。
また、SSH から AUR にアクセスすることもできます: 利用可能なコマンドをリストアップするには ssh aur@aur.archlinux.org help
を入力してください。
歴史
当初、ftp://ftp.archlinux.org/incoming
というサーバーがあり、人々は PKGBUILD やビルドに必要なファイル、ビルド済みのパッケージをそのサーバにアップロードしていました。パッケージやそれに関連するファイルは、パッケージメンテナがプログラムを見て取り入れるまで、そこに置かれていました。
その後、Trusted User リポジトリが誕生しました。コミュニティの特定の個人が、誰でも使えるリポジトリをホストすることを許可されていました。これを基礎として、より柔軟に使いやすくするために拡張されたものが AUR です。今でも、AUR のメンテナは TU (Trusted User) と呼ばれます。
2015年6月8日から2015年8月8日までの間に AUR はバージョン 3.5.1 から 4.0.0 に移行し、PKGBUILD を公開するために Git リポジトリが使われるようになりました。 既存のパッケージは、メンテナによって新しいインフラに手動で移行されない限り、ドロップされました。
AUR3 パッケージの Git リポジトリ
GitHub 上の AUR Archive には、移行時に AUR3 内にあったすべてのパッケージが保存されているリポジトリです。 あるいは、同じものを提供する aur3-mirror リポジトリもあります。
パッケージをインストール・アップグレードする
AUR からパッケージをインストールする手順は比較的単純です。基本的には:
- ビルドファイルを取得する。PKGBUILD や、systemd ユニットやパッチなどの (しばしば、実際のコードではない) 他の必要なファイルを含みます。
PKGBUILD
とそれに付属しているファイルが、悪意のある、または信頼できないものでないことを検証する。- それらのファイルが保存されているディレクトリ内で
makepkg
を実行する。これは、コードをダウンロードし、コンパイルし、パッケージングします。 pacman -U package_file
を実行し、パッケージをシステムにインストールする。
要件
まず、必要なツールがインストールされているか確かめましょう。base-devel パッケージグループは絶対に必要です。make などの、ソースコードからのコンパイルに必要なツールが含まれています。
次に、適切なビルドディレクトリを選択してください。ビルドディレクトリは、パッケージが作成/ビルドされるディレクトリであり、任意のディレクトリにすることができます。以下のセクションでは例として ~/builds
をビルドディレクトリとして使用します。
ビルドファイルを取得する
AUR 内の対象パッケージの場所を特定します。AUR ホームページの検索フィールドを使って行うことができます。検索リスト内のアプリケーションの名前をクリックして、そのパッケージの情報ページを開きます。説明欄を読んで、それがあなたの求めているパッケージであることを確認してください。パッケージの最終更新日時とコメントも確認してください。
パッケージのビルドファイルを取得する方法は複数存在します:
- そのパッケージの git リポジトリをクローンする。URL は、そのパッケージの AUR ページの「パッケージの詳細」の「Git クローン URL」にあります。これは推奨される方法です。利点としては、
git pull
を実行すれば、パッケージを簡単にアップデートできます。
$ git clone https://aur.archlinux.org/package_name.git
- スナップショットをダウンロードする。パッケージの AUR ページの右側にある「パッケージアクション」内の「スナップショットのダウンロード」リンクをクリックするか、ターミナルで以下を実行してください:
$ curl -L -O https://aur.archlinux.org/cgit/aur.git/snapshot/package_name.tar.gz
- archlinux/aur GitHub 上の読み取り専用ミラーを使う。1つのブランチ内に1つのパッケージが存在しています。1つのブランチのみをクローンすることが推奨されます (リポジトリ全体は大きすぎるので、パフォーマンスが低下するでしょう)。これを行う方法として、以下の2つがあります:
git clone --single-branch
を使う:$ git clone --branch branch_name/package_name --single-branch https://github.com/archlinux/aur
- このリポジトリの部分クローンを行い (
git clone --depth=1
)、選択的にブランチを追加する:
$ git clone --depth=1 https://github.com/archlinux/aur; cd aur
$ git remote set-branches --add origin package_name
$ git fetch
$ git checkout package_name
必要であれば PGP 公開鍵を取得する
PKGBUILD の source 配列に .sig や .asc という形式の署名ファイルがあるか確認してください。それがある場合、PKGBUILD の validpgpkeys 配列内にリストアップされている公開鍵のうち1つを取得してください。詳細は makepkg#署名チェック を参照してください。
パッケージをビルドする
パッケージの PKGBUILD が含まれているディレクトリに移動してください:
$ cd package_name
提供されているファイルすべての内容を確認してください。例えば、less を使って PKGBUILD
を見るには:
$ less PKGBUILD
パッケージを作成します。手動でファイルの内容を確認したあとで、makepkg を通常ユーザとして実行してください。いくつか便利なフラグがあります:
-s
/--syncdeps
は、ビルド前に自動的に依存関係を解決し、pacman を使って依存パッケージをインストールします。パッケージが他の AUR パッケージに依存している場合、まずその AUR パッケージを手動でインストールする必要があります。-i
/--install
は、ビルドが成功した場合にパッケージをインストールします。このフラグを使えば、通常手動で行う次の手順をスキップすることができます。-r
/--rmdeps
は、ビルド後に、ビルド時の依存パッケージを削除します (なぜなら、それらはもはや必要ないからです)。しかし、これらの依存パッケージは、パッケージがアップデートされたときに再インストールする必要があるでしょう。-c
/--clean
は、ビルド後に一時ビルドファイルをクリーンアップします (なぜなら、それらはもはや必要ないからです)。通常、これらのファイルはビルドプロセスをデバッグするときにだけ必要になります。
パッケージをインストールする
これで、pacman を使ってパッケージをインストールできます:
# pacman -U package_name-version-architecture.pkg.tar.zst
パッケージをアップグレードする
パッケージの PKGBUILD を含むディレクトリ内で、まず最初に以下のコマンドを使ってファイルと変更を更新しなければなりません:
$ git pull
次に、前述のビルドとインストールの指示に従ってください。
アカウントステータス
休止 (Suspension)
Trusted User としてユーザを編集するとき、休止 (Suspended) フィールドをセットできます。これは、対象のユーザを休止させます。ユーザが休止しているとき、以下のことはできなくなります:
- https://aur.archlinux.org へのログイン
- 通知の受け取り
- git インターフェイスとの対話
活動休止 (Inactivity)
あなた自身のアカウントを編集するときや、Trusted User としてユーザを編集するとき、活動休止 (Inactive) フィールドをセットできます。活動休止中のアカウントは2つの理由により使用されます:
- アカウントページに活動休止になった日付を表示する。
- 新しい提案のために、活動休止になっているかどうかで現在アクティブな Trusted User の数を生成する。
フィードバック
パッケージにコメントする
AUR ウェブインターフェイスにはコメント機能があり、PKGBUILD の貢献者にコメントで提案やフィードバックを提供することができます。
Python-Markdown は、コメントをフォーマットする基本的な Markdown 構文を提供します。
パッケージに投票する
すべての Arch ユーザにとって最も簡単なアクティビティの1つとして、AUR のオンラインインターフェイスによる AUR のブラウズや、お気に入りのパッケージにへの投票があります。すべてのパッケージは、TU によってcommunity リポジトリに取り込まれる可能性があり、得票数はその過程で考慮されます。また、投票数はみんなが気にしていることでもあります。
パッケージのブラウジングで「このパッケージに投票する」オプションを利用できるようにするには、AUR のウェブサイトにサインアップしてください。サインアップ後、aurvoteAUR、aurvote-gitAUR、aur-auto-vote-gitAUR を使ってコマンドラインからも投票できるようになります。
あるいは、ssh 認証がセットアップ済みである場合、あなたの ssh 鍵を使ってコマンドラインから直接投票できます。これはつまり、AUR パスワードを保存・入力する手間が省けることを意味します。
$ ssh aur@aur.archlinux.org vote package_name
パッケージに out-of-date フラグを立てる
まず、そのパッケージに out-of-date フラグを立て、そのパッケージが out-of-date である理由の詳細や、出来ればリリースのアナウンスや新しいリリースの tarball へのリンクを含めてください。
また、メンテナに email で直接連絡を取ってみるべきです。2周間経ってもメンテナから応答がない場合、孤児リクエストを提出することができます。詳細は AUR 投稿ガイドライン#リクエスト を見てください。
パッケージのビルドプロセスをデバッグする
- 何かをビルドする前にアップグレードしてビルド環境が最新であることを確認してください。
- base-devel グループがインストールされていることを確認してください。
- ビルドプロセスを始める前に、
makepkg
で-s
オプションを使って、必要とされているすべての依存関係をチェック・インストールしてください。 - デフォルトの makepkg の設定を試してください。
- 一般的な問題については Makepkg#トラブルシューティング を見てください。
パッケージのビルドで問題が発生する場合、まず、そのパッケージの PKGBUILD とそのパッケージの AUR ページのコメントを読んでください。
PKGBUILD
が全員の環境で壊れている場合もあり得ます。ひとりで解決できない場合、問題をメンテナに報告してください (例えば、発生するエラーを AUR ページのコメント欄に投稿するなど)。また、AUR Issues, Discussion & PKGBUILD Requests フォーラムで助けを得ることもできるかもしれません。
結局、原因が些細なことではない場合もあります。カスタムの CFLAGS
、LDFLAGS
、MAKEFLAGS
フラグは失敗を引き起こす可能性があります。あなたのシステム構成によって引き起こされる問題を回避するには、パッケージをクリーンな chroot 内でビルドしてください。ビルドプロセスがクリーンな chroot 内でも失敗する場合、原因はおそらく PKGBUILD
にあるのでしょう。
namcap
の使用に関しては パッケージの作成#パッケージの正常性のテスト を見てください。PKGBUILD
をレビューしてもらいたいならば、aur-general メーリングリストに投稿して TU やフェロー AUR メンバーからフィードバックをもらうか、Creating & Modifying Packages フォーラムに投稿してください。また、Libera Chat ネットワーク上の IRC チャンネル #archlinux-aur で助けを乞うこともできます。
パッケージを投稿する
ユーザは、Arch User Repository を使って PKGBUILD を共有できます。詳細は AUR 投稿ガイドライン を見てください。
ウェブインターフェイスの翻訳
AUR ウェブインターフェイスの翻訳の作成とメンテナンスについては AUR ソースツリーの i18n.txt を見てください。
FAQ
どのような種類のパッケージが AUR に置かれていますか?
AUR にあるパッケージはたんに"ビルドスクリプト"、つまり pacman 用にバイナリをビルドするレシピにすぎません。ほとんどの場合、有用性と範囲のガイドラインを条件として、コンテンツのライセンスの問題がない限り、すべてのものが置くことを許されています。他の場合、ダウンロードにリンクできない、つまり再配布が禁止されている時は、ソースとしてファイル名だけを使うことができます。よってパッケージをビルドするには、ユーザーによってビルドディレクトリにその制限されたソースを入れておく必要があります。どちらかわからない場合は、尋ねて下さい。
どうすれば AUR 内のパッケージに投票できますか?
#パッケージに投票する を見てください。
Trusted User / TU とは何ですか?
Trusted User (略して TU) とは、AUR と community リポジトリを監督するように選ばれた人のことです。彼らは community に入っている人気の PKGBUILD を管理していて、みんなで AUR を運営し続けています。
Arch User Repository と community リポジトリの違いは何ですか?
Arch User Repository にはユーザーが投稿した全ての PKGBUILD が保存されており、利用するには手動で makepkg を使ってビルドしなくてはなりません。PKGBUILD
にコミュニティの十分な関心が集まると、パッケージは community リポジトリに移され TU が管理するバイナリパッケージとなり、pacman によってインストールできるようになります。
AUR の Hoge が古くなっています、どうするべきでしょうか?
#パッケージに out-of-date フラグを立てる を見てください。
その間、ローカルで PKGBUILD を自分で編集してパッケージをアップデートしてみることもできます。アップデートにビルドプロセスの変更が必要ない場合もあり、この場合、pkgver
か source
配列を更新するだけで十分です。
AUR の Hoge を makepkg でコンパイルすることができません。どうしたらいいですか?
何か些細なことを見逃しているのかもしれません。#パッケージのビルドプロセスをデバッグする を見てください。
ERROR: One or more PGP signatures could not be verified! この場合、どうすればよいですか?
最もあり得るのは、ダウンロードしたファイルを検証するために必要な公開鍵があなたの個人キーリング内に存在しないことです。詳細は Makepkg#署名チェック を見てください。
どうやって PKGBUILD を作るのですか?
AUR 投稿ガイドライン#投稿の規則 を見て、次に パッケージの作成 を見てください。
PKGBUILD を作って投稿したいと思っています。エラーがないか誰かチェックしてくれるでしょうか?
パッケージをレビューのために提出できるチャネルが複数存在します。#パッケージのビルドプロセスをデバッグする を見てください。
どうすれば PKGBUILD が community リポジトリに移されるのですか?
通常、パッケージを community リポジトリ に移すには最低 10 票必要です。しかし、TU がパッケージをサポートしたいと望んだときは、community リポジトリに入ることがしばしばあります。
必要な最低投票数に到達することは唯一の要件ではありません。そのパッケージをメンテナンスしてもよいという TU がいなければなりません。たとえパッケージに数千もの投票があったとしても、TU は community リポジトリにそのパケージを移す必要はないのです。
通常、非常に人気なパッケージが AUR に残っている理由としては:
- Arch Linux のリポジトリ内にパッケージの他のバージョンがすでに存在するから
- ライセンスで再配布が禁止されているから
- そのパッケージが、ユーザによって投稿された PKGBUILD の取得を補助するものだから。AUR ヘルパー は、当然、サポートされていません。
community リポジトリにパッケージを入れるときのルール も見てください。
繰り返されるビルドプロセスを速めるにはどうすればよいですか?
Makepkg#コンパイル時間を短縮する を見てください。
foo と foo-git パッケージは何が違うのですか?
多くの AUR パッケージには安定バージョン ("stable") と開発バージョン ("unstable") が存在します。開発版のパッケージには大抵、バージョン管理システムを示す接尾辞が付いており、通常の使用を意図していません。しかし、それらは新しい機能やバグフィックスを提供している場合があります。
makepkg
を実行した時、これらのパッケージは最新のソースをダウンロードするので、pkgver()
は必ずしも上流と合っていません。同じく、これらのパッケージは、如何なる VCS ソースのチェックサムの確認もできません。
システムメンテナンス#実績のあるソフトウェアパッケージを使用する も見てください。
Foo が AUR から消えたのはなぜですか?
パッケージが TU によって引き取られ、現在は community リポジトリ に存在している可能性があります。
また、投稿の規則に違反していたため、削除されてしまった可能性もあります。削除の理由は、aur-requests アーカイブ を見てください。
そのパッケージが AUR3 に存在していた場合、AUR4 に移行されなかったのかもしれません。そのようなパッケージが保存されている場所である #AUR3 パッケージの Git リポジトリ を見てください。
インストール済みのパッケージが AUR から消えてしまっているかどうかを確かめるには?
最もシンプルな方法は、そのパッケージの AUR ページの HTTP ステータスをチェックすることです:
$ comm -23 <(pacman -Qqm | sort) <(curl https://aur.archlinux.org/packages.gz | gzip -cd | sort)
全ての AUR パッケージのリストを入手するには?
- https://aur.archlinux.org/packages.gz
- python3-aurAUR の
aurpkglist
を使ってください