Provided by: manpages-ja_0.5.0.0.20180315+dfsg-1_all bug

名前

       libtool - ライブラリのコンパイル・ビルド・ インストール・アンインストールをする

書式

       libtool  [-n]  [--config]  [--debug]  [--dry-run]  [--features]  [--finish]  [--mode=MODE]
       [--quiet] [--silent] [MODE-ARGS...]

       リンクモード:  [-lNAME]   [-o    OUTPUT-FILE]   [-LLIBDIR]   [-R   LIBDIR]   [-all-static]
       [-avoid-version]  [-dlopen  FILE]  [-dlpreopen  FILE]  [-export-dynamic] [--export-symbols
       FILE] [--export-symbols  REGEX]  [--module]  [-no-undefined]  [-release  RELEASE]  [-rpath
       LIBDIR] [-static] [-version-info CURRENT[:REVISION[:AGE]]

       実行モード: [-dlopen FILE]

       libtool [--features] [--help] [--version]

説明

       libtool   は静的ライブラリや共有ライブラリの  コンパイル・リンク・インストール・アンインス
       トールの複雑さを簡略化する。  異なるプラットフォームそれぞれで、完全な機能を  統一的なイン
       ターフェースを介して使用することができ、  プラットフォーム固有の厄介な癖はプログラマーから
       隠蔽される。

       libtool はコンパイル・実行・リンク・フィニッシュ・インストール・アンインストール という  6
       つのモードで動作できる。

   コンパイルモード
       コンパイルモードの場合、MODE-ARGS  は 標準的なオブジェクトファイルを作成するために使われる
       コンパイラコマンドである。 これらの引き数は C コンパイラの名前で始まり、  オブジェクトファ
       イルのみを作成するよう、 -c コンパイラフラグを含んでいなければならない。

       libtool  は出力ファイルの名前を決定するとき、 ソースファイル名からディレクトリ構成要素を取
       り除き、 それから  C  言語のソースコードの拡張子  `.c'  をライブラリオブジェクトの  拡張子
       `.lo' に置き換えるという方法を用いる。

       共有ライブラリがビルドされる場合、必要な PIC 作成フラグすべてが コンパイルコマンドに挿入さ
       れる。 -static  オプションを指定すると、たとえ  --disable-static  が  設定されていたとして
       も、libtool は `.o' ファイルを作成する。

       -o  オプションが直接サポートされていないプラットフォーム上では (コンパイラによって作成され
       たオブジェクトファイルのロックと移動により) エミュレートを行う。  したがって、以下のような
       通常の構文を使うことができる。

              lightside:% libtool cc -c foo/x.c -o foo/x.lo

       プラットフォームが -c-o オプションをサポートしていない場合、 古い `foo/x.o' を上書きせ
       ずに `foo/x.lo' をビルドすることはできない。 この場合、`foo/x.o' が `foo/x.lo' の後に (再)
       ビルドされることを 確かめておかなければならない。

   リンクモード
       リンクモードはライブラリや実行可能プログラムを作成するために、  オブジェクトファイル (ライ
       ブラリオブジェクトも含む) をリンクする。

       MODE-ARGS  は、C  コンパイラがオブジェクトファイルから  (-o   フラグにより)   出力ファイル
       OUTPUT-FILE を作成する ときに使用するコマンドで構成される。 以下のように、ファイルの形式は
       OUTPUT-FILE の拡張子に依存する。

       .la    libtool ライブラリを作成する。 このライブラリはライブラリオブジェクト (`.lo' ファイ
              ル) のみからビルドされなければならない。 -rpath オプションが必要である。 現在の実装
              では、libtool ライブラリはアンインストールされた他の libtool ライブラリに依存できな
              い。

       .a     ar(1) と (あるいは) ranlib(1) を使って 標準ライブラリが作成される。

       .o .lo (一般には `ld -r' を使うことで) 入力ファイルから 再ロード可能なオブジェクトファイル
              が作成される。 この手法は ``部分リンク'' と呼ばれることが多い。

       other  実行可能なプログラムが作成される。

   実行モード
       実行モードでは、ライブラリパスの環境変数が自動的にセットされ (そして -dlopen  によって修正
       されて)、プログラムが実行される。

       一番目の MODE-ARGS はプログラム名として扱われ、 残りはプログラムの引数として扱われる。

       引数の中のどれかが libtool 実行ファイルのラッパーであった場合、 その引数はそれぞれ対応する
       アンインストール済みバイナリの名前に変換される。  このとき、必要とされるライブラリディレク
       トリがライブラリパスに加えられる。

   インストールモード
       インストールモードでは、MODE-ARGScp(1) もしくは BSD-互換の install(1) から始まる イン
       ストールコマンドとして解釈する。

       残りの MODE-ARGS は、インストールコマンドの 引数として解釈される。

       このコマンドは実行され、 インストール後の処理に必要な非特権コマンドもすべて完了する。

   フィニッシュモード
       フィニッシュモードは、システム管理者の   libtool   ライブラリ   インストール作業を補助し、
       libtool ライブラリの探索およびユーザー プログラムへのリンクができるようにする。

       MODE-ARG はライブラリディレクトリ名として解釈される。 このコマンドを実行するのにはスーパー
       ユーザー特権が必要なため、 --dry-run オプションを使うと便利だろう。

   アンインストールモード
       このモードではインストールされたライブラリ (もしくはファイル) を削除する。

       一番目の  MODE-ARG はファイルを削除するためのプログラム名 (一般には `/bin/rm') である。

       残りの MODE-ARGS は削除プログラムの (`-' で始まる) フラグもしくは、 削除するファイルの名前
       である。

オプション

   グローバルオプション
       --config
              libtool の設定変数を表示して終了する。

       --debug
              シェルスクリプトのトレースモードを有効にして、標準出力に書き出す。

       -n, --dry-run
              ファイルの作成・修正・削除を行わず、libtool によってどのような コマンドが実行される
              かを表示する。

       --features
              libtool の基本的な特徴を表示する。 また静的ライブラリと共有ライブラリが有効になって
              いるかを表示する。

       --finish
              --mode=finish と同じ。

       --mode=MODE
              MODE      をオペレーションモードとする。     デフォルトでは、オペレーションモードは
              MODE-ARGS の内容から推論される。 MODE  を指定する場合、次のうちの一つでなければなら
              ない。

              compile
                     ソースファイルを libtool オブジェクトにコンパイルする。

              execute
                     他のプログラムがアンインストールされたプログラムやライブラリ (libtool により
                     作成されたもの)  を使うことができるように、   ライブラリパスを自動的に設定す
                     る。

              finish システムへの libtool ライブラリのインストールを完了する。

              install
                     ライブラリや実行ファイルをインストールする。

              link   ライブラリや実行ファイルを作成する。

              uninstall
                     ライブラリや実行ファイルを削除する。

       --features
              libtool の設定情報を表示して終了する。 このオプションを使うと、パッケージは共有ライ
              ブラリと静的ライブラリの どちらを作るか決定できる。

       --help 使用法のメッセージを標準出力に表示して、正常終了する。 --mode=MODE が指定されている
              場合は、 指定されたモードについてのヘルプが表示される。

       --version
              バージョン情報を標準出力に表示して、正常終了する。

   リンクモードオプション
       -lNAME OUTPUT-FILE はインストール済みの ライブラリ libNAME を必要とする。 このオプションは
              OUTPUT-FILE が実行ファイルでなくても必要とされる。

       -o OUTPUT-FILE
              指定したオブジェクトとライブラリから OUTPUT-FILE を作成する。

       -LLIBDIR
              必要なインストール済みライブラリを LIBDIR から検索する。

       -R LIBDIR
              OUTPUT-FILE が実行ファイルの場合は LIBDIR を実行時パスに加える。 OUTPUT-FILE がライ
              ブラリの場合は  `-RLIBDIR' を DEPENDENCY_LIBS に加える。 これは、そのライブラリが実
              行ファイルにリンクされるときに必ず LIBDIR  を実行ファイルの実行時パスに加えるためで
              ある。

       -all-static
              OUTPUT-FILE がプログラムの場合は、 そのプログラムをどの共有ライブラリともリンクさせ
              ない。 OUTPUT-FILE がライブラリの場合は静的ライブラリを作成するのみである。

       -avoid-version
              どのような種類のバージョニングも行わない  (バージョン情報は組み込まれず、シンボリッ
              クリンクも作られない)。  このオプションはバージョニングを必要とするプラットホーム上
              では働かない。

       -dlopen FILE
              ホストプラットホーム上でネイティブな   ダイナミックロードがサポートされていない場合
              や、  実行ファイルが -static-all-static を 使ってリンクされる場合は、-dlpreopen
              FILE と同じ。 それ以外の場合は何も影響を及ぼさない。

              FILE が `実行ファイル自身' であった場合、 libtool は実行ファイルが  -export-dynamic-dlpreopen を使って自らを dlopen(3) できるかを確かめる。

       -dlpreopen FILE
              FILE を出力プログラムにリンクし、そのシンボルを LT_PRELOADED_SYMBOLS に加える。

              FILE    が   `出力プログラム自身'   であった場合、   出力プログラム自身のシンボルが
              LT_PRELOADED_SYMBOLS に加えられる。

       -export-dynamic
              OUTPUT-FILE のシンボルを dlsym(3) を使って解決できるようにする。

       -export-symbols FILE
              これをサポートしているプラットホーム上では、 リンカは FILE にリストされているシンボ
              ルのみをエクスポートする。 FILE の名前は `.sym' で終っていなければならず、 1 行に 1
              つのシンボルを含んでいなければならない。 デフォルトではすべてのシンボルがエクスポー
              トされる。

       -export-symbols-regex REGEX
              REGEX  regex(7)  にマッチするシンボルのみがエクスポートされる以外は -export-symbols
              と同じ。

       -module
              ダイナミックロードできるライブラリを作成する。 モジュール名は `lib'  で始まる必要は
              ないが、 名前の衝突を避けるため `libname' と `name' はパッケージの中で 同時に使用す
              べきではない。

       -no-undefined
              OUTPUT-FILE が他のライブラリに依存していないことを宣言する。 他のライブラリに依存す
              る共有ライブラリを作れないプラットホームもある。

       -release RELEASE
              ライブラリがパッケージのリリース   RELEASE   で作られたことを指定する。  これによっ
              て、ユーザーはどのバージョンが他のものより新しいかを 簡単に判断できる。  このフラグ
              を使うと、パッケージの各リリースのいかなるペアの間にも バイナリ互換はなくなることに
              注意せよ。 バイナリ互換にしたい場合は、-version-info フラグを使うこと。

       -rpath LIBDIR
              OUTPUT-FILE がライブラリの場合、 最終的に LIBDIR にインストールされる。

       -static
              OUTPUT-FILE がプログラムの場合、 アンインストールされた共有 libtool  ライブラリはリ
              ンクしない。 OUTPUT-FILE がライブラリの場合、 静的ライブラリを作成するのみである。

       -version-info CURRENT[:REVISION[:AGE]]
              OUTPUT-FILE  が libtool ライブラリであるとき、 ライブラリをビルドするためにインター
              フェースバージョン情報 CURRENT, REVISION, AGE を使う。 パッケージのリリース情報を指
              定するために、  このオプションを使ってはいけない。 むしろ -release フラグを参照すべ
              きである。

   実行モードオプション
       -dlopen FILE
              FILE を含んでいるディレクトリをライブラリパスに加える。

バージョニング

       libtool は共有ライブラリ用に独自のバージョニングシステムを持っている。  このシステムを使い
       たい場合は、-version-info     オプションを     使わなければならない。     このオプションは
       CURRENT[:REVISION[:AGE]] という形式の引数を受け付ける。

       CURRENT
              インターフェースのバージョン。インターフェースとは "外側"  の世界に見えるすべてのも
              ので、 変数・関数プロトタイプ・出力形式などである。

       REVISION
              CURRENT からの相対値で与える実装のバージョン。

       AGE    このライブラリが実装している最新のインターフェースと   最古のインターフェースとの違
              い。 言い替えると、このライブラリは `CURRENT - AGE' から CURRENT までの範囲のすべて
              のインターフェース番号を実装していて、 このバージョンの範囲にあるライブラリに対して
              過去にリンクされた すべての実行ファイルは、このライブラリを使うことができる、  とい
              うことである。

       REVISIONAGE が省略された場合のデフォルトは 0 である。 AGECURRENT インターフェース
       番号より小さいか  等しくなければならないことにも注意すること。  2   つのライブラリが同一の
       CURRENT 番号と AGE 番号であるとき、 ダイナミックリンカは大きい REVISION 番号のライブラリを
       選択する。

       バージョニングのガイドライン:

        1. それぞれの libtool ライブラリについて `0:0:0' というバージョン情報から始めなさい。

        2.  バージョン情報を更新するのは ソフトウェアの公開リリースの直前だけにしなさい。 頻繁な
       更新は不必要であり、現在のインターフェース番号が大きくなるのを 早くするだけである。

        3.  前回の更新からライブラリのソースコードが すっかり変更されたなら、REVISION を増加させ
       なさい (C:R:AC:R+1:A になる)。

        4.   前回の更新からインターフェースが    追加・削除・変更されたなら、CURRENT    を増加さ
       せ、REVISION を 0 にしなさい。

        5. 前回の公開リリースからインターフェースが 追加されたなら、AGE を増加させなさい。

        6. 前回の公開リリースからインターフェースが 削除されたなら、AGE を 0 にしなさい。

       パッケージバージョンをライブラリ名にエンコードしたい場合や、  libtool のバージョニングと衝
       突せずに   他のバージョニングシステムを使いたい場合は、-release   を使うこと。    たとえば
       binutils-2.7.0.2  に付属する `libbfd.so.2.7.0.2' は libtool のバージョニングと明らかに衝突
       する。 `-release 2.7.0' を使えば `libbfd-2.7.0.so.0.0.0' で終ることができる。

       異なる CURRENT バージョンのライブラリや 異なる -release のライブラリはバイナリ非互換であろ
       う。

インターフェースの設計

       良いライブラリインターフェースを書くには、  練習とライブラリが解決しようとしている問題に対
       する徹底的な理解が必要である。  良いインターフェースを設計すれば、  頻繁に変更する必要はな
       く、ドキュメントを更新し続ける必要もなく、  クライアントがライブラリの使い方を再び勉強し続
       ける必要もないだろう。

       設計に対するガイドラインをいくつか示す:

        前もって計画を立てる
       エントリーポイントを頻繁に削除する必要がないように、  それぞれのインターフェースを最小にす
       るようにしなさい。

        インターフェースの変更を避ける
       もしインターフェースを再設計する必要があるならば、  クライアントが既に存在するコードを書き
       直す必要がないように、 互換性のある関数も残しておくようにしなさい。

        見えないデータタイプを使う
       クライアントがアクセスする必要のあるデータタイプの定義は少ない程良い。  可能ならば、関数が
       ジェネリックポインタ  (内部データタイプにキャストすることが可能) を 受け付けるように設計し
       なさい。 クライアントに直接データを操作させるよりは、 アクセス関数を提供しなさい。  このよ
       うするとインターフェースを変更することなく データ構造を自由に変更できる。

        ヘッダファイルを使う
       それぞれのライブラリについて大域関数・大域変数をヘッダファイルに書いて  ライブラリのソース
       ファイルにインクルードしておけば、 気づかずにインターフェースの変更をしてしまっても コンパ
       イラが知らせてくれるだろう。

        可能なときはいつでも静的 (もしくは等価なもの) を使う
       ライブラリに大域関数が少ないほど、ライブラリは柔軟に変更できる。  静的な関数・変数は、クラ
       イアントがアクセスできないから  インターフェースの変更とはならないので、好きなだけ変更する
       ことができる。

AUTOMAKE ルールの書き方

       libtool ライブラリのサポートは、 LTLIBRARIES プライマリのもとに実装されている。

       プログラムを libtool ライブラリにリンクするためには、 ライブラリ名を指定する program_LDADD
       変数を使うこと。 libtool に -static といったオプションを渡すためには program_LDFLAGS  を使
       うと良い。

       libtool  ライブラリをビルドするには、  ライブラリ名を指定する lib_LTLIBRARIES を使うこと。
       そして、たとえば、libtool-version-info オプションを 渡すには lib_LDFLAGS  を使うこと。
       次のセクションに例がある。

       作業をするためには、パッケージにいくつかの基本的なファイルを入れたり、 libtoolize を使う必
       要があるだろう。 libtool スクリプトを直接インクルードしてはならない。

       config.guess
              標準システム名を推測しようとする。

       config.sub
              標準システム名を確認するサブルーチンスクリプト。

       ltconfig
              指示されたシステムについて libtool スクリプトを作成する。

       ltmain.sh
              基本的な libtool の機能を実装した一般的なスクリプト。

モジュールのダイナミックロード

       libtool のダイナミックロード機能を使うためには、 configure.in のなかで AM_PROG_LIBTOOL  よ
       り前に  マクロ  AC_LIBTOOL_DLOPEN  を使わなければならない。 さもなければ、libtool はそのプ
       ラットホームには ダイナミックロードのメカニズムがないと仮定して、 これをシミュレートしよう
       とする。  このシミュレーション機能を使うためには、  実行ファイルをリンクするときに -dlopen-dlreopen  フラグを使い、  ダイナミックロードするオブジェクトを宣言しなければならない。
       libtool  はオブジェクトファイルをリンクし、 以下のような実行ファイルのシンボルテーブルを保
       持した データ構造を作成する。

              struct lt_dlsymlist { const char *NAME; lt_ptr_t ADDRESS; }

       NAME    には、"fprintf"     のような、シンボル名のアスキー文字列が保持される。     ADDRESS
       は、&fprintf のような、 適切なオブジェクトへのジェネリックポインタである。

              const lt_dlsymlist * lt_preloaded_symbols;

       この配列は実行ファイルにリンクされている  プリロードされたシンボルを表す。 -dlpreloaded さ
       れたファイルのそれぞれについて要素が存在し、  ファイル名  NAME   と   `0'   というアドレス
       ADDRESS、  およびこのファイルからエクスポートされたすべてのシンボルを保持する。 実行ファイ
       ル自身については、特別な名前 @PROGRAM@ が使われる。 最後のエレメントは NAME と `0'  という
       ADDRESS を持つ。

       ダイナミックロードされるライブラリもしくは、  モジュールをダイナミックロードしようとする実
       行ファイルをリンクするときは、 -module フラグを指定するのを忘れないこと。

       ダイナミックロードしようとしているライブラリの外部シンボルを、  実行ファイルが参照する必要
       がある場合は、実行ファイルをリンクするときに -export-dynamic を使用すること。

       ライブラリ名にバリエーションがあるので、 プログラムはどれがダイナミックロードするための 正
       しいファイルであるのかを決定する必要がある。 直接的な方法は `.la' ファイルを調べて、
        dlname='DLNAME' という行を探すことである。 この行はライブラリをダイナミックロードできない
       場合は空で、 そうでない場合はライブラリの名前が入っている。

       ソースファイル `foo.c', `bar.c' から `libbaz' とよばれるライブラリを作成し、 次に `a' とい
       う名前の実行ファイルを作成するために `a.c' を `libbaz' と リンクしようといる。

   ライブラリの作成
        コンパイルモード:Linux は共有ライブラリをサポートしているので、 libtool は  2  つのオブ
       ジェクトファイル、 一つは静的ライブラリ (`foo.lo')、 もう一つは共有ライブラリ (`foo.o') を
       作成する。 ソースファイル自身へのリンクをコンパイラにやらせたくないので、 -c  オプションは
       必須である。

              lightside:~% libtool cc -c foo.c
              cc -c -fPIC -DPIC foo.c -o .libs/foo.lo
              cc -c foo.c >/dev/null 2>&1
              lightside:~% libtool cc -c bar.c
              cc -c -fPIC -DPIC bar.c -o .libs/bar.lo
              cc -c bar.c >/dev/null 2>&1

         リンクモード、静的ライブラリのみをビルドする: 以前に作成された `.o' というオブジェクト
       ファイルを指定している。 -o オプションは必須である。

              lightside:~% libtool cc -o libbaz.a foo.o bar.o
              ar cru libbaz.a foo.o bar.o
              ranlib libbaz.a

        リンクモード、静的ライブラリと共有ライブラリをビルドする: `.lo'  というオブジェクトファ
       イルを指定する。 必須オプションは、前と同じ -o と ライブラリのインストールされるディレクト
       リを指示する -rpath である。 ライブラリは `.libs' ディレクトリに作成される。

              lightside:~% libtool cc -o libbaz.la foo.lo bar.lo \
                  -rpath /usr/local/lib
              cc -shared -Wl,-soname -Wl,libbaz.so.0 \
                  -o .libs/libbaz.so.0.0.0 foo.lo bar.lo
              (cd .libs && ln -s libbaz.so.0.0.0 libbaz.so.0)
              (cd .libs && ln -s libbaz.so.0.0.0 libbaz.so)
              ar cru .libs/libbaz.a foo.o bar.o
              ranlib .libs/libbaz.a
              creating libbaz.la
              (cd .libs && ln -s ../libbaz.la libbaz.la)

        インストールモード:ライブラリを指定したパス (この場合は `/usr/local/lib')  にインストー
       ルするために  必要なコマンドを実行する。 このモードでは共有ライブラリ (`.so') と静的ライブ
       ラリ (`.a') を インストールするとともに、アンインストールと情報提供の目的で libtool ファイ
       ル (`.la') がインストールされる。

       このモードはふつう特権ユーザーとして実行されるので、 -n または --dry-run オプションを 指定
       して結果をチェックしておくとよい。

              lightside:/tmp% libtool -n install libbaz.la /usr/local/lib
              install .libs/libbaz.so.0.0.0 /usr/local/lib/libbaz.so.0.0.0
              (cd /usr/local/lib && ln -s libbaz.so.0.0.0 libbaz.so.0)
              (cd /usr/local/lib && ln -s libbaz.so.0.0.0 libbaz.so)
              install libbaz.la /usr/local/lib/libbaz.la
              install .libs/libbaz.a /usr/local/lib/libbaz.a
              ranlib /usr/local/lib/libbaz.a
              chmod 644 /usr/local/lib/libbaz.a

   実行ファイルの作成
       最初に `a.c' をコンパイルする

              cc -c a.c

       ライブラリが既にインストールされている場合には、 普段のように続行することができる

              cc a.c -lbaz -L/usr/local/lib

       ライブラリがまだインストールされていない場合は、    実行ファイルのリンク・デバッグ・インス
       トールに  libtool を使用しなければならない (一度ライブラリがインストールされるまで、これは
       つづく)。 実際の実行ファイルはインストールされるまで `.libs' 内にあり、 作業ディレクトリに
       ある実行ファイルは単なるラッパーであることに注意すること。

       曖昧さを避けるため、絶対に  -l-L を使ってアンインストールされた 共有ライブラリにリンク
       してはならない。 `.la' ファイルへのパスだけを指定すること。  以下の  (`-lm')  でわかるよう
       に、インストール済みのライブラリは問題ではない。

              lightside:~% libtool cc a.o libbaz.la -o a -lm
              cc a.o -Wl,--rpath -Wl,/usr/local/lib \
                  .libs/libbaz.so -o .libs/a -lm
              lightside:~% libtool gdb a
              [複雑なデバッグのセッションは省略]
              lightside:~% libtool install -c a /usr/local/bin/a
              install -c .libs/a /usr/local/bin/a

   Makefile.am の作成
        最初に簡単な  configure.in を作成し、 automakelibtool のためのマクロを忘れずに追加す
       る。

              AC_DEFUN(AM_INIT_AUTOMAKE)
              AC_INIT(a.c)
              AM_INIT_AUTOMAKE(a, 1.0)
              AC_PROG_CC
              AM_PROG_LIBTOOL
              AC_OUTPUT(Makefile)

        対応する Makefile.am

              # ライブラリのビルド
              lib_LTLIBRARIES=libbaz.la
              libbaz_la_SOURCES = foo.c bar.c
              libbaz_la_LDFLAGS = -version-info 0:0:0

              bin_PROGRAMS = a a.debug

              # a.c と libbaz.la から a をビルド
              a_SOURCES = a.c
              a_LDADD = libbaz.la

              # 静的デバッグバージョンを作成
              a_debug_SOURCES = a.c
              a_debug_LDADD = libbaz.la
              a_debug_LDFLAGS = -static

        そして最後に実行する

              lightside:~% aclocal; libtoolize; automake --add-missing; autoconf
              lightside:~% ./configure; make

関連項目

        libtoolize(1), libltdl(3)

注意

       プログラムのバグについては <bug-libtool@gnu.org> へ報告してください。
       この man ページは Ragnar Hojland Espinosa <ragnar@ragnar-hojland.com> が作成しました。