File:  [Local Repository] / gnujdoc / libtool-1.3.5 / libtool-ja.texi
Revision 1.2: download - view: text, annotated - select for diffs
Sat Jun 11 07:02:50 2005 UTC (15 years, 3 months ago) by futoshi
Branches: MAIN
CVS tags: HEAD
Format html with makeinfo.
Some "@ininfo"s (for @menu and @top) replace to "@ifnottex"s.

\input texinfo   @c -*-texinfo-*-
@c %**start of header
@setfilename libtool-ja.info
@settitle Libtool
@c For double-sided printing, uncomment:
@c @setchapternewpage odd
@c %**end of header
@c @documentlanguage ja

@include libtool-v.texi
@set BUGADDR the libtool bug reporting address @email{bug-libtool@@gnu.org}
@set MAILLIST the libtool mailing list @email{libtool@@gnu.org}
@set objdir .libs

@dircategory GNU programming tools
@direntry
* Libtool(ja): (libtool-ja).           Generic shared library support script.
@end direntry

@dircategory Individual utilities
@direntry
* libtoolize(ja): (libtool-ja)Invoking libtoolize.     Adding libtool support.
@end direntry

@ifinfo
このファイルは,GNU Libtool @value{VERSION}を説明します.

Copyright (C) 1996-1999 Free Software Foundation, Inc.

Permission is granted to make and distribute verbatim copies of this
manual provided the copyright notice and this permission notice are
preserved on all copies.

@ignore
Permission is granted to process this file through TeX and print the
results, provided the printed document carries copying permission notice
identical to this one except for the removal of this paragraph


@end ignore
Permission is granted to copy and distribute modified versions of this
manual under the conditions for verbatim copying, provided that the
entire resulting derived work is distributed under the terms of a
permission notice identical to this one.

Permission is granted to copy and distribute translations of this manual
into another language, under the above conditions for modified versions,
except that this permission notice may be stated in a translation
approved by the Foundation.
@end ifinfo


@titlepage
@title GNU Libtool
@subtitle For version @value{VERSION}, @value{UPDATED}
@author Gordon Matzigkeit
@author Alexandre Oliva
@author Thomas Tanner
@author Gary V. Vaughan
@c 翻訳:西尾 太

@page
@vskip 0pt plus 1filll
Copyright @copyright{} 1996-1999 Free Software Foundation, Inc.

Permission is granted to make and distribute verbatim copies of this
manual provided the copyright notice and this permission notice are
preserved on all copies.

Permission is granted to copy and distribute modified versions of this
manual under the conditions for verbatim copying, provided that the
entire resulting derived work is distributed under the terms of a
permission notice identical to this one.

Permission is granted to copy and distribute translations of this manual
into another language, under the above conditions for modified versions,
except that this permission notice may be stated in a translation
approved by the Free Software Foundation.
@end titlepage

@c Put everything in one index (arbitrarily chosen to be the concept index).
@syncodeindex vr cp
@syncodeindex fn cp
@syncodeindex tp cp
@synindex pg cp

@ifnottex
@node Top, Introduction, (dir), (dir)
@comment  node-name,  next,  previous,  up
@top Shared library support for GNU

このファイルはGNU Libtoolの説明で,それは,パッケージ開発者が一般的な共
有ライブラリを提供可能とするスクリプトです.このエディションはバージョン
@value{VERSION}を説明します.

libtoolを用いた問題の報告方法の情報は,@xref{Reporting bugs}.

@menu
* Introduction::                What the heck is libtool?
* Libtool paradigm::            How libtool's view of libraries is different.
* Using libtool::               Example of using libtool to build libraries.
* Invoking libtool::            Running the @code{libtool} script.
* Integrating libtool::         Using libtool in your own packages.
* Versioning::                  Using library interface versions.
* Library tips::                Tips for library interface design.
* Inter-library dependencies::  Libraries that depend on other libraries.
* Dlopened modules::            @code{dlopen}ing libtool-created libraries.
* Using libltdl::               Libtool's portable @code{dlopen} wrapper library.
* Other languages::             Using libtool without a C compiler.
* Troubleshooting::             When libtool doesn't work as advertised.
* Maintaining::                 Information used by the libtool maintainer.
* Index::                       Full index.

@detailmenu
--- The Detailed Node Listing ---

はじめに

* Motivation::                  Why does GNU need a libtool?
* Issues::                      The problems that need to be addressed.
* Other implementations::       How other people have solved these issues.
* Postmortem::                  Learning from past difficulties.

libtoolの使用

* Creating object files::       Compiling object files for libraries.
* Linking libraries::           Creating libraries from object files.
* Linking executables::         Linking object files against libtool libraries.
* Debugging executables::       Running GDB on libtool-generated programs.
* Installing libraries::        Making libraries available to users.
* Installing executables::      Making programs available to users.
* Static libraries::            When shared libraries are not wanted.

@code{libtool}の呼び出し

* Compile mode::                Creating library object files.
* Link mode::                   Generating executables and libraries.
* Execute mode::                Debugging libtool-generated programs.
* Install mode::                Making libraries and executables public.
* Finish mode::                 Completing a library installation.
* Uninstall mode::              Removing executables and libraries.

パッケージとlibtoolの統合

* Makefile rules::              Writing @file{Makefile} rules for libtool.
* Using Automake::              Automatically supporting libtool.
* Configuring::                 Configuring libtool for a host system.
* Distributing::                What files to distribute with your package.
* Static-only libraries::       Sometimes shared libraries are just a pain.

libtoolのコンフィグレーション

* Invoking ltconfig::           @code{ltconfig} command line options.
* ltconfig example::            Manually configuring a @code{libtool}.
* AM_PROG_LIBTOOL::             Configuring @code{libtool} in @file{configure.in}.

パッケージにlibtoolを含める

* Invoking libtoolize::         @code{libtoolize} command line options.
* Autoconf .o macros::          Autoconf macros that set object file names.

ライブラリインターフェースバージョン

* Interfaces::                  What are library interfaces?
* Libtool versioning::          Libtool's versioning system.
* Updating version info::       Changing version information before releases.
* Release numbers::             Breaking binary compatibility for aesthetics.

インターフェース設計の助言

* C header files::              How to write portable include files.

dlopenモジュール

* Building modules::            Creating dlopenable objects and libraries.
* Dlpreopening::                Dlopening that works on static platforms.
* Finding the dlname::          Choosing the right file to @code{dlopen}.
* Dlopen issues::               Unresolved problems that need your attention.

libltdlの使用

* Libltdl interface::           How to use libltdl in your programs.
* Modules for libltdl::         Creating modules that can be @code{dlopen}ed.
* Distributing libltdl::        How to distribute libltdl with your package.

他の言語でのlibtoolの使用

* C++ libraries::

トラブルシューティング

* Libtool test suite::          Libtool's self-tests.
* Reporting bugs::              How to report problems with libtool.

libtoolテストスイート

* Test descriptions::           The contents of the test suite.
* When tests fail::             What to do when a test fails.

libtoolの管理メモ

* New ports::                   How to port libtool to new systems.
* Tested platforms::            When libtool was last tested.
* Platform quirks::             Information about different library systems.
* libtool script contents::     Configuration information that libtool uses.
* Cheap tricks::                Making libtool maintainership easier.

新しいシステムへのlibtoolの移植

* Information sources::         Where to find relevant documentation
* Porting inter-library dependencies::  Implementation details explained

プラットフォームの癖

* References::                  Finding more information.
* Compilers::                   Creating object files from source files.
* Reloadable objects::          Binding object files together.
* Archivers::                   Programs that create static archives.

@end detailmenu
@end menu

@end ifnottex

@node Introduction
@chapter はじめに

これまで,ソースコードパッケージの開発者が共有ライブラリの力を利用したい
場合,パッケージを実行するそれぞれのプラットフォームに対し,カスタムサポー
トコードを書く必要がありました.パッケージインストーラが構築されるライブ
ラリの種類を選択できるように,コンフィグレーションインターフェースを設計
する必要もありました.

GNU Libtoolは,一つのスクリプトで,プラットフォーム特有の依存とユーザイ
ンターフェースの両方をカプセル化することで,開発者の仕事を単純にします.
それぞれのホスト形式の完全な機能を一般的なインタフェースを通して利用でき
るようにGNU Libtoolは設計されていますが,やっかいな癖はプログラマから隠
されます.

GNU Libtoolの一貫したインターフェースは再保証されます@dots{}ユーザは好み
のソースコードパッケージを共有ライブラリに構築するため,曖昧なドキュメン
トを読む必要がありません.それらはパッケージの@code{configure}スクリプト
(または同等品)を実行し,libtoolはいやな仕事をすべて行います.

このドキュメント全体にいくつかの例があります.すべて同じ環境を仮定してい
ます.我々は,ライブラリ@file{libhello}を一般的な方法で構築したいと思っ
ています.

@file{libhello}は,共有ライブラリ,スタティックライブラリ,または,その
両方です@dots{}libtoolで移植できるホストシステムで利用可能な,あらゆるも
のです.

この章は,libtoolの最初の設計思想を説明します.歴史に興味がなかったり,
一貫した方法で拡張されているlibtoolに対しコードを書きたい場合,つぎの章
へ自由に行ってください.

@menu
* Motivation::                  Why does GNU need a libtool?
* Issues::                      The problems that need to be addressed.
* Other implementations::       How other people have solved these issues.
* Postmortem::                  Learning from past difficulties.
@end menu

@node Motivation
@section libtoolを書いた動機

@cindex motivation for writing libtool
@cindex design philosophy
1995年初頭から,数人の異なるGNU開発者は,パッケージに対する共有ライブラ
リのサポートの重要性を認識していました.そのように変更した主な動機は,
GNUプログラムでのコードのモジュール化と再利用を(概念的,物理的の両方で)
促進するためです.

そのような要求は,GNUパッケージにライブラリを組み込む方法で,パッケージ
インストーラが必要とするあらゆるライブラリ形式が可能な,一般的な方法が必
要だということを意味します.異なるプラットフォームで共有ライブラリを作成
する標準手続きが無いことが問題です.

以下のセクションで,GNUでの共有ライブラリのサポートが直面している重大な
問題と,共有ライブラリのサポートをlibtoolで標準化した方法を概説します.

@cindex specifications for libtool
@cindex libtool specifications
以下の仕様書が,このシステムの開発評価で使用されました.

@enumerate
@item
システムはできる限り簡潔である必要があります.

@item
システムはGNU管理者がより簡単に使用できるよう,GNU AutoconfとAutomakeユー
ティリティと完全に統合する必要があります.しかし,GNUパッケージ以外でも
使用できるように,これらのツールを要求してはなりません.

@item
他の(GNUでない)アーキテクチャとツールへの移植は望ましい.
@end enumerate

@node Issues
@section 問題の実装

@cindex tricky design issues
@cindex design issues
以下の問題は,再利用可能なあらゆる共有ライブラリシステム,特にlibtoolで
扱う必要があります.

@enumerate
@item
パッケージのインストーラは,構築されるライブラリの種類を制御可能であるべ
きです.

@item
インストールされていないライブラリと動的にリンクされるプログラムの実行を
巧妙に行うはずです.@code{LD_LIBRARY_PATH}が(サポートしている場合は)正し
く設定されている必要があり,そうでなければプログラムの実行に失敗するでしょ
う.

@item
システムは,共有ライブラリをサポートしていないホストでさえ,堅実に処理す
る必要があります.

@item
共有ライブラリを構築するとき必要なコマンドは,ホスト毎に大きく異なる可能
性があります.これらは,コンフィグレーション時に一定の方法で決定する必要
があります.

@item
インストールされる共有ライブラリの接尾子が常に明白なわけではありません.
通常,ファイル名は,ホスト毎に同じだということを仮定されるので,
@file{Makefile}規則が難しくなります.

@item
共有ライブラリをその場でアップグレード可能なように,システムは,単純なラ
イブラリバージョンナンバーの抽象化が必要です.プログラマは,バイナリ互換
を最大にするため,ライブラリへのインターフェースの設計方法を伝えるべきで
す.

@item
インストールする@file{Makefile}ターゲットは,パッケージインストーラに
特定の環境変数(@code{LD_LIBRARY_PATH}または同等のもの)を設定したり,
@code{ldconfig}を実行するよう,警告する必要があります.
@end enumerate

@node Other implementations
@section その他の実装

libtoolが開発されるまで,多くのフリーソフトウエアパッケージは,独自の
共有ライブラリを構築し,インストールしていました.最初は,既存の機能の再
発明を避けるために,これらのパッケージは調査されました.

さて,これらのパッケージに,libtoolが要求する,共有ライブラリシステム
の詳細な文章が無いのは明らかです.そのため,他のパッケージは,影響のため
多少捨てられました.

@node Postmortem
@section その他の実装の近代的な解析

@cindex other implementations, flaws in
@cindex reusability of library systems
調査されたそれぞれの実装は,多くの異なるホストシステムに対して,予定して
いた仕事をすべて公平に行いました.しかし,一般的に再利用できる要素として
機能するものは,これらの解決法にはなさそうです.

@cindex complexity of library systems
ほとんどのものは,実装が行っていることを正確に理解すること無く使用する
(まして,変更する)には複雑すぎ,それらは通常,文章化されていませんでした.

主な困難さは,異なるベンダーはライブラリについて異なる見解を持つこと,そ
して,調査したパッケージには,当然@emph{動作する}という,単一の規範を自
信を持って定めているものが無かったことです.

理想は,拡張シリーズと既存のライブラリシステムが絶えず動作するような編集
を実装する標準に,libtoolがなることです.しかし,オペレーティングシステ
ム開発者の悪い方法を修正することは簡単な仕事ではなく,人々は,バグが多く,
壊れていて,混乱したオペレーティングシステム上でさえ,今すぐに共有ライブ
ラリを構築したいと思っていました.

このため,libtoolは独立したシェルスクリプトとして設計されました.それは,
異なるプラットフォーム上のコンパイラスイートを,堅実で強力なインターフェー
スを用いて包み込むことで,@file{Makefile}の書き手を悩ませるライブラリ構
築での問題と矛盾から隔離しています.

運が良ければ,libtoolは役に立ちGNUコミュニティで使用され,そして,それを
書くとき学んだ教訓は,将来のライブラリシステムの設計に採用されるでしょう.


@node Libtool paradigm
@chapter libtoolのパラダイム

最初は,ライブラリのオブジェクト形式の任意の数をサポートするように
libtool は設計されました.その後,libtoolはより多くのプラットフォームに
移植され,新しいパラダイムは,ライブラリとプログラムの間の関係を記述する
ため,徐々に開発されました.

@cindex definition of libraries
@cindex libraries, definition of
要約すると,``ライブラリは複数のエントリポイントり,より正式に定義された
インターフェースがあるプログラムです.''

libtoolのバージョン0.7は,この新しいパラダイムを反映するため,完全に再設
計され書き換えられました.これまで,成功しているようです.libtoolは,以
前よりより単純になり,より役に立ちます.

libtoolパラダイムを導入する最善の方法は,それぞれの例を用い,既存のライ
ブラリシステムのパラダイムと比較することです.それは新しい考え方なので吸
収するまで少し時間がかかるかもしれませんが,理解したとき世界がより単純化
されるでしょう.

@node Using libtool
@chapter libtoolの使用

@cindex examples of using libtool
@cindex libtool examples
libtoolが人生をより単純にする方法が分かるまで,独自のパッケージでlibtool 
を使用することを話す意味がありません.この章の例は,標準的なライブラリの
構築処理と,libtoolの処理を,2つの異なるプラットフォームで比較することで,
主な特徴を紹介します.

@table @samp
@item a23
スタティックライブラリのみのUltrix 4.2プラットフォーム.

@item burger
共有ライブラリを持つ,NetBSD/i386 1.2プラットフォーム.
@end table

独自のプラットフォームの例をこれに続けることができ,それは,libtoolでイ
ンストールされた,前もってコンフィグレーションされたlibtoolスクリプトを
用います(@pxref{Configuring}).

以下の例のソースファイルは,libtool配布物の@file{demo}サブディレクトリか
ら持ってきました.ファイル@file{foo.c}と@file{hello.c}からライブラリ
@file{libhello}を構築していると考えてください.

@file{foo.c}ソースファイルが@code{cos}数学ライブラリ関数を使用していて,
それは通常,Cライブラリではなく単独の数学ライブラリで見つかることに注意
してください(@pxref{Trig Functions, , Trigonometric Functions, libc, The
GNU C Library Reference Manual}).そのため,@file{foo.o}や@file{foo.lo} 
を実行形式やライブラリにリンクするときは,常にリンク行の最後に@kbd{-lm} 
を加える必要があります(@pxref{Inter-library dependencies}).

同じ規則は,標準Cライブラリに無い関数を使用するときは常に当てはまります
@dots{}これらのオブジェクトに対しリンクするときは,適切な
@kbd{-l@var{name}}フラグをリンク行の終りに加える必要があります.

ライブラリをビルドした後,@file{libhello}に対して@file{main.o}をリンクす
ることでプログラムを作成したいと思います.

@menu
* Creating object files::       Compiling object files for libraries.
* Linking libraries::           Creating libraries from object files.
* Linking executables::         Linking object files against libtool libraries.
* Debugging executables::       Running GDB on libtool-generated programs.
* Installing libraries::        Making libraries available to users.
* Installing executables::      Making programs available to users.
* Static libraries::            When shared libraries are not wanted.
@end menu

@node Creating object files
@section オブジェクトファイルの作成

@cindex compiling object files
@cindex object files, compiling
ソースファイルからオブジェクトファイルを作成するため,コンパイラは`-c'フ
ラグ(とその他の必要なあらゆるフラグ)とともに呼び出されます.

@example
burger$ @kbd{gcc -g -O -c main.c}
burger$
@end example

上記のコンパイラコマンドは,ソースファイル@file{main.c}からオブジェクト
ファイル@file{main.o}を生成します.

ほとんどのライブラリシステムに対し,スタティックライブラリの一部となるオ
ブジェクトファイルを作成することは,実行可能な形式にリンクされるオブジェ
クトファイルを作成することと同じくらい単純です.

@example
burger$ @kbd{gcc -g -O -c foo.c}
burger$ @kbd{gcc -g -O -c hello.c}
burger$
@end example

@cindex position-independent code
@cindex PIC (position-independent code)
しかし,共有ライブラリは@dfn{position-independent code}(PIC)のみから構築
されます.そのため,標準のposition-dependent codeではなくPICを生成するよ
うにコンパイラに伝えるため,特定のフラグを渡す必要があります.

@cindex library object file
@cindex @samp{.lo} files
@cindex object files, library
これはライブラリ実装の詳細なので,libtoolは別々の(@samp{.o}の代わりに
@samp{.lo}で終わる)ライブラリオブジェクトファイルを用いて,複雑なPICコン
パイラフラグを隠します.共有ライブラリがない(または,特定のPICフラグがな
い)システムでは,これらのライブラリオブジェクトファイルは``標準の''オブ
ジェクトファイルと同じです.

@file{foo.c}と@file{hello.c}に対するライブラリオブジェクトファイルを作成
するため,単純に標準のコンパイルコマンドを引数として,libtoolを呼び出し
てください(@pxref{Compile mode}).

@example
a23$ @kbd{libtool gcc -g -O -c foo.c}
gcc -g -O -c foo.c
echo timestamp > foo.lo
a23$ @kbd{libtool gcc -g -O -c hello.c}
gcc -g -O -c hello.c
echo timestamp > hello.lo
a23$
@end example

libtoolがそれぞれの呼び出しに対し,2つのファイルを作成することに注意し
てください.@samp{.lo}ファイルはライブラリオブジェクトで,それは共有ライ
ブラリに構築され,@samp{.o}ファイルは標準的なオブジェクトファイルです.
@samp{a23}では,スタティックライブラリのみサポートされているので,ライブ
ラリオブジェクトはタイムスタンプのみです.

共有ライブラリのあるシステムでは,ライブラリオブジェクトと標準オブジェク
トが異なるように,libtoolはPIC生成フラグをコンパイルコマンドに自動的に挿
入します.

@example
burger$ @kbd{libtool gcc -g -O -c foo.c}
gcc -g -O -c -fPIC -DPIC foo.c
mv -f foo.o foo.lo
gcc -g -O -c foo.c >/dev/null 2>&1
burger$ @kbd{libtool gcc -g -O -c hello.c}
gcc -g -O -c -fPIC -DPIC hello.c
mv -f hello.o hello.lo
gcc -g -O -c hello.c >/dev/null 2>&1
burger$
@end example

2番目に実行されるGCCがその出力を破棄していることに注意してください.こ
れは,コンパイラの警告がうるさく重複しないために行われます.

@node Linking libraries
@section ライブラリのリンク

@pindex ar
libtoolを用いない場合,スタティックライブラリを作成するため,プログラマ
は@code{ar}コマンドを呼び出していました.

@example
burger$ @kbd{ar cru libhello.a hello.o foo.o}
burger$
@end example

@pindex ranlib
しかしもちろん,それだけではあまりに単純すぎて,多くのシステムでは(それ
以上のカルマや何かを与えるため)@code{ranlib}コマンドを結果として生成され
たライブラリ上で実行する必要があります.

@example
burger$ @kbd{ranlib libhello.a}
burger$
@end example

libtoolの``ライブラリはプログラム''というアプローチで与えられるこの作業
に対し,Cコンパイラを使用することは,より自然に感じられます.そのため,
共有ライブラリが無いプラットフォームでは,libtoolは単純にシステムの
@code{ar}(そして可能なら@code{ranlib})コマンドのラッパ-として動作します.

@cindex libtool libraries
@cindex @samp{.la} files
再びlibtoolライブラリ名を標準の名前(@samp{.a}接尾子の代わりに@samp{.la} 
接尾子を持ちます)と異なるものとします.libtoolの引数はコンパイラで
@file{libhello.la}という名の実行形式を生成するために使用したのと同じもの
です(@pxref{Link mode}).

@example
a23$ @kbd{libtool gcc -g -O -o libhello.la foo.o hello.o}
libtool: cannot build libtool library `libhello.la' from non-libtool \
                objects
a23$
@end example

あぁ!libtoolは通常のエラーを得てしまった@dots{}ライブラリオブジェクトの
代わりに,標準のオブジェクトからライブラリを構築しています.これはスタ
ティックライブラリでは問題ありませんが,共有ライブラリシステムでは非常に
重要です.

そのため,今回はライブラリオブジェクトファイルを用いて,もう一度試してみ
ましょう.@file{foo.c}が@code{cos}数学ライブラリを使用しているので,コマ
ンドラインに@kbd{-lm}を加える必要があることも忘れないでください
(@pxref{Using libtool}).

共有ライブラリを構築するその他の複雑なことは,(最終的に)インストールされ
るディレクトリパス(この場合は,@file{/usr/local/lib})
@footnote{@code{rpath}を指定しない場合,libtoolは便利なアーカイブを構築
しますが,それは共有ライブラリではありません(@pxref{Static libraries}).} 
を指定する必要があることです.

@example
a23$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \
                -rpath /usr/local/lib -lm}
mkdir @value{objdir}
ar cru @value{objdir}/libhello.a foo.o hello.o
ranlib @value{objdir}/libhello.a
creating libhello.la
a23$
@end example

さて,共有ライブラリのプラットフォーム上で同じトリックを試してみましょう.

@example
burger$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \
                -rpath /usr/local/lib -lm}
mkdir @value{objdir}
ld -Bshareable -o @value{objdir}/libhello.so.0.0 foo.lo hello.lo -lm
ar cru @value{objdir}/libhello.a foo.o hello.o
ranlib @value{objdir}/libhello.a
creating libhello.la
burger$
@end example

さてそれはかなり賢いです@dots{}libtoolは共有ライブラリを作成するため,ス
タティックライブラリと同様に,曖昧な@code{ld}コマンドを実行しただけです.

@cindex @file{@value{objdir}} subdirectory
libtoolが現在のディレクトリではなく,@file{@value{objdir}}サブディレクト
リに,予備のファイルを作成する方法に注意してください.この機能は構築ディ
レクトリをきれいにするのをより簡単にするためと,たまたまlibtoolの使用を
忘れていて他のプログラムを実行するとき,確実に手ひどく失敗させるのに役立
ちます.

@node Linking executables
@section 実行形式のリンク

@cindex linking against installed libraries
ライブラリを,実行形式とリンクする前に,@dfn{インストール}する(永久に位
置する場所にそれを配置する)点を選択した場合,リンクするためにlibtoolを使
用する必要はありません.ライブラリの位置を指定するため,単純に適切な
@samp{-L}と@samp{-l}フラグを使用してください.

@cindex buggy system linkers
システムのリンカによっては結果として生じる実行形式に,共有ライブラリの完
全なディレクトリ名の符号化を強要するものもあります.libtoolは永久に配置
されるディレクトリ名のみインストールされた実行形式に書き込むことを確実に
するため,特別な魔法でこの設計ミスに関して動作する必要があります.

@cindex security problems with buggy linkers
@cindex bugs, subtle ones caused by buggy linkers
このバグの重要性は,見落としてはなりません.それによるプログラムの暴走は
明白ではありません.それはセキュリティホールを作成し,さらに悪いことには,
パッケージのインストール後にライブラリソースコードを編集した場合,インス
トールされたプログラムの動作を変更してしまうでしょう!

そのため,インストールする前にライブラリとプログラムをリンクさせたい場合,
リンクするためにlibtoolを使用する必要があります.

@cindex linking against uninstalled libraries
ここにインストールされていないライブラリとリンクする古い方法があります.

@example
burger$ @kbd{gcc -g -O -o hell.old main.o libhello.a -lm}
burger$
@end example

libtoolの方法はほとんど同じです@footnote{しかし,インストールされていな
いlibtoolライブラリにリンクするために,@samp{-L}や@samp{-l}フラグの使用
を避けたほうがいいでしょう.@samp{.la}ファイルに対する,
@file{../intl/libintl.la}のような相対パスのみを指定してください.これは,
インストールされていない共有ライブラリに対しリンクするとき,あらゆる曖昧
さを取り除くため決定された設計です.}(@pxref{Link mode}).

@example
a23$ @kbd{libtool gcc -g -O -o hell main.o libhello.la -lm}
gcc -g -O -o hell main.o ./@value{objdir}/libhello.a -lm
a23$
@end example

真実としてはあまりに単純に見えます.libtoolが行うことは,
@file{libhello.la}を@file{./@value{objdir}/libhello.a}に変換することがす
べてですが,@samp{a23}は共有ライブラリがないことを忘れないでください.

@samp{burger}では,状況が異なります.

@example
burger$ @kbd{libtool gcc -g -O -o hell main.o libhello.la -lm}
gcc -g -O -o @value{objdir}/hell main.o -L./@value{objdir} -R/usr/local/lib -lhello -lm
creating hell
burger$
@end example

@cindex linking with installed libtool libraries

さて,@file{libhello.la}が既にインストールされていると仮定し,新しいプロ
グラムをそれとリンクしたいとします.自分でそれがある場所を探し,以下を実
行します.

@example
burger$ @kbd{gcc -g -O -o test test.o -L/usr/local/lib -lhello}
@end example

しかし,@file{/usr/local/lib}が標準のライブラリ検索パスに無い場合,
@code{test}を実行することはできません.しかし,既にインストールされてい
るlibtoolライブラリとリンクするためlibtoolを使用する場合,それは The
Right Thing (TM)となります.

@example
burger$ @kbd{libtool gcc -g -O -o test test.o /usr/local/lib/libhello.la}
gcc -g -O -o @value{objdir}/test test.o -Wl,--rpath
-Wl,/usr/local/lib /usr/local/lib/libhello.a -lm
creating test
burger$
@end example

libtoolが,ライブラリlibhello.laが依存している@samp{-lm}同様,必要なラン
タイムパスフラグを加えていることに注意してください.いいですね,ふっふ?

libtoolがラッパースクリプトを作成したので,インストールとデバッグにも
libtoolを使用したほうがいいでしょう.しかし,プログラムはインストールさ
れていないlibtoolライブラリには全く依存しないので,ラッパースクリプトを
用いない場合でも,それはおそらく有用でしょう.この場合はラッパースクリプ
トの作成を避けるため,おそらくより賢くlibtoolを作成できたでしょうが,こ
れは読者の演習として残しておきます.

@cindex wrapper scripts for programs
@cindex program wrapper scripts
実行形式@code{hell}は,実際には@file{@value{objdir}}サブディレクトリに作
成されることに注意してください.そして,ラッパースクリプトは現在のディレ
クトリに作成されます.

NetBSD 1.2では,libtoolは,@samp{-R/usr/local/lib}コンパイラフラグを使用
して,@file{libhello}のディレクトリのインストールを符号化します.そして,
ラッパースクリプトは,正しくインストールされるまで実行形式が正しい
(@file{./@value{objdir}}にある)共有ライブラリを見つけることを保証します.

2つの異なるプログラムを比較してみましょう.

@example
burger$ @kbd{time ./hell.old}
Welcome to GNU Hell!
** This is not GNU Hello.  There is no built-in mail reader. **
        0.21 real         0.02 user         0.08 sys
burger$ @kbd{time ./hell}
Welcome to GNU Hell!
** This is not GNU Hello.  There is no built-in mail reader. **
        0.63 real         0.09 user         0.59 sys
burger$
@end example

ラッパースクリプトは実行にかなりかかりますが,共有ライブラリがインストー
ルされていなくても,少なくとも結果は正しくなります.

そのため,共有ライブラリが生じると仮定すると,保存スペース全体ははどうなっ
ているのでしょう?

@example
burger$ @kbd{ls -l hell.old libhello.a}
-rwxr-xr-x  1 gord  gord  15481 Nov 14 12:11 hell.old
-rw-r--r--  1 gord  gord   4274 Nov 13 18:02 libhello.a
burger$ @kbd{ls -l @value{objdir}/hell @value{objdir}/libhello.*}
-rwxr-xr-x  1 gord  gord  11647 Nov 14 12:10 @value{objdir}/hell
-rw-r--r--  1 gord  gord   4274 Nov 13 18:44 @value{objdir}/libhello.a
-rwxr-xr-x  1 gord  gord  12205 Nov 13 18:44 @value{objdir}/libhello.so.0.0
burger$
@end example

さて,それは吸収されます.おそらく,私はこのプロジェクトを破壊し,作成中
の籠を取り上げたほうがいいでしょう.

実際,それは重要な点を証明します.共有ライブラリは,それが(関連する)複雑
さのため,オーバーへッドを招きます.この状況では,ダイナミックの価値は8 
キロバイトで,報酬は約4キロバイトです.そのため,少なくとも2,3以上のプ
ログラムとリンクするまで,共有される@file{libhello}を維持することは利点
ではありません.

@node Debugging executables
@section 実行形式のデバッグ

@file{hell}が複雑なプログラムの場合,システムにインストールする前にそれ
のテストとデバッグを間違いなく行いたいでしょう.上記のセクションで,
libtoolラッパースクリプトが,プログラムを直接実行することを可能にする方
法を見ましたが,残念ながら,このメカニズムはデバッガを妨げます.

@example
burger$ @kbd{gdb hell}
GDB is free software and you are welcome to distribute copies of it
 under certain conditions; type "show copying" to see the conditions.
There is no warranty for GDB; type "show warranty" for details.
GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc.

"hell": not in executable format: File format not recognized

(gdb) @kbd{quit}
burger$
@end example

残念です.GDBは実行形式がある場所が分からないので動作しません.そのため,
もう一度実行形式でGDBを呼び出してみてください.

@example
burger$ @kbd{gdb @value{objdir}/hell}
trick:/home/src/libtool/demo$ gdb .libs/hell
GDB is free software and you are welcome to distribute copies of it
 under certain conditions; type "show copying" to see the conditions.
There is no warranty for GDB; type "show warranty" for details.
GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc.
(gdb) @kbd{break main}
Breakpoint 1 at 0x8048547: file main.c, line 29.
(gdb) @kbd{run}
Starting program: /home/src/libtool/demo/.libs/hell
/home/src/libtool/demo/.libs/hell: can't load library 'libhello.so.2'

Program exited with code 020.
(gdb) @kbd{quit}
burger$
@end example

あぁ.さて,GDBは,@file{hell}がリンクしている共有ライブラリを見つけるこ
とができないため文句を言いました.そのため,正しいライブラリパスを設定し
て,デバッガを実行するため,libtoolを使う必要があります.幸い,
@file{@value{objdir}}ディレクトリを完全に忘れて,そのままの実行形式のラッ
パーで実行可能です(@pxref{Execute mode}).

@example
burger$ @kbd{libtool gdb hell}
GDB is free software and you are welcome to distribute copies of it
 under certain conditions; type "show copying" to see the conditions.
There is no warranty for GDB; type "show warranty" for details.
GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc.
(gdb) @kbd{break main}
Breakpoint 1 at 0x8048547: file main.c, line 29.
(gdb) @kbd{run}
Starting program: /home/src/libtool/demo/.libs/hell

Breakpoint 1, main (argc=1, argv=0xbffffc40) at main.c:29
29	  printf ("Welcome to GNU Hell!\n");
(gdb) @kbd{quit}
The program is running.  Quit anyway (and kill it)? (y or n) @kbd{y}
burger$
@end example

@node Installing libraries
@section ライブラリのインストール

@pindex strip
libtoolが無いシステムでライブラリをインストールすることは,全く簡単です
@dots{}それらをその場所にコピーするだけです.@footnote{ライブラリを偶然
でもシンボルを切り捨てないでください,そうすると使用不可能になります.}

@pindex su
@example
burger$ @kbd{su}
Password: @kbd{********}
burger# @kbd{cp libhello.a /usr/local/lib/libhello.a}
burger#
@end example

おっと,@code{ranlib}コマンドを忘れないでください.

@example
burger# @kbd{ranlib /usr/local/lib/libhello.a}
burger#
@end example

@pindex install
libtoolのインストールは,同様に全く単純です.通常使用する,
@code{install}や@code{cp}コマンドをそのまま使用してください
(@pxref{Install mode}).

@example
a23# @kbd{libtool cp libhello.la /usr/local/lib/libhello.la}
cp libhello.la /usr/local/lib/libhello.la
cp @value{objdir}/libhello.a /usr/local/lib/libhello.a
ranlib /usr/local/lib/libhello.a
a23#
@end example

アンインストールでlibtoolを助け(@pxref{Uninstall mode}),リンクし
(@pxref{Linking executables}),dlopenでプログラムを助ける
(@pxref{Dlopened modules})ため,libtoolのライブラリ@file{libhello.la}も
インストールされることに注意してください.

ここに,共有ライブラリの例があります.

@example
burger# @kbd{libtool install -c libhello.la /usr/local/lib/libhello.la}
install -c @value{objdir}/libhello.so.0.0 /usr/local/lib/libhello.so.0.0
install -c libhello.la /usr/local/lib/libhello.la
install -c @value{objdir}/libhello.a /usr/local/lib/libhello.a
ranlib /usr/local/lib/libhello.a
burger#
@end example

@cindex stripping libraries
@cindex libraries, stripping
ライブラリインストール時にBSD互換のinstallプログラムを使用する場合,
@samp{-s} (シンボルを切り捨てる)フラグを指定すると安全です.libtool は
@samp{-s}フラグを無視するか,ライブラリからデバッグとコンパイラシンボル
のみを切り捨てるプログラムを実行します.

ライブラリを一度配置すると,使用する前に必要な追加のコンフィグレーション
を行います.最初に構築時に使用した@samp{-rpath}フラグと同じ場所に,ライ
ブラリが実際にインストールされていることを確かめる必要があります.

@cindex postinstallation
@cindex installation, finishing
@cindex libraries, finishing installation
そして,@samp{libtool -n --finish @var{libdir}}を実行すると,行うことの
ヒントが与えられます(@pxref{Finish mode}).

@example
burger# @kbd{libtool -n --finish /usr/local/lib}
PATH="$PATH:/sbin" ldconfig -m /usr/local/lib
-----------------------------------------------------------------
Libraries have been installed in:
   /usr/local/lib

To link against installed libraries in a given directory, LIBDIR,
you must use the `-LLIBDIR' flag during linking.

 You will also need to do one of the following:
   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable
     during execution
   - add LIBDIR to the `LD_RUN_PATH' environment variable
     during linking
   - use the `-RLIBDIR' linker flag

See any operating system documentation about shared libraries for
more information, such as the ld and ld.so manual pages.
-----------------------------------------------------------------
burger#
@end example

これらのステップを完了した後,インストールされたライブラリを使用開始でき
ます.作成されたライブラリに依存する実行形式もインストールできます.

@node Installing executables
@section 実行形式のインストール

インストールされていないlibtoolライブラリに対して実行形式をリンクするた
めにlibtoolを使用した場合(@pxref{Linking executables}),ライブラリをイン
ストールした後で,実行形式をインストールするためlibtoolを使用する必要が
あります.

そして,Ultrixの例を実行します.

@example
a23# libtool install -c hell /usr/local/bin/hell
install -c hell /usr/local/bin/hell
a23#
@end example

共有ライブラリシステムでは,libtoolはラッパースクリプトを無視し,正しい
バイナリをインストールします.

@example
burger# libtool install -c hell /usr/local/bin/hell
install -c @value{objdir}/hell /usr/local/bin/hell
burger#
@end example

@node Static libraries
@section スタティックライブラリとのリンク

@cindex static linking
@cindex convenience libraries
libtoolの旨味を知って,@code{ar}と@code{ranlib}の愚かさへなぜ戻るのでしょ
う?さて,決して共有されるはずがないスタティックアーカイブをつくることが
望ましいときもあります.最もよくあるケースは,複数の異なるプログラムを構
築するために使用する,オブジェクトファイルの集まりを持っているときです.
個々のプログラムに対し,すべてのオブジェクトファイルをリストアップする代
わりに,それらのオブジェクトから``便利なライブラリ''を作成し,ライブラリ
とプログラムをリンクすることが可能です.この技術は,他のディレクトリのラ
イブラリへのリンクをサポートするので,他のディレクトリのソースから構築さ
れるオブジェクトファイルをリンクするサポートが欠けている,GNU automakeを
補うためによく使用されます.この制限は,リリース1.4までのGNU automakeに
当てはまります.より新しいリリースは,他のディレクトリのソースをサポート
するでしょう.

この便利なライブラリとプログラムをリンクしたいだけ場合,完全にlibtoolを
無視し,古い@code{ar}と@code{ranlib}コマンド(や,対応するGNU automake
@samp{_LIBRARIES}規則)が使用可能です.(おそらく使用したくはないでしょう
が)libtoolを使用して,便利なライブラリをインストールすることさえ可能です.

@example
burger$ @kbd{libtool ./install-sh -c libhello.a /local/lib/libhello.a}
./install-sh -c libhello.a /local/lib/libhello.a
ranlib /local/lib/libhello.a
burger$
@end example

スタティックライブラリのインストールにlibtoolを使用すると,ライブラリが
(@samp{-s}フラグを使用したインストーラの場合のように)偶然切り取られるこ
とから守り,自動的に実行される正しい@code{ranlib}コマンドと同様になりま
す.

しかし,libtoolライブラリは単にオブジェクトファイルの集合以上です.それ
らは古いアーカイブにはない,ライブラリの依存情報も運ぶことが可能です.
libtoolの静的な便利なライブラリを作成したい場合,スタティックライブラリ
のみに興味があることを示すため,@samp{-rpath}フラグを省略し
@samp{-static}を使用することができます.そのようなスタティックライブラリ
とリンクするとき,libtoolは実際にすべてのオブジェクトファイルと依存する
ライブラリをプログラムにリンクします.

@samp{-rpath}と@samp{-static}の両方を省略した場合,libtoolは,他の
libtoolライブラリで,共有ライブラリの作成にすら使用可能なlibtoolの便利な
ライブラリを作成します.静的な場合のように,ライブラリは一組のオブジェク
トファイルと依存するライブラリの別名として動作しますが,この場合,オブジェ
クトファイルは共有ライブラリに含まれるほうが適しています.しかし,直接ま
たは間接的に,単一のプログラムやライブラリに単一の便利なライブラリをリン
クしないように注意して下さい.さもなければ,シンボル再定義に関するエラー
を得るでしょう.

GNU automakeを使用するとき,@samp{-rpath}オプションがリンク時に渡されな
いように,便利なライブラリに対する@code{lib_LTLIBRARIES}の代わりに
@code{noinst_LTLIBRARIES}を使用した方がよいでしょう.

経験的に,最大一つのlibtoolライブラリにlibtoolの便利なライブラリをリンク
し,プログラムにはリンクせず,libtoolの便利なスタティックライブラリを一
つのプログラムにのみリンクし,それは,ライブラリ依存情報を便利なスタティッ
クライブラリのユーザに運ぶことが必要な場合のみです.

@cindex standalone binaries
静的なリンクが適している,その他の一般的な状況は,独立したバイナリを作成
するときです.リンクにlibtoolを使用し,@samp{-all-static}フラグを加えて
ください.

@node Invoking libtool
@chapter @code{libtool}の呼び出し
@pindex libtool
@cindex libtool command options
@cindex options, libtool command
@cindex command options, libtool

@code{libtool}プログラムは以下の構文を持ちます.

@example
libtool [@var{option}]@dots{} [@var{mode-arg}]@dots{}
@end example

@noindent
そして,以下のオプションを受け入れます.

@table @samp
@item --config
libtoolのコンフィグレーション変数を表示し終了します.

@item --debug
シェルスクリプトの実行の追跡を標準出力にダンプします.これは多くの出力を
生成するので,@code{less}(や@code{more})にパイプしたり,ファイルにリダイ
レクトしたいかもしれません.

@item -n
@itemx --dry-run
あらゆるファイルを作成,編集,削除せず,libtoolによりコマンドで実行され
るものを表示するだけです.

@item --features
基本的なコンフィグレーションオプションを表示します.これは,パッケージが
構築するライブラリをスタティックまたは共有のいずれにするか決定する方法を
提供します.

@item --finish
@samp{--mode=finish}と同じです.

@item --help
へルプメッセージを表示し終了します.@samp{--mode=@var{mode}}が指定された
場合,@var{mode}の詳細へルプを表示します.

@item --mode=@var{mode}
処理モードとして@var{mode}を使用します.デフォルトで,処理モードは
@var{mode-args}から推測されます.

@var{mode}が指定された場合,それは以下の一つにする必要があります.

@table @samp
@item compile
ソースファイルをlibtoolオブジェクトにコンパイルします.

@item execute
インストールされていない,libtoolが生成したプログラムやライブラリを他の
プログラムが使用できるように,自動的にライブラリパスを設定します.

@item finish
libtoolライブラリのシステムへのインストールを完全に行います.

@item install
ライブラリや実行形式をインストールします.

@item link
ライブラリや実行形式を作成します.

@item uninstall
ライブラリや実行形式を削除します.
@end table

@item --version
libtoolのバージョン情報を出力し終了します.
@end table

@var{mode-args}は引数の変数の数で,処理モードの選択に依存します.一般的
に,それぞれの@var{mode-arg}は,libtool自身ではなく,libtoolが呼び出すプ
ログラムで解釈されます.

@menu
* Compile mode::                Creating library object files.
* Link mode::                   Generating executables and libraries.
* Execute mode::                Debugging libtool-generated programs.
* Install mode::                Making libraries and executables public.
* Finish mode::                 Completing a library installation.
* Uninstall mode::              Removing executables and libraries.
@end menu

@node Compile mode
@section コンパイルモード
@cindex mode, compile
@cindex compile mode

@dfn{コンパイル}モードに対し,@var{mode-args}は,`標準的な'オブジェクト
ファイルを作成するとき使用するコンパイルコマンドです.これらの引数は,C
コンパイラの名前で始まり,オブジェクトファイル蚤を作成するための
@samp{-c}コンパイラフラグを含みます.

libtoolは,ソースファイル名からディレクトリ要素を削除して出力ファイル名
を決定し,ソースコードの接尾子(例えば,Cソースコードに対する@samp{.c})を
ライブラリオブジェクト接尾子@samp{.lo}に置換します.

共有ライブラリの構築の場合は,必要なPIC生成フラグがコンパイルコマンドに
置換されます.

@samp{-static}オプションが与えられた場合は,libtoolが
@samp{--disable-static}でコンフィグレーションされていた場合でも,
@samp{.o}ファイルが構築されてます.

@samp{-o}オプションが,現在は完全にサポートされていることに注意してくだ
さい.それは,(オブジェクトのロックと移動によって)それがサポートされてい
ないプラットフォームでエミュレートされているので,Makefileを少し編集する
だけでlibtoolの使用は本当に簡単です.入力例です.

@example
libtool gcc -c foo/x.c -o foo/x.lo
@end example
これは期待したことを行います.

しかし,コンパイラが@samp{-c}と@samp{-o}をサポートしていない場合,既存の
@file{./x.o}を上書きせずに@file{foo/x.c}をコンパイルすることが不可能なこ
とに注意してください.そのため,ソースファイル@file{./x.c}がある場合,
@file{./x.o}(や@file{./x.lo})が,サブディレクトリのあらゆる@file{x.lo}の
後で再作成されることを確実にするため,@file{Makefile}に依存性の導入を必
ず行ってください.

@example
x.o x.lo: foo/x.lo bar/x.lo
@end example
これは,プログラムやライブラリを作成するため,一時的に壊れた@file{x.o}の
使用を試みないことを確実にします.それは,@samp{-c}と@samp{-o}を同時にサ
ポートするプラットフォームで,不必要な再コンパイルを引き起こすかもしれま
せんが,それは,そうでないものに対して安全にする唯一の方法です.

@node Link mode
@section リンクモード
@cindex link mode
@cindex mode, link

@dfn{リンク}モードは,(ライブラリオブジェクトを含む)オブジェクトファイル
と,その他のライブラリや作成された実行可能なプログラムをリンクします.

@var{mode-args}は,いくつかのオブジェクトファイルから(@samp{-o}フラグを
用いた)出力ファイルを作成するためにCコンパイラが使用するコマンドから成り
立ちます.

以下の@var{mode-args}の組は特別に扱われます.

@table @samp
@cindex undefined symbols, allowing
@cindex unresolved symbols, allowing
@item -all-static
@var{output-file}がプログラムの場合,共有ライブラリと全くリンクしません.
@var{output-file}がライブラリの場合,スタティックライブラリのみ作成しま
す.

@item -avoid-version
ライブラリとモジュールに対しバージョン管理(@pxref{Versioning})を避けよう
とし,すなわち,バージョン情報は保存されず,シンボリックリンクも作成され
ません.プラットフォームがバージョニングを要求する場合,このオプションは
効果がありません.

@item -dlopen @var{file}
ネイティブなdlopenがホストプラットフォームでサポートされていない場合
(@pxref{Dlopened modules})や,プログラムが@samp{-static}や
@samp{-all-static}でリンクされている場合,@samp{-dlpreopen @var{file}}と
同じです.それ以外では効果はありません.@var{file}が@code{self}の場合,
@code{-export-dynamic}を可能にする,または,@samp{-dlpreopen self}に後退
することにより,libtoolはプログラムがそれ自身を@code{dlopen}可能であるこ
とを確かめます.

@item -dlpreopen @var{file}
@var{file}を出力プログラムにリンクし,そのシンボルを
@var{lt_preloaded_symbols}に含めます(@pxref{Dlpreopening}).@var{file}が
@code{self}の場合,プログラムのシンボル自身が@var{lt_preloaded_symbols} 
に加えられます.@var{file}が@code{force}の場合,libtoolは,
@var{lt_preloaded_symbols}が空であろうがなかろうが,常に@emph{定義済}で
あることを確実にします.

@item -export-dynamic
@var{output-file}からのシンボルが@code{dlsym}で解決されることを許可しま
す(@pxref{Dlopened modules}).

@item -export-symbols @var{symfile}
リンカに@var{symfile}でリストアップされているシンボルのみエクスポートす
るよう伝えます.シンボルファイルは@samp{.sym}で終わるべきで,一行毎に一
シンボル名を含める必要があります.このオプションは効果がないプラットフォー
ムがあります.デフォルトですべてのシンボルがエクスポートされます.

@item -export-symbols-regex @var{regex}
正規表現@var{regex}に一致するシンボルのみエクスポートされる以外,
@samp{-export-symbols}と同じです.デフォルトですべてのシンボルがエクスポー
トされます.

@item -L@var{libdir}
既にインストールされている,要求されるライブラリに対し,@var{libdir}を検
索します.

@item -l@var{name}
@var{output-file}はインストールされているライブラリ@file{lib@var{name}} 
を要求します.このオプションは@var{output-file}が実行形式でないときも要
求されます.

@item -module
dlopen可能なライブラリを作成します(@pxref{Dlopened modules}).このオプショ
ンはプログラムでは動作しません.モジュール名は'lib'の前置は不要です.し
かし,名前の破壊を避けるため,'libname'と'name' パッケージで同時に使用し
てはなりません.

@item -no-undefined
@var{output-file}が他のライブラリに依存しないことを宣言します.他のライ
ブラリに依存する共有ライブラリを作成不可能なプラットフォームもあります
(@pxref{Inter-library dependencies}).

@item -o @var{output-file}
指定されたオブジェクトとライブラリから@var{output-file}を作成します.

@item -release @var{release}
ユーザが他より新しいバージョンを簡単に伝えられるよう,パッケージのリリー
ス@var{release}で生成されたライブラリを指定します.このフラグを使用する
場合,パッケージの2つのリリースがバイナリ互換でないことを警告されます.
バイナリ互換が欲しい場合,代わりに@samp{-version-info}フラグを使用してく
ださい(@pxref{Versioning}).

@item -rpath @var{libdir}
@var{output-file}がライブラリの場合,それは最終的に@var{libdir}にインス
トールされます.@var{output-file}がプログラムの場合,プログラムの実行時
のパスを@var{libdir}に加えます.

@item -R @var{libdir}
@var{output-file}がプログラムの場合,プログラムの実行時のパスを
@var{libdir}に加えます.@var{output-file}がライブラリの場合,ライブラリ
がプログラムとリンクされるときは,常に@var{libdir}が実行時のパスに加えら
れるように,その@var{dependency_libs}に-R@var{libdir}を加えます.

@item -static
@var{output-file}がプログラムの場合,インストールされていない共有ライブ
ラリとリンクしません.@var{output-file}がライブラリの場合,スタティック
ライブラリのみ作成します.

@item -version-info @var{current}[:@var{revision}[:@var{age}]]
@var{output-file}がlibtoolライブラリの場合,それを構築するために,バージョ
ン情報@var{current},@var{revision},そして@var{age}を使用します
(@pxref{Versioning}).このフラグをパッケージのリリース情報の指定に使用せ
ず,そのためには@samp{-release}を参照してください.
@end table

@var{output-file}が@samp{.la}で終わる場合,libtoolライブラリが作成され,
それはライブラリオブジェクト(@samp{.lo}ファイル)からのみ作成される必要が
あります.@samp{-rpath}オプションは要求されません.現在の実装では,
libtoolライブラリが他のインストールされていないlibtoolライブラリに依存す
ることはできません(@pxref{Inter-library dependencies}).

@var{output-file}が@samp{.a}で終わる場合,標準的なライブラリは@code{ar} 
と,おそらく@code{ranlib}を使用して作成されます.

@cindex partial linking
@cindex linking, partial
@var{output-file}が@samp{.o}や@samp{.lo}で終わる場合,再ロード可能なオブ
ジェクトファイルは,(通常@samp{ld -r}を用いて)入力ファイルから作成されま
す.この手法は@dfn{部分的なリンク}と呼ばれることが多いです.

それ以外の場合,実行可能なプログラムが作成されます.


@node Execute mode
@section 実行モード
@cindex execute mode
@cindex mode, execute

@samp{実行}モードに対し,ライブラリパスは自動的に設定され,プログラムは
実行されます.

@var{mode-args}の最初は,プログラム名として扱われ,残りはプログラムの引
数となります.

以下の@var{mode-args}の組は特別に扱われます.

@table @samp
@item -dlopen @var{file}
ライブラリパスに@var{file}を含むディレクトリを加えます.
@end table

このモードは,あらゆる@samp{-dlopen}フラグによって,ライブラリパス環境変
数を設定します.

すべての@var{args}がlibtoolの実行形式のラッパーの場合,それらは対応する
インストールされていないバイナリの名前に変換され,それらが要求するすべて
のライブラリディレクトリがライブラリパスに加えられます.

@node Install mode
@section インストールモード
@cindex install mode
@cindex mode, install

@dfn{インストール}モードでは,libtoolは@var{mode-args}を,@code{cp}で始
まるインストールコマンドやBSD互換の@code{install}プログラムとして解釈し
ます.

@var{mode-args}の残りは,そのコマンドの引数として解釈されます.

コマンドが実行され,特権の不要な必要なインストール後のコマンドも完全に実
行されます.

@node Finish mode
@section フィニッシュモード
@cindex finish mode
@cindex mode, finish

@dfn{フィニッシュ}モードは,ユーザプログラムにlibtoolライブラリを配置し,
リンクできるよう,システム管理者のインストールを助けます.

それぞれの@var{mode-arg}はライブラリのディレクトリの名前として解釈されま
す.このコマンドの実行は,@samp{--dry-run}オプションが役に立つように,スー
パーユーザの特権を要求するかもしれません.

@node Uninstall mode
@section アンインストールモード
@cindex uninstall mode
@cindex mode, uninstall

@dfn{アンインストール}モードはインストールされているライブラリ,実行形式,
そしてオブジェクトを削除します.

@var{mode-arg}の最初はファイルの削除に使用するプログラム名(通常は
@file{/bin/rm})です.

残りの@var{mode-args}は,(`-'で始まる)削除プログラムに対するフラグ,また
は削除するファイル名です.

@node Integrating libtool
@chapter パッケージとlibtoolの統合

この章は,ユーザが混乱せずに共有ライブラリをインストールできるように,パッ
ケージとlibtoolの統合方法を記述します.

@menu
* Makefile rules::              Writing @file{Makefile} rules for libtool.
* Using Automake::              Automatically supporting libtool.
* Configuring::                 Configuring libtool for a host system.
* Distributing::                What files to distribute with your package.
* Static-only libraries::       Sometimes shared libraries are just a pain.
@end menu

@node Makefile rules
@section libtoolに対する@file{Makefile}規則を書く
@cindex Makefile
@cindex Makefile.am
@cindex Makefile.in

libtoolは,完全にAutomake(@pxref{Top,, Introduction, automake, The
Automake Manual})と統合されていて,それはAutomake version 1.2から開始し
ました.

通常の@file{Makefile}(や@file{Makefile.in})で,libtoolを使用したい場合,
独自のものとなります.Automake 1.2を使用せず,パッケージにlibtoolの組み
込み方を知らない場合,以下の一つが必要です.

@enumerate 1
@item
Automake(バージョン1.2以降)を近くのGNUのミラーからダウンロードし,インス
トールし,その使用を開始してください.

@item
@file{Makefile}規則の手での書き方を学んでください.複雑なときもあります
が,古いライブラリをコンパイルするための規則を書けるぐらいの知識がある場
合,libtoolライブラリに対する新しい規則の理解は可能でしょう(ヒント:
libtool 配布物の@file{demo}サブディレクトリの@file{Makefile.in}を調べて
ください@dots{}特に,それがAutomakeによって@file{Makefile.am}から自動的
に生成されたことに注意してください).
@end enumerate

@node Using Automake
@section libtoolとともにAutomakeを使用する

@vindex LTLIBRARIES
libtoolライブラリのサポートは,@samp{LTLIBRARIES}プライマリの元で実装さ
れました.

ここに,libtool配布物の@file{demo}サブディレクトリの,Automake
@file{Makefile.am}からの例がいくつかあります.

最初に,プログラムをlibtoolライブラリとリンクするため,
@samp{program_LDADD}変数のみを使用してください.

@example
bin_PROGRAMS = hell hell.debug

# Build hell from main.c and libhello.la
hell_SOURCES = main.c
hell_LDADD = libhello.la

# Create an easier-to-debug version of hell.
hell_debug_SOURCES = main.c
hell_debug_LDADD = libhello.la
hell_debug_LDFLAGS = -static
@end example

フラグ@samp{-dlopen}と@samp{-dlpreopen}(@pxref{Link mode})は,
@var{program_LDADD}変数で,より適切になります.残念ながら,リリース1.4ま
でのGNU automakeは,@var{program_LDADD}変数でこれらのフラグを受け入れな
いため,以下で代用します.

@itemize @bullet
@item
それらを@var{program_LDFLAGS}に加え,@var{program_DEPENDENCIES}にライブ
ラリをリストアップし,それらが属するこれらのフラグを受け入れるGNU
automakeのリリースを待ってください.

@item
フラグの回りを引用符で囲みますが,@var{program_DEPENDENCIES}も設定する必
要があります.

@example
program_LDADD = "-dlopen" libfoo.la
program_DEPENDENCIES = libfoo.la
@end example

@item
@file{configure.in}の@samp{AC_SUBST}で,変数@var{DLOPEN}と
@var{DLPREOPEN}を設定し,@samp{program_LDADD}での明確なフラグ
@samp{-dlopen}と@samp{-dlpreopen}に対する置換物として,@samp{@@DLOPEN@@} 
と@samp{@@DLPREOPEN@@}を使用します.Automakeは,依存性から
@samp{AC_SUBST}された変数を捨てるので,@samp{program_LDADD}のこれらのフ
ラグを受け入れたとき,それは正確に期待したように動作します.
@end itemize

(インストールされていない共有libtoolライブラリとのリンクを避けるため
@samp{-static}を使用するような)@samp{program}をリンクしている間,libtool
に渡したいあらゆるフラグを詰め込むため,@samp{program_LDFLAGS}変数を使用
することも可能です.

libtoolライブラリを構築することは,ほとんど冒険です@dots{}
@samp{-version-info}(@pxref{Versioning})オプションをlibtoolに渡すため,
@samp{libhello_la_LDFLAGS}を使用することに注意してください.

@example
# Build a libtool library, libhello.la for installation in libdir.
lib_LTLIBRARIES = libhello.la
libhello_la_SOURCES = hello.c foo.c
libhello_la_LDFLAGS = -version-info 3:12:1
@end example

@samp{-rpath}オプションは,(@code{noinst_LTLIBRARIES}としてリストアップ
されるライブラリ以外)Automakeにより自動的に渡されるので,指定する必要は
ありません.

詳細は,@xref{A Shared Library, Building a Shared Library, The Automake
Manual, automake, The Automake Manual}.


@node Configuring
@section libtoolのコンフィグレーション
@cindex configuring libtool

libtoolは,共有ライブラリを作成し適切なものにリンクするため,コンパイラセット
とオペレーティングシステムの詳細な知識を必要とします.libtool配布物をイ
ンストールするとき,システム特有のlibtoolスクリプトはバイナリディレクト
リにインストールされます.

しかし,独自のパッケージとともにlibtoolを配布するとき
(@pxref{Distributing}),パッケージをコンパイルするために使用されるコンパ
イラセットとオペレーティングシステムを,常に知っているわけではありません.

このため,libtoolを使用する前に@dfn{コンフィグレーション}する必要があり
ます.この考えは,GNU @code{configure}スクリプトを使用するものに似ていま
す.@code{configure}は,システムの特徴に対しいくつものテストを行い,
@file{Makefiles}(と,おそらく@file{config.h}ヘッダファイル)を生成し,そ
の後,@code{make}を実行しパケージを構築することができます.

libtoolは@code{configure}スクリプトと同等の独自のものがあり,それは
@code{ltconfig}です.

@menu
* Invoking ltconfig::           @code{ltconfig} command line options.
* ltconfig example::            Manually configuring a @code{libtool}.
* AM_PROG_LIBTOOL::             Configuring @code{libtool} in @file{configure.in}.
@end menu

@node Invoking ltconfig
@subsection @code{ltconfig}の呼び出し
@pindex ltconfig
@cindex ltconfig command options
@cindex options, ltconfig command
@cindex command options, ltconfig

@code{ltconfig}は,連続したコンフィグレーションテストを実行し,システム
特有の@code{libtool}を現在のディレクトリに作成します.@code{ltconfig}プ
ログラムは以下の構文です.

@example
ltconfig [@var{option}]@dots{} @var{ltmain} [@var{host}]
@end example

@noindent
そして,以下のオプションを受け入れます.

@table @samp
@item --debug
シェルスクリプトの実行の追跡を標準出力にダンプします.これは多くの出力を
生成するので,@code{less}(や@code{more})にパイプしたり,ファイルにリダイ
レクトしたいかもしれません.

@item --disable-shared
スタティックライブラリのみを構築する@code{libtool}を作成します.

@item --disable-static
可能な場合,共有ライブラリのみ構築する@code{libtool}を作成します.スタ
ティックライブラリのみ構築可能な場合,このフラグは効果がありません.

@item --disable-fast-install
構築したディレクトリでの実行が適切でない,デフォルトで作成される実行形式
がインストール可能なプラットフォームでは,デフォルトでインストールされな
いライブラリを検索する実行形式にリンクする@code{libtool}を作成し,インス
トール時に再リンクします.単一の実行形式で十分なプラットフォームでは無視
されます.

@item --enable-dlopen
dlopenメカニズムがサポートされているかどうか調べます.このフラグが与えら
れない場合や,動作するdlopenメカニズムが見つからない場合,すべてdlopenさ
れたモジュールをdlpreopenする@code{libtool}を生成します.

@item --help
へルプメッセージを表示し終了します.

@item --no-verify
@var{host}が有効な標準ホスト名システムであることを照合するために
@code{config.sub}を使用しません.

@item --output=@var{file}
@item -o @var{file}
@code{libtool}と呼ばれるlibtoolを作成する代わりに,@var{file}と呼ばれる
ものを作成します.これは,クロスコンパイルのためのlibtoolを作成したり,
同じディレクトリに1つ以上のlibtoolを作成したい場合に便利です.

@item --quiet
@itemx --silent
コンフィグレーションテストの実行時に情報的なメッセージを出力しません.

@item --srcdir=@var{dir}
@var{dir}で@code{config.guess}と@code{config.sub}を探します.

@item --version
@code{ltconfig}のバージョン情報を出力し終了します.

@item --with-gcc
オブジェクトファイルをコンパイルとリンクするために作成される
@code{libtool}を呼び出すとき,GNU Cコンパイラが使用されることを仮定しま
す.

@item --with-gnu-ld
CコンパイラがGNUリンカを使用すると仮定します.

@item --disable-lock
@samp{-c}と@samp{-o}をどちらもサポートしないCコンパイラの場合,適切な並
列コンパイルを確実にするため,ロックを実行しない@code{libtool}を作成しま
す.

@item --cache-file=@var{file}
この@var{file}をいくつかのテストの結果を保存するものとして使用します.こ
れは通常,@code{configure}で使用される@file{config.cache}です.デフォル
トでは,キャッシュファイルは使用しません.
@end table

@var{ltmain}は,基本的なlibtool機能を提供する@code{ltmain.sh}シェルスク
リプトの断片です(@pxref{Distributing}).

@var{host}は標準的なシステム名で,デフォルトで@code{config.guess}の実行
で分かります.

@code{ltconfig}は以下の環境変数も認識します.

@defvar CC
@code{libtool}の生成に使用されるCコンパイラです.これが設定されていない
場合,@code{ltconfig}は@code{gcc}や@code{cc}を探します.
@end defvar

@defvar CFLAGS
標準的なオブジェクトファイルを生成するために使用するコンパイラフラグです.
これが設定されていない場合,そのようなフラグを全く使用しません.それは
@code{ltconfig}の実行テストにのみに効果があり,@code{libtool}の生成には
効果はありません.
@end defvar

@defvar CPPFLAGS
Cプリプロセッサフラグです.これが設定されていない場合,@code{ltconfig}は
そのようなフラグを使用しません.それは@code{ltconfig}の実行テストにのみ
に効果があり,@code{libtool}の生成には効果はありません.
@end defvar

@defvar LD
(生成された@code{libtool}が要求する)使用するシステムリンカです.これが
設定されていない場合,@code{ltconfig}は@var{CC}で使用されるリンカを判定
しようとします.
@end defvar

@defvar LDFLAGS
プログラムのリンク時に@code{ltconfig}が使用するフラグです.これが設定さ
れていない場合,@code{ltconfig}はそのようなフラグを使用しません.それは
@code{ltconfig}の実行テストにのみに効果があり,@code{libtool}の生成には
効果はありません.
@end defvar

@defvar LIBS
プログラムのリンク時に@code{ltconfig}が使用するライブラリです.これが設
定されていない場合,@code{ltconfig}はそのようなフラグを使用しません.そ
れは@code{ltconfig}の実行テストにのみに効果があり,@code{libtool}の生成
には効果はありません.
@end defvar

@defvar NM
@code{nm}を調査するのではなく,使用するプログラムです.
@end defvar

@defvar RANLIB
@code{ranlib}を調査するのではなく,使用するプログラムです.
@end defvar

@defvar LN_S
プログラムのリンクを作成するコマンドで,可能な場合はソフトリンク,それ以
外ではハードリンクです.
@end defvar

@defvar DLLTOOL
@code{dlltool}を調査するのではなく,使用するプログラムです.
Cygwin/MS-Windowsでのみ意味があります.
@end defvar

@defvar OBJDUMP
@code{objdump}を調査するのではなく,使用するプログラムです.
Cygwin/MS-Windowsでのみ意味があります.
@end defvar

@defvar AS
@code{as}を調査するのではなく,使用するプログラムです.Cygwin/MS-Windows
でのみ意味があります.
@end defvar

@node ltconfig example
@subsection @code{ltconfig}の使用

ここに,NetBSD/i386 1.2システムでlibtoolをコンフィグレーションするために
@code{ltconfig}を使用している,単純な例があります.

@example
burger$ @kbd{./ltconfig ltmain.sh}
checking host system type... i386-unknown-netbsd1.2
checking for ranlib... ranlib
checking for gcc... gcc
checking whether we are using GNU C... yes
checking for gcc option to produce PIC... -fPIC -DPIC
checking for gcc option to statically link programs... -static
checking if ld is GNU ld... no
checking if ld supports shared libraries... yes
checking dynamic linker characteristics... netbsd1.2 ld.so
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... yes
creating libtool
burger$
@end example

この例は,(@file{/local/i486-gnu/bin}にコンパイルツールが存在すると仮定
した)i486 GNU/Hurd 0.1システムへのクロスコンパイルで@code{libtool}をコン
フィグレーションする方法を示します.

@example
burger$ export PATH=/local/i486-gnu/bin:$PATH
burger$ ./ltconfig ltmain.sh i486-gnu0.1
checking host system type... i486-unknown-gnu0.1
checking for ranlib... ranlib
checking for gcc... gcc
checking whether we are using GNU C... yes
checking for gcc option to produce PIC... -fPIC -DPIC
checking for gcc option to statically link programs... -static
checking if ld is GNU ld... yes
checking if GNU ld supports shared libraries... yes
checking dynamic linker characteristics... gnu0.1 ld.so
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... yes
creating libtool
burger$
@end example

@node AM_PROG_LIBTOOL
@subsection @code{AM_PROG_LIBTOOL}マクロ

GNU Autoconf(やAutomake)を使用している場合,@code{AM_PROG_LIBTOOL}の呼び
出しを@file{configure.in}に加える必要があります.このマクロは,
@code{configure}スクリプトと@code{ltconfig}の間で,シームレスな統合を提
供します.

@defmac AM_PROG_LIBTOOL
@samp{--enable-shared}と@samp{--disable-shared}フラグに対するサポートを
加えます.パッケージのコンフィグレーションで正しい引数で@code{ltconfig} 
を呼び出してください(@pxref{Invoking ltconfig}).
@footnote{@code{AM_PROG_LIBTOOL}は,@file{Makefile.in}での
@file{Makefile}変数の@code{top_builddir}の定義を要求します.Automakeはこ
れを自動的に行いますが,Autoconfユーザは,構築ディレクトリのトップへの相
対パス(例えば,@file{../..})を設定する必要があります.}

デフォルトで,このマクロは,利用可能な場合は共有ライブラリを開始し,共有
ライブラリと衝突しない場合はスタティックライブラリも可能とします.これら
のデフォルトは,@code{AC_DISABLE_SHARED}や@code{AC_DISABLE_STATIC}マクロ
のどちらかで修正可能です.

@example
# Turn off shared libraries during beta-testing, since they
# make the build process take too long.
AC_DISABLE_SHARED
AM_PROG_LIBTOOL
@end example

ユーザは,パッケージ名を元に構築される,共有またはスタティックライブラリ
を選択するため,@samp{--enable-shared}と@samp{--enable-static}コンフィグ
レーションフラグで指定を修正できます.例えば,共有する@samp{bfd}と
@samp{gdb}ライブラリを構築し,@samp{libg++}を共有にしないため,以下の
@code{configure}スクリプトの実行で,3つすべて可能となります.

@example
trick$ ./configure --enable-shared=bfd,gdb
@end example

一般的に,@samp{--enable-shared=@var{pkgs}}の指定は,カンマで分けられた
@var{pkgs}リストに名前があるすべてのパッケージを@samp{--enable-shared}で,
それ以外のすべてのパッケージを@samp{--disable-shared}でコンフィグレーショ
ンすること同じです.@samp{--enable-static=@var{pkgs}}フラグは,同様に動
作しますが,その場合は@samp{--enable-static}と@samp{--disable-static}を
使用します.同様に,@samp{--enable-fast-install=@var{pkgs}}フラグは適用
され,それは,@samp{--enable-fast-install}と
@samp{--disable-fast-install}を使用します.

パッケージ名@samp{default}は,@code{PACKAGE}環境変数に名前が設定されてい
ない,あらゆるパッケージに一致します.

このマクロは,シェル変数@var{LIBTOOL_DEPS}も設定し,それで,libtoolスク
リプトが時代遅れになった場合の自動的な更新に使用できるようになります.そ
うするために@file{configure.in}に以下を加えてください.

@example
AM_PROG_LIBTOOL
AC_SUBST(LIBTOOL_DEPS)
@end example

そして,@file{Makefile.in}や@file{Makefile.am}に,以下を加えてください.

@example
LIBTOOL_DEPS = @@LIBTOOL_DEPS@@
libtool: $(LIBTOOL_DEPS)
        $(SHELL) ./config.status --recheck
@end example

GNU automakeを使用してる場合,automakeが面倒をみるので,指示の省略が可能
です.@file{libtool}での依存性を明確に作成する必要があります.
@end defmac

@defmac AC_LIBTOOL_DLOPEN
dlopenサポートの調査を可能にします.パッケージで@samp{-dlopen}と
@samp{-dlpreopen}フラグを使用する場合,このマクロ使用すべきで,そうしな
い場合,libtoolはシステムがdlopenをサポートしていないと仮定します.マク
ロは@code{AM_PROG_LIBTOOL}の@strong{前で}呼び出す必要があります.
@end defmac

@defmac AC_LIBTOOL_WIN32_DLL
このマクロは,win32プラットフォームでクリーンなdllを構築するために移植す
る場合,使用する必要があります.通常,これは,あらゆるライブラリデータ項
目を@code{__declspec(dllexport)}でエクスポートし,
@code{__declspec(dllimport)}でインポートすることを意味します.このマクロ
が使用されていない場合,libtoolはパッケージライブラリがクリーンなdllでは
なく,win32ホストでのスタティックライブラリのみを構築すると仮定します.

@code{AM_PROG_LIBTOOL}は,このマクロの@strong{後で}呼び出す必要があり,
パッケージの@code{Makefile}でのリンクモードでの準備として,
@code{libtool}に@samp{-no-undefined}を渡させる必要があります.通常,
@samp{-no-undefined}を渡すことは,すべてのライブラリシンボルが,リンク時
には@strong{本当に}定義されていることを意味します.
@end defmac

@defmac AC_DISABLE_FAST_INSTALL
@code{AM_PROG_LIBTOOL}のデフォルトの動作を,テストインストールに対する最
適化を不可能に変更します.ユーザはこのデフォルトを,プラットフォームのサ
ポートに依存して,@samp{--enable-fast-install}を指定することで優先させる
ことができます.
@end defmac

@defmac AC_DISABLE_SHARED
@defmacx AM_DISABLE_SHARED
@code{AM_PROG_LIBTOOL}のデフォルトの動作を,共有ライブラリを利用不可能に
変更します.ユーザはこのデフォルトを,@samp{--enable-shared}を指定するこ
とで優先させることができます.
@end defmac

@defmac AC_DISABLE_STATIC
@defmacx AM_DISABLE_STATIC
@code{AM_PROG_LIBTOOL}のデフォルトの動作を,スタティックライブラリを利用
不可能に変更します.ユーザはこのデフォルトを,@samp{--enable-static}を指
定することで優先させることができます.
@end defmac

@pindex aclocal
@code{libtoolize}プログラムを呼び出すとき(@pxref{Invoking libtoolize}),
それは@code{AM_PROG_LIBTOOL}の定義が見つかる場所を伝えます.Automakeを使
用している場合,@code{aclocal}プログラムは自動的に,@code{configure}スク
リプトに@code{AM_PROG_LIBTOOL}サポートを加えます.

それにもかかわらず,@file{acinclude.m4}に@file{libtool.m4}のコピーを含め
ることは賢明で,そのため,@file{aclocal.m4}と@file{configure}がとある理
由で再構築された場合も,適切なlibtoolマクロが使用されます.代わりに,ユー
ザが@file{libtool.m4}の互換バージョンをインストールしていて,
@code{aclocal}にアクセス可能なことを期待します.これは,バージョンが一致
しない場合,不運なエラーを導くかもしれません.


@node Distributing
@section パッケージにlibtoolを含める

libtoolを使用するため,パッケージに以下のファイルを含める必要があります.

@table @file
@item config.guess
@pindex config.guess
標準的なシステム名の判別を試みます.

@item config.sub
@pindex config.sub
標準的なシステム名の評価のサブルーチンスクリプトです.

@item ltconfig
システムに与えるlibtoolスクリプトを生成します.

@item ltmain.sh
@pindex ltmain.sh
基本的なlibtool機能を実装する一般的なスクリプトです.
@end table

libtoolスクリプト自身はパッケージに含まないことに注意してください.
@xref{Configuring}.

手動でこれらのファイルをパッケージにコピーするより,@code{libtoolize}プ
ログラムを使用した方がよいでしょう.

@menu
* Invoking libtoolize::         @code{libtoolize} command line options.
* Autoconf .o macros::          Autoconf macros that set object file names.
@end menu

@node Invoking libtoolize
@subsection @code{libtoolize}の呼び出し
@pindex libtoolize
@cindex libtoolize command options
@cindex command options, libtoolize
@cindex options, libtoolize command

@code{libtoolize}プログラムは,libtoolサポートをパッケージに追加する標準
的な方法を提供します.将来は,より良い調査の使用法や,より簡単にlibtool 
を作成する特徴を実装するかもしれません.

@code{libtoolize}プログラムは以下の構文です.

@example
libtoolize [@var{option}]@dots{}
@end example

@noindent
そして,以下のオプションを受け入れます.

@table @samp
@item --automake
静かに動作し,libtoolがサポートされているAutomakeを仮定します.

@samp{libtoolize --automake}は,@code{AM_PROG_LIBTOOL}が
@file{configure.in}にあるとき,Automakeがlibtoolファイルをパッケージに追
加するために使用します.

@item --copy
@itemx -c
libtoolデータディレクトリから,シンボリックリンクを作成するのではなく,
ファイルをコピーします.

@item --debug
シェルスクリプトの実行の追跡を,標準出力にダンプします.これは大量の出力
を生成するため,@code{less}(や@code{more})にパイプしたり,ファイルにリダ
イレクトしたいかもしれません.

@item --dry-run
@itemx -n
ファイルシステムを変更するコマンドは実行せず,それらを出力するだけです.

@item --force
@itemx -f
既存のlibtoolファイルを置換します.デフォルトで,@code{libtoolize}は既存
のファイルを上書きしません.

@item --help
へルプメッセージを出力し終了します.

@item --ltdl
パッケージのサブディレクトリに,libltdlをインストールします.

@item --ltdl-tar
ファイルlibltdl.tar.gzをパッケージに追加します.

@item --version
@code{libtoolize}のバージョン情報を出力し終了します.
@end table

@findex AC_CONFIG_AUX_DIR
@code{libtoolize}が,パッケージの@file{configure.in}で,明確な
@code{AC_CONFIG_AUX_DIR}の呼び出しを検出した場合(@pxref{Input, , The
Autoconf Manual, autoconf, The Autoconf Manual}),指定されたディレクトリ
にファイルを配置します.

@code{libtoolize}は,パッケージにlibtoolサポートを加えるヒントも同様に表
示します.


@node Autoconf .o macros
@subsection Autoconfの@samp{.o}マクロ

Autoconfパッケージは,テストを実行するいくつかのマクロをもたらし,それは,
オブジェクトファイル名に対応して変数を設定します.libtoolオブジェクトに
対応する名前を使用する必要があるときもあります.

ここにlibtoolオブジェクトがリストアップする変数名があります.

@defvar LTALLOCA
@findex AC_FUNC_ALLOCA
@code{AC_FUNC_ALLOCA}で置換されます(@pxref{Particular Functions,
Particular Function Checks, The Autoconf Manual, autoconf, The Autoconf
Manual}).空,または@samp{alloca.lo}を含みます.
@end defvar

@defvar LTLIBOBJS
@findex AC_REPLACE_FUNCS
@code{AC_REPLACE_FUNCS}とその他の関数で置換されます(@pxref{Generic
Functions, Generic Function Checks, The Autoconf Manual, autoconf, The
Autoconf Manual}).
@end defvar

残念ながら,ほとんど最近のバージョンのAutoconf(これを書いている時期は,
2.12)は,libtoolでこれらの変数を提供する方法が全くありません.そのため,
それに依存して,パッケージの@file{configure.in}で@code{AC_OUTPUT}を呼び
出す前に,以下のコードの実装を使用してください.

@example
LTLIBOBJS=`echo "$LIBOBJS" | sed 's/\.o/.lo/g'`
AC_SUBST(LTLIBOBJS)
LTALLOCA=`echo "$ALLOCA" | sed 's/\.o/.lo/g'`
AC_SUBST(LTALLOCA)
AC_OUTPUT(@dots{})
@end example

@node Static-only libraries
@section スタティックのみのライブラリ
@cindex debugging libraries
@cindex developing libraries
@cindex double-compilation, avoiding
@cindex avoiding shared libraries
@cindex eliding shared libraries
@cindex using shared libraries, not
@cindex shared libraries, not using
@cindex time, saving
@cindex saving time

パッケージを開発しているとき,パッケージを@samp{--disable-shared}フラグ
でコンフィグレーションしたり,@code{AM_DISABLE_SHARED} Autoconfマクロ
(@pxref{AM_PROG_LIBTOOL, , The @code{AM_PROG_LIBTOOL} macro})を使用して,
@code{AM_PROG_LIBTOOL}のデフォルトに優先することに価値があることもよくあ
ります.これは,libtoolが共有ライブラリを構築することを避け,それには,
いくつかの利点があります.

@itemize @bullet
@item
2回目のコンパイルを速くし,開発サイクルを高速にします.

@item
共有ライブラリによって加えられる複雑さの詳細が不要なので,デバッグがより
簡単になります.

@item
スタティックのみのプラットフォームでのlibtoolの動作方法が分かります.
@end itemize

パッケージの@file{README}に,他の開発者に@samp{--disable-shared}で時間を
稼げることを知らせるため,ちょっとした注意を書きたいかもしれません.以下
の例の注意は,GIMP@footnote{思い切りが良くない人のためのGNU Image
Manipulation Programです.@url{http://www.gimp.org/}を参照してください.} 
配布物の@file{README}から持ってきました.

@example
The GIMP uses GNU Libtool in order to build shared libraries on a
variety of systems. While this is very nice for making usable
binaries, it can be a pain when trying to debug a program. For that
reason, compilation of shared libraries can be turned off by
specifying the @samp{--disable-shared} option to @file{configure}.
@end example


@node Versioning
@chapter ライブラリインターフェースのバージョン
@cindex dynamic dependencies
@cindex dependency versioning
@cindex shared library versions

共有ライブラリで導入された発行物で,最も難しいものは,実行時の依存の作成
と解決です.プログラムとライブラリの依存は,@code{sed}のような単一の名前
の用語で,よく記述されます.そのため``libtoolはsedに依存する''と告げ,そ
れで十分目的を果たせます.

しかし,規則的にインターフェースが変更されるとき,我々はより具体的に告げ
る必要があります.``Gnus 5.1はEmacs 19.28以上を要求する.''ここでは,名
前からなるインターフェースの記述と``バージョンナンバー''です.

種類の説明はいくつかの目的において十分でないことすらあります.Emacs 20で
変更された場合,Gnus 5.1を破壊するのに十分ではないでしょうか?

同じ問題は,共有ライブラリでも存在します.我々は,プログラムが必要として
いるインターフェースを提供するライブラリのみとリンクされることを,ダイナ
ミックリンカが保証できるように,プログラムが依存する共有ライブラリを記述
するために,通常のバージョン管理システムが必要です.

@menu
* Interfaces::                  What are library interfaces?
* Libtool versioning::          Libtool's versioning system.
* Updating version info::       Changing version information before releases.
* Release numbers::             Breaking binary compatibility for aesthetics.
@end menu

@node Interfaces
@section ライブラリインターフェースとは?
@cindex library interfaces

ライブラリのインターフェースは,以下の何か(またはそれ以上)でしょう.

@itemize @bullet
@item
大域的変数:名前と型

@item
大域的関数:引数の型と数,戻り値の型,関数名

@item
標準入力,標準出力,標準エラー,ファイル形式

@item
ソケット,パイプ,プロセス間通信のプロトコル書式
@end itemize

静的な関数は,ライブラリのユーザが直接利用可能なので,インターフェースに
数えられないことに注意してください.


@node Libtool versioning
@section libtoolのバージョン管理システム
@cindex libtool library versions
@cindex formal versioning
@cindex versioning, formal

libtoolは独自の形式的なバージョン管理システムがあります.それは,あまり
柔軟ではありませんが,強力なバージョン管理システムで確に最も単純です.

ライブラリとは,整数で任意に表示できるインターフェースのいくつかの組を
エクスポートするものだと考えて下さい.プログラムがライブラリとリンクされ
るとき,これらのインターフェースのサブセットを利用するかもしれません.

プログラムが使用するインターフェースのlibtoolの記述は単純です.それは,
結果のバイナリにある最大と最小のインターフェースの番号を符号化します
(@var{first-interface}, @var{last-interface}).

ダイナミックリンカは,ライブラリが@var{first-interface}と
@var{last-interface}の間の@emph{すべての}インターフェースの番号をサポー
トする場合,プログラムがライブラリとリンク可能なことを保証します.

libtoolの移植性の要求が,実際に必要と言うよりは厳密なので,問題を生じる
可能性があることに注意してください.

さて,@file{libhello}がインターフェースの5,16,17,18,と19をサポートし,
libtoolは@file{libhello}を@file{test}にリンクするとき使用されると仮定し
ます.

libtoolは@file{test}に数字5と19を符号化し,ダイナミックリンカは,5と19の
間の@emph{すべての}インターフェースをサポートしているライブラリのみと,
@file{test}をリンクします.そのため,ダイナミックリンカは@file{libhello}
と@file{test}をリンクすることを拒否します!

この問題を排除するために,libtoolはライブラリが連続したインターフェース
番号を宣言することのみ可能としています.そのため,@file{libhello}は,16 
から19までのインターフェースをサポートすることを宣言するのが精一杯です.
そして,ダイナミックリンカは,@file{libhello}を@file{test}とリンクします.

そのため,libtoolライブラリバージョンは,3つの整数で宣言されます.

@table @var
@item current
このライブラリで実装されている,最も新しいインターフェース番号.

@item revision
@var{current}のインターフェースの実装番号.

@item age
このライブラリで実装されている,最新と最古のインターフェースの違い.言い
換えると,ライブラリは,@code{@var{current} - @var{age}}から
@code{@var{current}}までの番号の範囲で,すべてのインターフェース番号を実
装しています.
@end table

2つのライブラリが,個別の@var{current}と@var{age}を持つ場合,ダイナミッ
クリンカは,より大きい@var{revision}番号を選択します.


@node Updating version info
@section ライブラリバージョン情報の更新

libtoolのバージョン管理システムを使用したい場合,リンクモード
(@pxref{Link mode})の時に,@samp{-version-info}フラグを使用して,libtool
にバージョン情報を指定する必要があります.

このフラグは,@samp{@var{current}[:@var{revision}[:@var{age}]]}の形式の
引数を受け入れます.そして,@samp{-version-info 3:12:1}を渡すと,
@var{current}を3,@var{revision}を12,そして@var{age}を1に設定します.

@var{revision}や@var{age}が省略された場合,デフォルトは0になります.また,
@var{age}は@var{current}インターフェース番号以下にする必要があることに注
意してください.

ここに,ライブラリバージョン情報を更新する助けとなる規則の集合があります.

@enumerate 1
@item
バージョン情報は,それぞれのlibtoolライブラリに対し@samp{0:0:0}で始めて
ください.

@item
ソフトウェアの一般へのリリースの直前にのみ,バージョン情報を更新してくだ
さい.より頻繁な更新は不要で,現在のインターフェース番号が速くなることを
保証するだけです.

@item
前回の更新から,ライブラりソースコードが完全に変更された場合,
@var{revision}を増加してください(@samp{@var{c}:@var{r}:@var{a}}は
@samp{@var{c}:@math{r+1}:@var{a}}となります).

@item
前回の更新から,インターフェースが加えられた,削除された,または変更され
た場合,@var{current}を増加し,@var{revision}を0に設定してください.

@item
前回の一般へのリリースから,あるインターフェースが加えられた場合,
@var{age}を増加してください.

@item
前回の一般へのリリースから,あるインターフェースが削除された場合,
@var{age}を0に設定してください.
@end enumerate

パッケージのリリース番号に対応するように,インターフェース番号を設定する
試みは@strong{@emph{決して}}しないでください.これは,ライブラリバージョ
ンの目的の誤解を促進する悪習にすぎません.その代わり,@samp{-release}
フラグ(@pxref{Release numbers})を使用しますが,パッケージが他のリリース
とバイナリ互換でないことを警告されます.


@node Release numbers
@section リリース情報の管理

プログラムをライブラリにリンクしたいユーザに明確になるように,パッケージ
リリース名を共有ライブラリに符号化したいこともよくあります.この便利さは,
特にGNU/Linuxで使用されます.

@example
trick$ @kbd{ls /usr/lib/libbfd*}
/usr/lib/libbfd.a	    /usr/lib/libbfd.so.2.7.0.2
/usr/lib/libbfd.so
trick$
@end example

@samp{trick}として,@file{/usr/lib/libbfd.so}は@file{libbfd.so.2.7.0.2} 
へのシンボリックリンクで,それは@samp{binutils-2.7.0.2}の一部として配布
されています.

ライブラリインターフェースは,リリース番号のように,滅多に同時に変更され
す,ライブラリ接尾子はすべてのプラットフォームを跨り,すべて同じではない
ので,残念ながらこの便利さはlibtoolのライブラリバージョンの情報の考えと
直接衝突します.

そのため,両方の見方に適応するため,@samp{-version-info}を使用したくない
ライブラリに対し,リリース情報を設定するにあたり,@samp{-release}フラグ
を使用することができます.@file{libbfd}の例では,libtoolが使用する次のリ
リースは,@samp{-release 2.9.0}で構築されるべきで,それは,GNU/Linuxで,
以下のファイルを生成します.

@example
trick$ @kbd{ls /usr/lib/libbfd*}
/usr/lib/libbfd-2.9.0.so     /usr/lib/libbfd.a
/usr/lib/libbfd.so
trick$
@end example

この場合,@file{/usr/lib/libbfd.so}は@file{libbfd-2.9.0.so}へのシンボリッ
クリンクです.これは@samp{binutils-2.9.0}を扱っているユーザにとって,バー
ジョン情報のlibtoolの考えに妥協することなく,明白になります.

このオプションはライブラリ名を編集することに注意し,過去のライブラリリリー
スとのバイナリ互換を壊したくない場合は使用しないでください.一般的に,パッ
ケージの内部ライブラリや,大変頻繁に変更されるインターフェースを持つ物に
対してのみ@samp{-release}を使用してください.


@node Library tips
@chapter インターフェースデザインのヒント
@cindex library interfaces, design
@cindex design of library interfaces

良いライブラリインターフェースと書くことは,多くの経験とライブラリが解決
する問題への完全な理解が必要です.

良いインターフェースを設計した場合,頻繁に変更する必要がなく,ドキュメン
トを更新し続ける必要がなく,ユーザはライブラリの使用方法を何度も学習する
必要がありません.

ここにライブラリインターフェースの設計に関するヒントの短いリストがあり,
それは仕事上で役立つでしょう.

@table @asis
@item 計画前
エントリポイントを頻繁に削除する必要がないように,すべてのインターフェー
スを本当に最小限にするように試みてください.

@item インターフェースの変更を避ける
@cindex renaming interface functions
エントリポイントの再設計と変更を地獄のように繰り返すのが好きな人もいます
(注意:関数の@emph{名前変更}はエントリポイントの変更と考えられます).イ
ンターフェースを再設計する必要がある場合,ユーザが既存のコードを書き換え
る必要がないように,互換機能を残すことを試みてください.

@item 不透明なデータ型の使用
@cindex opaque data types
ライブラリユーザがアクセスするデータ型の定義は,少ないければ少ないほど良
いでしょう.可能な場合,一般的な(内部データにキャスト可能な)ポインタを受
け入れる関数を設計し,ライブラリユーザが直接データを操作するのを許可する
のではなく,アクセスする関数を提供してください.そうすることで,インター
フェースを変更せずに,データ構造を変更することが自由になります.

これは,本質的にオブジェクト指向のシステムで抽象的なデータ型と継承を使用
するのと同じです.

@item ヘッダファイルの使用
@cindex header files
ライブラリのグローバル関数と変数のそれぞれのドキュメントをヘッダファイル
に注意して書いていて,ライブラリソースファイルに含めている場合,コンパイ
ラは偶然にインターフェースの変更の有無を知らせるでしょう(@pxref{C header
files}).

@item 可能な場合は@code{static}キーワード(または等価物)の使用
@cindex global functions
ライブラリが持つグローバル関数は,減らせば減らすほど,より柔軟に変更でき
ます.スタティック関数と変数は,形式を変更したいとき変更できます@dots{} 
ユーザはそれらにアクセスできず,そのためインターフェースは変更されません.
@end table

@menu
* C header files::              How to write portable include files.
@end menu

@node C header files
@section Cヘッダファイルを書く
@cindex portable C headers
@cindex C header files, portable
@cindex include files, portable

移植性の高いCヘッダファイルを書くことは難しく,それは異なる形式のコンパ
イラで読まれる可能性があるためです.

@table @asis
@item C++コンパイラ
C++コンパイラは,Cより強固に形式化されているため,完全なプロトタイプで宣
言された関数を要求します.C関数と変数は,名前がおかしくならないように,
@code{extern "C"}ディレクティブで宣言する必要があります.libtoolでC++の
使用に関連したその他の問題は,@xref{C++ libraries}.

@item ANSI Cコンパイラ
ANSI Cコンパイラは,C++コンパイラほど厳密ではありませんが,関数のプロト
タイプは,ヘッダファイルを@code{#include}したときの不必要な警告を避ける
ため,行う方が良いでしょう.

@item 非ANSI Cコンパイラ
Non-ANSIコンパイラは,関数がプロトタイプされている場合,エラーを報告しま
す.
@end table

これらの複雑さは,上記それぞれのコンパイラを利用可能にするため,ライブラ
リインファーフェースヘッダで,いくつかのCプリプロセッサの魔法を使用する
必要があることを意味します.

libtool配布物の@file{demo}サブディレクトリの@file{foo.h}は,安全にシステ
ムディレクトリにインストール可能な,ヘッダファイルの書き方の例を提供しま
す.

ここに,そのファイルの関連する部分があります.

@example
/* __BEGIN_DECLS should be used at the beginning of your declarations,
   so that C++ compilers don't mangle their names.  Use __END_DECLS at
   the end of C declarations. */
#undef __BEGIN_DECLS
#undef __END_DECLS
#ifdef __cplusplus
# define __BEGIN_DECLS extern "C" @{
# define __END_DECLS @}
#else
# define __BEGIN_DECLS /* empty */
# define __END_DECLS /* empty */
#endif

/* __P is a macro used to wrap function prototypes, so that compilers
   that don't understand ANSI C prototypes still work, and ANSI C
   compilers can issue warnings about type mismatches. */
#undef __P
#if defined (__STDC__) || defined (_AIX) \
        || (defined (__mips) && defined (_SYSTYPE_SVR4)) \
        || defined(WIN32) || defined(__cplusplus)
# define __P(protos) protos
#else
# define __P(protos) ()
#endif
@end example

これらのマクロは,以下のように@file{foo.h}で使用されます.

@example
#ifndef _FOO_H_
#define _FOO_H_ 1

/* The above macro definitions. */
@dots{}

__BEGIN_DECLS
int foo __P((void));
int hello __P((void));
__END_DECLS

#endif /* !_FOO_H_ */
@end example

@file{#ifndef _FOO_H_}が,@file{foo.h}の本体を,与えられたコンパイルで一
回以上読み込むことを避けることに注意してください.

@code{__P},@code{__BEGIN_DECLS},そして@code{__END_DECLS}の定義は独自の
ヘッダに自由にコピーしてください.そして,C++,ANSI,そしてnon-ANSIに対
し有効なヘッダファイルを作成するために使用可能です.

移植可能なコードをネイティブに書かないでください,上記のヒントに続けるこ
とで,最も明白な問題を無くすことに役立ちますが,明らかに別の微妙な問題が
あります.以下の問題に対処する必要があるかもしれません.

@itemize @bullet
@item
Pre-ANSIコンパイラは,一般的なポインタ型@code{void *}を常にサポートする
わけではなく,そこでは@code{char *}を使用する必要があります.

@item
@code{const}と@code{signed}キーワードは,サポートされていないコンパイラ
もあり,特にpre-ANSIコンパイラがあげられます.

@item
@code{long double}型は,多くのコンパイラでサポートされていません.
@end itemize


@node Inter-library dependencies
@chapter ライブラリ内部の依存
@cindex dependencies between libraries
@cindex inter-library dependencies

定義では,すべての共有ライブラリシステムは,シンボル解決が実行時まで延期
されるので,実行形式をライブラリに依存させる方法を提供します.

@dfn{ライブラリ内部の依存性}は,他のライブラリに依存するライブラリにあり
ます.例えば,libtoolライブラリ@file{libhello}が@code{cos}関数を使用する
場合,それは@file{libm}に対するライブラリ内部の依存性があり,数学ライブ
ラリが@code{cos}を実装しています.

共有ライブラリシステムには,内部で一貫した方法で,この機能を提供するもの
もあります.これらのシステムは,潜在的に無限長の依存性の連鎖を認めます.

しかし,ほとんどの共有ライブラリのシステムは,単一レベルの依存のみを認め
るという制限があります.これらのシステムでは,プログラムは共有ライブラリ
に依存しますが,共有ライブラリは他の共有ライブラリに依存しません.

あらゆるイベントで,ライブラリ内部の依存性を宣言するため,libtoolは単純
なメカニズムを提供します.独自のライブラリに依存するすべてのライブラリ
@file{lib@var{name}}に対しライブラリを作成するとき,対応する
@code{-l@var{name}}オプションをリンク行に単純に加えます.@footnote{残念
ながら,libtoolのバージョン@value{VERSION}では,インストールされていない
libtoolライブラリ上で,ライブラリ内部の依存性を指定する方法はありません.
libtool 1.4はこの特徴をサポートするでしょう.}@file{libm}に依存する
@file{libhello}の例を構築してみます.

@example
burger$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \
                -rpath /usr/local/lib -lm}
burger$
@end example

プログラムを@file{libhello}に対しリンクするとき,@samp{-l}オプションを再
び指定する必要はありません.すべて必要なライブラリが見つかることを保証す
るため,libtoolはそれを行います.この制約は,静的なライブラリシステムと,
単純な動的ライブラリシステムとの互換性を保つために必要です.

AIXのように,この柔軟性さえ許可されないプラットフォームもあります.共有
ライブラリを構築するため,それは完全に自己内蔵型である必要があり(すなわ
ち,@samp{.lo}ファイルや@samp{-l}で指定されたライブラリでシンボルが見つ
かるもののみを参照する),@var{-no-undefined}フラグを指定する必要がありま
す.デフォルトで,libtoolはこの種のプラットフォームではスタティックライ
ブラリのみを構築します.

1.2以前のlibtoolのリリースのコードにおける,単純な考えのライブラリ内部の
依存性の追跡は,ライブラリを他のライブラリとリンク可能なときが明白でない
ため不可能で,複雑な異常終了が発生します.この概念のより複雑な実装は,リ
リース1.3の前に再導入されましたが,libtoolがサポートするすべてのプラット
フォームに移植されませんでした.デフォルトで,保守的な動作は,ライブラリ
が他のライブラリとリンクすることを避け,プログラムがリンクされるときのみ
に,その内部依存性が導入されます.


@node Dlopened modules
@chapter dlopenモジュール
@findex dlopen
@findex dlsym
@findex dlclose
@findex shl_load
@cindex dynamic linking, applications
@cindex dlopening modules
@cindex modules, dynamic
@cindex application-level dynamic linking

@dfn{ダイナミックリンク}の議論では,用語が2つの異なる概念の言及で使用さ
れるので,混乱することがあります.

@enumerate 1
@item
共有ライブラリに対しプログラムをコンパイルとリンクし,それは,ダイナミッ
クリンカにより実行時に自動的に解決される.この処理では,ダイナミックリン
クはアプリケーション透過です.

@item
アプリケーションの,@code{dlopen}@footnote{HP-UXでは異なり,
@code{shl_load}という名の関数が使用されます.}のような関数の呼び出しで,
それは,ユーザが指定したモジュールを実行時に任意にロードします.この形式
のダイナミックリンクは,アプリケーションで明示的に制御されます.
@end enumerate

混乱を軽減するため,このマニュアルは2番目の形式のダイナミックリンクを
@dfn{dlopen}モジュールとして言及します.

dlopenモジュールの主な利点は,インタプリタ言語を使用する代わりに,プログ
ラムを拡張するためのコンパイルされたオブジェクトコードにアクセスする能力
です.実際,dlopenは,言語を拡張する効果的な方法を提供するため,インタプ
リタ言語でよく使用されます.

バージョン@value{VERSION}の現在は,libtoolはdlopenされるモジュールのサポー
トを提供します.しかし,パッケージがそのようなサポートを行うことを,
@file{configure.in}で,マクロ@samp{AC_LIBTOOL_DLOPEN}を使用して指示した
方が良いでしょう.このマクロが使用されない(または@samp{AM_PROG_LIBTOOL} 
の@emph{後で}使用される)場合,libtoolはdlopenメカニズムが利用不可能と仮
定し,シミュレーションを試みます.

この章ではdlopenでアクセス可能なモジュールを生成するため,dlopenアプリケー
ション開発者がlibtoolを使用する方法を議論します.

@menu
* Building modules::            Creating dlopenable objects and libraries.
* Dlpreopening::                Dlopening that works on static platforms.
* Finding the dlname::          Choosing the right file to @code{dlopen}.
* Dlopen issues::               Unresolved problems that need your attention.
@end menu

@node Building modules
@section dlopenのためのモジュールの構築

オペレーティングシステムには,プログラムシンボルを@code{dlsym}(またはそ
の透過)関数を用いて動的に解決するために,特定のもので指定する必要がある
ものもあります.

libtoolは,@samp{-export-dynamic}と@samp{-module}リンクフラグを提供し
(@pxref{Link mode}),それはこの宣言を行います.他のモジュールやdlopenさ
れているライブラリをdlopenするアプリケーションプログラムをリンクする場合,
これらのフラグを使用する必要があります.

例えば,後でアプリケーションにdlopenされる共有ライブラリ@file{libhello}
を構築したい場合,他のリンクオプションに@samp{-module}を加えます.

@example
burger$ @kbd{libtool gcc -module -o libhello.la foo.lo \
                hello.lo -rpath /usr/local/lib -lm}
burger$
@end example

@emph{実行形式}からのシンボルが,dlopenしたいライブラリの未解決の参照を
満足させる必要がある場合,フラグ@samp{-export-dynamic}を使用する必要があ
ります.dlopenを呼び出す実行形式をリンクするとき,@samp{-export-dynamic} 
を使用してください.

@example
burger$ @kbd{libtool gcc -export-dynamic -o hell-dlopener main.o}
burger$
@end example


@node Dlpreopening
@section dlopen

libtoolは,dlopenするlibtoolオブジェクトとlibtoolライブラリファイルに対
し,@emph{たとえ@code{dlopen}と@code{dlsym}関数が無いプラットフォームで
も}そのシンボルが解決できるように,特別のサポートを提供します.

``laziness''の増加順にプログラムにコードをロードする,以下の別の方法を考
慮します.

@enumerate 1
@item
参照するしないに関わらない,実行形式の一部となるオブジェクトファイルへの
リンクです.オブジェクトファイルが見つからない場合,リンカは実行形式の作
成を停止します.

@item
上記のオブジェクトファイルでの未定義の参照を満足させるために,リンク時に
検索されるようにするための,リンカに対するスタティックライブラリの宣言で
す.スタティックライブラリが見つからない場合,リンカは実行形式の作成を停
止します.

@item
上記のファイルでの未定義の参照を満足させるために,実行時に検索されるよう
にするための,実行時リンクの共有ライブラリの宣言です.共有ライブラリが見
つからない場合,ダイナミックリンカは実行形式の作成を停止します.

@item
アプリケーション自身が解決することができるように,参照を動的解決する
dlopenモジュールです.モジュールを開くときエラーが発生したり,モジュール
が見つからない場合,アプリケーションは壊れることなく回復します.
@end enumerate

libtoolは,コンパイル時にオブジェクトファイルをプログラムにリンクし,プ
ログラムのシンボルテーブルを表現するデータ構造を作成することで,スタティッ
クなプラットフォームで@samp{-dlopen}オプションをエミュレートします.

この特徴を使用するため,プログラムのリンク時(@pxref{Link mode})に
@samp{-dlopen}や@samp{-dlpreopen}フラグを使用することで,アプリケーショ
ンでdlopenしたいオブジェクトを宣言する必要があります.

@deftypefn {Structure} {struct} lt_dlsymlist @{ @w{const char *@var{name};} @w{lt_ptr_t @var{address};} @}
@var{name}属性は,@code{"fprintf"}のような,シンボル名のNULLで終わる文字
列です.@var{address}属性は,@code{&fprintf}のような対応するオブジェクト
への一般的なポインタです.
@end deftypefn

@deftypevar {const lt_dlsymlist *} lt_preloaded_symbols
@var{lt_symbol}構造体の配列で,プログラムにリンクされる,プリロードされ
ているすべてのシンボルを表現します.それぞれの@samp{-dlpreloaded}ファイ
ルに対し,ファイルの@var{name}を用いた要素と,@code{0}の@var{address}が
あり,このファイルからエクスポートされるすべてのシンボルが続きます.実行
形式自身に対し,特別の名前@@PROGRAM@@が使用されます.最後の要素は,
@var{name}と@code{0}の@var{address}を持ちます.
@end deftypevar

ドル記号のような,ANSI Cでは有効ではない識別子を許可するコンパイラもあり
ます.libtoolはANSI Cで有効なシンボル(最初がASCII文字またはアンダースコ
アで,0以上のASCII文字,数字,そしてアンダースコアが続くもの)のみ認識す
るので,非ASCIIシンボルは@var{lt_preloaded_symbols}に出現しません.


@node Finding the dlname
@section dlopenで正しい名前の検索
@cindex names of dynamic modules
@cindex dynamic modules, names

@samp{-module}を用いてライブラリがリンクされた後,dlopen可能になります.
残念ながら ライブラリ名が変更されるため,パッケージでdlopenの正しいファ
イルを決定する必要があります.

最も率直で柔軟な実装は,インストールされた@samp{.la}ファイルを探し,以下
の行を検索することで実行時に決定することです.

@example
# The name that we can @code{dlopen}.
dlname='@var{dlname}'
@end example

@var{dlname}が空の場合,ライブラリはdlopenされません.それ以外では,それ
でライブラリのdlnameを与えます.そのため,ライブラリが
@file{/usr/local/lib/libhello.la}にインストールされていて,@var{dlname}
が@file{libhello.so.3}の場合,@file{/usr/local/lib/libhello.so.3}が
dlopenされます.

プログラムがこのアプローチを行っている場合,ライブラリが最終的にインストー
ルされるディレクトリと同じように,@code{LD_LIBRARY_PATH}@footnote{AIXで
の@code{LIBPATH}とHP-UXでの@code{SHLIB_PATH}です.}環境変数でリストアッ
プされているディレクトリで検索します.この変数(または同等物)を検索するこ
とで,インストール前でも,プログラムがlibtoolを使用してリンクし提供され
ているdlopenモジュールを見つけることを保証します.


@node Dlopen issues
@section 未解決のdlopenの問題
@cindex pitfalls with dlopen
@cindex dlopening, pitfalls
@cindex trouble with dlopen

以下の問題は,libtoolのdlopenサポートを使用しても解決しません.

@itemize @bullet
@item
dlopen関数は一般に,共有ライブラリプラットフォームでのみ利用可能です.パッ
ケージをスタティックなプラットフォームに移植したい場合,libltdl
(@pxref{Using libltdl})を使用する,または,代わりとなる独自のdlopenダイ
ナミックコードを開発する必要があります.最も妥当な解決方法は,
@code{dlopen}ファミリーのラッパー関数を書くことを必要とし,それは,与え
られたプラットフォームでdlopenがサポートされていないまたは利用不可能なと
きの,パッケージ特有ののトリックです.

@item
関数の@code{dlopen}ファミリーの実装には大きな違いがあります.同じ関数名
を用いないプラットフォーム(特にHP-UXでは@code{shl_load}ファミリーを用い
ます)さえ存在します.

@item
アプリケーション開発者は,@code{dlopen}に渡す正しいモジュール名を発見す
るために,カスタムの検索関数を書く必要があります.
@end itemize

@node Using libltdl
@chapter libltdlの使用
@findex libltdl
@findex dlopen
@findex dlsym
@findex dlclose
@findex dlerror
@findex shl_load
@cindex dynamic linking, applications
@cindex dlopening modules
@cindex modules, dynamic
@cindex application-level dynamic linking

libtoolは,@file{libltdl}と呼ばれる小さなライブラリを提供し,それは,
dlopenライブラリの様々な困難をプログラマから隠すことを目指します.それは,
dlopenの機能で必要とされるアプリケーションとともに配布可能な,ヘッダファ
イルと小さなCソースファイルから成り立ちます.@file{libltdl}サービスの単
純な実装に対し,あまりに制限が多いダイナミックリンカをもつプラットフォー
ム上では,GNU DLDを要求したり,libtoolのdlpreopenメカニズムを用いてダイ
ナミックリンクをエミュレートするだけのものもあります.

@noindent
libltdlは,現在以下のダイナミックリンクメカニズムをサポートします.

@itemize @bullet
@item
@code{dlopen} (Solaris,Linux,そして様々なBSD)
@item
@code{shl_load} (HP-UX)
@item
@code{LoadLibrary} (Win16とWin32)
@item
@code{load_add_on} (BeOS)
@item
GNU DLD (スタティックライブラリに対するダイナミックリンクのエミュレーション)
@item
libtoolのdlpreopen (@pxref{Dlpreopening})
@end itemize

@noindent
以下の例外で,libltdlはGNUライブラリ公有使用許諾書の条件下でライセンスさ
れています.

@quotation
GNU公有使用許諾書の特別な例外として,プログラムとライブラリを作成するた
め,GNU libtoolを使用するプログラムの部分としてこのファイルを配布する場
合,プログラムの残りに対して使用する配布条件の下でそれを含めることができ
ます.
@end quotation

@menu
* Libltdl interface::           How to use libltdl in your programs.
* Modules for libltdl::         Creating modules that can be @code{dlopen}ed.
* Distributing libltdl::        How to distribute libltdl with your package.
@end menu

@node Libltdl interface
@section プログラムでのlibltdlの使用法

@noindent
libltdl APIは,非常に簡単ですが,強力なSolarisとLinuxのdlopenインターフェー
スに似ています.

@noindent
プログラムでlibltdlを使用するために,ヘッダファイル@file{ltdl.h}をインク
ルードする必要があります.

@example
#include <ltdl.h>
@end example

@noindent
libltdlがスレッドセーフでない,すなわち,マルチスレッドアプリケーション
は,libtoolに対しミューテックスを使用する必要があることに注意してくださ
い.それは,GNU/Linuxのglibc 2.0の@samp{RTLD_LAZY}を用いた@code{dlopen} 
が(デフォルトでlibtoolを使用します),スレッドセーフではないことが報告さ
れていますが,この問題は,glibc 2.1でおそらく修正されるでしょ.一方,
@samp{RTLD_NOW}は,FreeBSD上のマルチスレッドアプリケーションで問題が生じ
たと報告されています.これらの問題に関する作業は,読者の演習として残って
います.貢献は,きっと歓迎されます.

@noindent
以下の型は@file{ltdl.h}で定義されています.

@deftp {Type} lt_ptr_t
@code{lt_ptr_t}は,汎用ポインタです.
@end deftp

@deftp {Type} lt_dlhandle
@code{lt_dlhandle}はモジュール"ハンドル"です.すべてのdlopenされるモジュー
ルはそれに関連付けされたハンドルがあります.
@end deftp

@deftp {Type} lt_dlsymlist
@code{lt_dlsymlist}はdlpreopenされるモジュールのシンボルリストです.この
構造体は,@pxref{Dlpreopening}で記述されます.
@end deftp

@page
@noindent
libltdlは以下の関数を提供します.

@deftypefun int lt_dlinit (void)
libltdlを初期化します.この関数は,libltdl使用する前に呼び出す必要があり,
複数回呼び出すことが可能です.成功したら0,それ以外ではエラーの番号を返
します.
@end deftypefun

@deftypefun int lt_dlexit (void)
libltdlを終了し,すべてのモジュールを閉じます.この関数は,
@code{lt_dlinit}が正常に呼び出された回数と同じだけ呼び出されたとき,
libltdlを終了するだけです.成功したら0,それ以外ではエラーの番号を返しま
す.
@end deftypefun

@deftypefun lt_dlhandle lt_dlopen (const char *@var{filename})
ファイル名@var{filename}を用いてモジュールを開き,そのハンドルを返します.
@code{lt_dlopen}は,libtoolダイナミックモジュール,プリロードされたスタ
ティックモジュール,プログラム自身,そしてネイティブなダイナミックライブ
ラリを開くことが可能です.

モジュール内の未解決のシンボルは,それが依存する(まだ実装されていない)ラ
イブラリと,前もってdlopenされたモジュールを用いて解決されます.このモ
ジュールを使用している実行形式が@code{-export-dynamic}フラグでリンクされ
ている場合,実行形式の大域的なシンボルもモジュール内の参照の解決に使用さ
れます.

@var{filename}がNULLでプログラムが@code{-export-dynamic}や@code{-dlopen
self}を用いてリンクされている場合,@code{lt_dlopen}はプログラム自身のハ
ンドルを返し,それはそのシンボルのアクセスに使用可能です.

libltdlがライブラリを見つけられず,ファイル名@var{filename}がディレクト
リコンポーネントを持たない場合,それは,以下の検索パスを(以下の順番で),
さらにモジュールを検索します.
 
@enumerate 1
@item
ユーザ定義の検索パス:

この検索パスは,関数@code{lt_dlsetsearchpath}と@code{lt_dladdsearchdir} 
を用いたプログラムで設定可能です.
 
@item
libtoolの検索パス:

この検索パスは,環境変数@var{LTDL_LIBRARY_PATH}の値です.
 
@item
システムのライブラリ検索パス:

システム依存のライブラリ検索パスです(例えば,Linuxでは
@var{LD_LIBRARY_PATH}になります).
@end enumerate

それぞれの検索パスは,例えば@code{"/usr/lib/mypkg:/lib/foo"}のような,コ
ロンで分けられた絶対的なディレクトリのリストにする必要があります.
 
同じモジュールが複数回ロードされた場合,同じハンドルが返されます.あらゆ
る原因で@code{lt_dlopen}が失敗した場合,NULLが返されます.
@end deftypefun

@deftypefun lt_dlhandle lt_dlopenext (const char *@var{filename})
ファイル名に異なるファイル名の拡張子を追加を試みる以外は,
@code{lt_dlopen}と同じです.ファイル名@var{filename}を持つファイルが見つ
からない場合,libltdlは,以下の拡張子の追加を試みます.

@enumerate 1
@item
libtoolのアーカイブ拡張子@samp{.la}
@item
ホストプラットフォームの本来のダイナミックライブラリに使用される拡張子で,例えば,@samp{.so},@samp{.sl}等
@end enumerate

この探索作戦は,本来のダイナミックライブラリの命名規則を知らないプログラ
ムが,そのようなライブラリを,libtoolモジュールと同様に,透過的に
@code{dlopen}することを可能にするために設計されています.
@end deftypefun

@deftypefun int lt_dlclose (lt_dlhandle @var{handle})
モジュール@var{handle}の参照カウントを減らします.ゼロになったり,このモ
ジュールに依存する他のモジュールがない場合,モジュールはアンロードされま
す.成功時には0を返します.
@end deftypefun
 
@deftypefun lt_ptr_t lt_dlsym (lt_dlhandle @var{handle}, const char *@var{name})
モジュール@var{handle}内のアドレスを返し,そこでは,ヌルで終端された文字
列@var{name}で与えられるシンボルがロードされています.シンボルが見つから
ない場合はNULLを返します.
@end deftypefun
 
@deftypefun {const char *} lt_dlerror (void)
libltdlのあらゆる関数から発生した最も新しいエラーを記述する可読性の高い
文字列を返します.初期化からまたは最後に呼び出されてからエラーが発生して
いない場合,NULLを返します.
@end deftypefun
 
@deftypefun int lt_dlpreload (const lt_dlsymlist *@var{preloaded})
プリロードされているモジュール@var{preloaded}のリストを登録します.
@var{preloaded}がNULLの場合,@code{lt_dlpreload_default}で設定されている
リスト以外の,これまで登録されているすべてのシンボルリストが検出されます.
成功時には0を返します.
@end deftypefun

@deftypefun int lt_dlpreload_default (const lt_dlsymlist *@var{preloaded})
プリロードされているモジュールリストのデフォルトを@var{preloaded}に設定
し,それは@code{lt_dlpreload}で検出されません.この関数は,
@code{lt_dlinit}を使用して初期化されるためにlibltdlを要求し@emph{ない}こ
とと,デフォルトでプリロードされるモジュールを登録するためにプログラムで
使用できることに注意してください.この関数を直接呼び出す代わりに,ほとん
どのプログラムはマクロ@code{LTDL_SET_PRELOADED_SYMBOLS}を使用します.

成功時には0を返します.
@end deftypefun

@defmac LTDL_SET_PRELOADED_SYMBOLS()
プリロードされるシンボルのデフォルトリストを設定します.プリロードされる
libltdlのモジュールを初期化するためにプログラムで使用した方が良いでしょ
う.

@example
#include <ltdl.h>

int main() @{
  /* ... */
  LTDL_SET_PRELOADED_SYMBOLS();
  /* ... */
@}
@end example
@end defmac

@deftypefun int lt_dladdsearchdir (const char *@var{search_dir})
検索ディレクトリ@var{search_dir}をユーザ定義のライブラリ検索パスに追加
します.成功時には0を返します.
@end deftypefun

@deftypefun int lt_dlsetsearchpath (const char *@var{search_path})
現在のユーザ定義のライブラリ検索パスを@var{search_path}で置換し,それは
コロンで分けられた絶対的なディレクトリのリストにする必要があります.成功
時には0を返します.
@end deftypefun

@deftypefun {const char *} lt_dlgetsearchpath (void)
現在のユーザ定義のライブラリ検索パスを返します.
@end deftypefun

@deftypevar {lt_ptr_t (*} lt_dlmalloc ) (size_t size)
@deftypevarx {void (*} lt_dlfree ) (lt_ptr_t ptr)
これらの変数は,デフォルトで@code{malloc}と@code{free}に設定されますが,
同等の機能を提供する他の関数に設定可能です.しかし,
@code{lt_dlpreopen_default}やマクロ@code{LTDL_SET_PRELOADED_SYMBOLS}以外
のあらゆるlibltdl関数の呼び出し後に,その値を編集すべきではありません.
@end deftypevar


@node Modules for libltdl
@section @code{dlopen}可能なモジュールの作成

libtoolモジュールは,いくつかの例外はありますが,通常のlibtoolライブラリ
に似ています.

libtoolの@samp{-module}スイッチを用いて,モジュールとリンクする必要があ
り,そして,dlopenをサポートしていないプラットフォームでlibtoolが
dlpreopen できるよう,@samp{-dlopen modulename.la}を用いてモジュールを
dlopenするために,あらゆるプログラムとリンクすべきです.モジュールが,あ
らゆる他のライブラリに依存する場合,モジュールとリンクするときや,それを
dlopenするプログラムをリンクするとき,それらを確実に指定してください.特
定のモジュールに対し@pxref{Versioning}を使用禁止にしたい場合,
@samp{-avoid-version}スイッチを用いてリンクすべきです.libtoolモジュール
は,"lib"接頭辞が不要なことに注意してください.しかし,automake 1.4やそ
れ以上のものは,そのようなモジュールの構築が必要です.

通常,その内部を知る必要なしにプログラムがdlopenできるよう,一組のモジュー
ルは同じインターフェース提供し,すなわち同じシンボルをエクスポートします.
すべてのエクスポートされたシンボルで,シンボルの衝突を避けるため,
"modulename_LTX_"を前置する必要があります(@samp{modulename}はモジュール
名です).内部シンボルは,例えば"_modulename_"を前置するといった,他のモ
ジュールと衝突しないような方法で命名する必要があります.一回以上宣言され
た,同じシンボルを持つことをサポートするシステムもありますが,それは通常
移植性がなく,そのようなモジュールをdlpreopenすることを不可能にします.
libltdlは,シンボルの本当の名前を得るとき,自動的に接頭辞を切り取ります.
さらに,非libtoolモジュールもdlopenできるよう,接頭辞を使用していないモ
ジュールをサポートします.

@file{foo1.c}は移植可能なlibtoolモジュールの例です.エクスポートされたシ
ンボルは"foo1_LTX_",内部シンボルは"_foo1_"が前置されています.コードの
可読性を高めるため,エイリアスは最初に定義されています.

@example
/* aliases for the exported symbols */
#define foo	foo1_LTX_foo
#define bar	foo1_LTX_bar

/* a global variable definition */
int bar = 1;

/* a private function */
int _foo1_helper() @{
  return bar;
@}

/* an exported function */
int foo() @{
  return _foo_helper();
@}
@end example

@noindent
@file{Makefile.am}は,モジュール@file{foo1.la}を構築するのに必要な規則を
含みます.

@example
...
lib_LTLIBRARIES = foo1.la

foo1_la_SOURCES = foo1.c
foo1_la_LDFLAGS = -module
...
@end example


@node Distributing libltdl
@section パッケージとともにlibltdlを配布する方法

libltdlはlibtoolとともにインストールされるのですが,libtoolやlibltdlをイ
ンストールしていないパッケージユーザの利便性のため,パッケージの配布物に
libltdlを含めたいと思うかも知れません.この場合,使用したいlibltdlの特色
を決定することが可能です.それは,便利なライブラリやインストール可能な
libtoolライブラリです.

便利なライブラリの利点の一つはインストールされていないということなので,
libtoolを使用するという事実はユーザにとって明白ではなく,ユーザが以前に
インストールしているlibtoolのバージョンを上書きしません.一方,(例えば,
バグフィックスといった)理由があり,libltdlをアップグレードしたい場合,イ
ンストールされているバージョンのlibtoolを置き換える代わりに,パッケージ
を再コンパイルする必要があります.しかし,プログラムやライブラリが以前に
インストールされているバージョンのlibltdlを使用しているライブラリとリン
クする場合,リンカエラーが発生し実行時にクラッシュするかもしれません.も
う一つの問題は,一つのlibtoolライブラリ以上の便利なライブラリをリンクで
きないことで,複数のシンボルを得る可能性があるので,これらのライブラリを
用いた単一のプログラムとリンクしてください.一般的に,libtoolを使用して
いる他のライブラリに依存しないプログラムでは,便利なライブラリを問題なく
使用可能です.libltdlのこの特徴を利用可能にするため,
@samp{AC_LIBLTDL_CONVENIENCE}行を@file{configure.in}に,
@samp{AM_PROG_LIBTOOL}の@emph{前に}加えた方が良いでしょう.

インストール可能なバージョンのlibltdlを選択するために,マクロ
@samp{AC_LIBLTDL_INSTALLABLE}の呼び出しを@file{configure.in}に,
@samp{AM_PROG_LIBTOOL}の@emph{前に}加えた方が良いでしょう.このマクロは,
libltdlが既にインストールされているかどうか調査し,そうでない場合,構築
しインストールされるパッケージlibltdlを埋め込むことを要求します.しかし,
バージョン調査は実行されないことに注意してください.ユーザは,コンフィグ
レーションスイッチ@samp{--enable-ltdl-install}を使用することで,他のバー
ジョンの存在に関係なく,テストを優先し,埋め込まれたlibtoolをインストー
ルする必要があるか決定することができます.

libtoolをパッケージに埋め込むため,@code{libtoolize}コマンドラインに
@samp{--ltdl}のみ加えてください.それで,パッケージのサブディレクトリ
@samp{libltdl}にlibtoolのソースをコピーします.どちらのマクロも,
@samp{libltdl}ディレクトリの位置を指定する,追加の引数を受け入れます.デ
フォルトで,どちらのマクロも@samp{$@{top_builddir@}/libltdl}を仮定します.

どのマクロを使用しても,@file{configure.in}は@samp{AC_CONFIG_SUBDIRS}を
使用して,libltdlをコンフィグレーションし,@file{Makefile}が,例えば,
automakeの@var{SUBDIRS}を使用して,libtoolのディレクトリでサブmakeを開始
することを確実にするのはあなたです.どちらのマクロも,libltdlでリンクす
るために使用するリンクフラグのシェル変数@var{LIBLTDL}と,@file{ltdl.h}を
インクルードするプログラムをコンパイルするために使用するプリプロセッサフ
ラグ@var{INCLTDL}を定義します.この変数が@file{Makefile}で利用可能にする
ことを確実にするため@samp{AC_SUBST}を使用したり,デフォルトで
@samp{AC_SUBST}される,@var{LIBS}と@var{CPPFLAGS}のような変数に加えるの
はあなた次第です.

便利なlibltdlを使用している場合,@var{LIBLTDL}は便利なlibltdlのバージョ
ンに対するパス名で,@var{INCLTDL}はlibltdlを含むディレクトリが続く
@samp{-I}になり,どちらも@samp{$@{top_builddir@}/}で始まります.

インストールされているlibltdlのバージョンを要求し,それが見つかった場合
@footnote{たとえ,libltdlがインストールされていても,libltdlがCライブラ
リ以外のライブラリが提供するシンボルに依存する場合,
@samp{AC_LIBLTDL_INSTALLABLE}は検出に失敗する可能性があります.この場合,
libltdlの構築とインストールは不必要です.},@var{LIBLTDL}は@samp{-lltdl} 
に,@var{INCLTDL}は空に設定されます(それは,libltdlがライブラリパスにあ
る場合,@file{ltdl.h}がインクルードパスのどこかにあるという,暗黙の仮定
です).インストール可能なlibltdlのバージョンを構築する必要がある場合,
@samp{$@{top_builddir@}/}で始まるそのパス名は,@var{LIBLTDL}に保存され,
@var{INCLTDL}は便利なライブラリの場合と同様に設定されます.

そのため,libltdlとプログラムをリンクしたいとき,libtoolを使用して,
@samp{$(INCLTDL)}を用いてコンパイルし,@samp{$(LIBLTDL)}を用いてリンクし,
インストールされた,または,インストール可能な便利なライブラリにしてくだ
さい.

おそらく@samp{AC_LIBTOOL_DLOPEN}も@file{configure.in}に,
@samp{AM_PROG_LIBTOOL}の@emph{前に}加えた方が良く,そうしない場合は,
libtoolはdlopenメカニズムがサポートされていないと仮定し,おそらく希望し
ていないdlpreopenに逆戻りします.

libltdlとプログラムをリンクするとき,@code{-static}や@code{-all-static} 
スイッチの使用を避けてください.dlopen関数はスタティックリンクに対して利
用可能でない可能性があるので,これはすべてのプラットフォームで動作するわ
けではありません.

以下の例は,パッケージに便利なlibltdlを埋め込む方法を示します.インストー
ル可能な変形を使用するために,@samp{AC_LIBLTDL_CONVENIENCE}を
@samp{AC_LIBLTDL_INSTALLABLE}で置換してください.我々は,libltdlが
@samp{libtoolize --ltdl}を使用して埋め込まれていると仮定しています.

configure.in:
@example
...
dnl Enable building of the convenience library
dnl and set LIBLTDL accordingly
AC_LIBLTDL_CONVENIENCE
dnl Substitute INCLTDL and LIBLTDL in the Makefiles
AC_SUBST(INCLTDL)
AC_SUBST(LIBLTDL)
dnl Check for dlopen support
AC_LIBTOOL_DLOPEN
dnl Configure libtool
AM_PROG_LIBTOOL
dnl Configure libltdl
AC_CONFIG_SUBDIRS(libltdl)
...
@end example

Makefile.am:
@example
...
SUBDIRS = libltdl

INCLUDES = $(INCLTDL)

myprog_LDFLAGS = -export-dynamic
# The quotes around -dlopen below fool automake into accepting it
myprog_LDADD = $(LIBLTDL) "-dlopen" self "-dlopen" libfoo.la
myprog_DEPENDENCIES = $(LIBLTDL) libfoo.la
...
@end example


@node Other languages
@chapter 他の言語でのlibtoolの使用
@cindex C, not using
@cindex languages, non-C
@cindex C++, using

libtoolは最初に,C言語での共有ライブラリを書くことに対するサポートを加え
るために実装されました.しかし,時間が経ち,プログラマが好みのプログラム
言語での共有ライブラリの便利さを自由に得られるように,libtoolは他の言語
と統合されています.

この章は,libtoolが他の言語と相互作用する方法と,Cを用いない場合に必要と
される特記事項を記述します.

@menu
* C++ libraries::
@end menu

@node C++ libraries
@section C++に対するライブラリを書く
@c FIXME: in the TOC, the ++ is too large (seems to be math mode)
@cindex trouble with C++
@cindex pitfalls using C++
@cindex C++, pitfalls

C++コードのライブラリを作成することは,そのオブジェクトファイルがCのもの
と3つの点でのみ異なるので,かなり簡単な処理になります.

@enumerate 1
@item
名前をめちゃくちゃにするため,C++ライブラリはC++コンパイラで作成されたも
のだけ利用可能です.この決定は,コンストラクタ,例外処理,そしてRTTIのよ
うな機能の実装との衝突からユーザを守るため,C++の設計者によってなされま
した.

@item
システムによっては,C++コンパイラは,ダイナミックリンカが動的(すなわち実
行時)に初期化を実行することを,特別な動作として考慮する必要があります.
これは,そのようなライブラリとリンクするため,@file{ld}を直接呼び出すべ
きではなく,その代わりにC++コンパイラを使用するべきだということを意味し
ます.

@item
C++コンパイラは,いくつかの標準C++ライブラリとデフォルトでリンクしますが,
libtoolは,これらのライブラリがどれかを知らないため,それに対してリンク
する方法を調査するため,ライブラリ内部の依存の解析さえ実行できません.そ
れゆえ,C++プログラムやライブラリとリンクするため@file{ld}を実行すること
は,失敗すると思われます.しかし,C++コンパイラを直接実行することは,ラ
イブラリ内部の依存に関係する問題に至る可能性があります.
@end enumerate

結論として,libtoolはC++ライブラリに対する一般的な使用のための準備ができ
ていません.標準Cコンパイラでコンパイルする場合は,``初期化要素は一定で
はない''というエラーの原因となる,あらゆるグローバルまたはスタティック変
数の初期化を避けるべきです.

この問題に関して動作する他の方法もありますが,それらはこのマニュアルの範
囲を越えています.

さらに,C++コンパイラがデフォルトでリンクするC++ 標準ライブラリと,リン
クコマンドラインの明示的なリストは,コンフィグレーション時に分かった方が
良いでしょう.たぶん将来,libtoolはこの仕事を単独で可能となるでしょう.


@node Troubleshooting
@chapter トラブルシューティング
@cindex troubleshooting
@cindex problems, solving
@cindex solving problems
@cindex problems, blaming somebody else for

libtoolは,コンスタントに開発されていて,現在のオペレーティングシステム
で最新を保つよう変更します.libtoolがプラットフォーム上で思ったように動
作しない場合,問題点と解決方法を決定する助けとなる,この章を読んだ方が良
いでしょう.

@menu
* Libtool test suite::          Libtool's self-tests.
* Reporting bugs::              How to report problems with libtool.
@end menu

@node Libtool test suite
@section libtoolのテストスイート
@cindex test suite

libtoolは,その能力をテストし,lobtoolプログラムの明らかなバグを報告する,
プログラムの独自のセットとともにあります.これらのテストは,libtoolの過
去の問題と他のオペレーティングシステム内の既知の欠陥を基にして,絶えず進
化もしています.

@file{INSTALL}ファイルに記述されているように,libtoolの構築後,基本的な
機能要求に合っていることを確めるために,@kbd{make check}を実行することが
可能です.

@menu
* Test descriptions::           The contents of the test suite.
* When tests fail::             What to do when a test fails.
@end menu

@node Test descriptions
@subsection テストスイートの記述

ここに,テストスイートの現在のプログラムと,それらがテストするもののリスト
があります.

@table @file

@item cdemo-conf.test
@itemx cdemo-exec.test
@itemx cdemo-make.test
@itemx cdemo-static.test
@itemx cdemo-shared.test
@pindex cdemo-conf.test
@pindex cdemo-exec.test
@pindex cdemo-make.test
@pindex cdemo-static.test
@pindex cdemo-shared.test
これらのプログラムは,libtool配布物の@file{cdemo}サブディレクトリが,正
しくコンフィグレーションされ,構築されることを知るために調査します.

@file{cdemo}サブディレクトリは,libtoolの便利なライブラリのデモンストレー
ションをふくみ,それは,構築時に共有ライブラリの作成を可能とするメカニズ
ム,コンポーネントが,それが共有ライブラリでも,プログラムや他のライブラ
リと遅れてリンクされることを可能とする方法です.

@file{cdemo-make.test}と@file{cdemo-exec.test}のテストは,3つの異なる
libtoolコンフィグレーションで,3回実行されます.@file{cdemo-conf.test} 
は,スタティックライブラリと共有ライブラリの両方を構築するために(両方サ
ポートしているプラットフォームではデフォルトです)@file{cdemo/libtool}を
コンフィグレーションし,@file{cdemo-static.test}はスタティックライブラリ
のみ構築し(@samp{--disable-shared}),そして@file{cdemo-shared.test}は共
有ライブラリのみ構築します(@samp{--disable-static}).

@item demo-conf.test
@itemx demo-exec.test
@itemx demo-inst.test
@itemx demo-make.test
@itemx demo-unst.test
@itemx demo-static.test
@itemx demo-shared.test
@itemx demo-nofast.test
@pindex demo-conf.test
@pindex demo-exec.test
@pindex demo-inst.test
@pindex demo-make.test
@pindex demo-unst.test
@pindex demo-static.test
@pindex demo-shared.test
@pindex demo-nofast.test
これらのプログラムは,libtool配布物の@file{demo}サブディレクトリが,コン
フィグレーション,構築,インストール,そしてアンインストールが正しくでき
ることを知るために調査します.

@file{demo}サブディレクトリは,libtoolを使用する平凡なパッケージのデモン
ストレーションを含みます.テストの@file{demo-make.test},
@file{demo-exec.test},@file{demo-inst.test},そして
@file{demo-unst.test}は,4つの異なるlibtoolのコンフィグレーションの下で,
4回実行されます.@file{demo-conf.test}は,スタティックと共有の両方のラ
イブラリを構築するために@file{demo/libtool}をコンフィグレーションし,
@file{demo-static.test}は,スタティックライブラリのみ構築し
(@samp{--disable-shared}),そして@file{demo-shared.test}は,共有ライブラ
リのみを構築します(@samp{--disable-static}).@file{demo-nofast.test}は,
fast-installモードを使用禁止にするために
(@samp{--enable-fast-install=no}),@file{demo/libtool}をコンフィグレーショ
ンします.

@item deplibs.test
@pindex deplibs.test
スタティックライブラリを共有ライブラリにリンク不可能なシステムもたくさん
あります.そのような場合を避けるため,libtoolは
@code{deplibs_check_method}を使用します.このテストは,libtoolの
@code{deplibs_check_method}が正しく動作するかどうか調査します.

@item hardcode.test
@pindex hardcode.test
共有ライブラリを持つすべてのシステムで,実行形式に対しリンクされるライブ
ラリの位置が実行形式の内部に符号化されるはずです@pxref{Linking
executables}.このテストは,システムリンカがライブラリの位置をハードコー
ドし,libtool自身のリンカの動作方法の概念と一致することを保証する条件を
調査します.

@item build-relink.test
@pindex build-relink.test
変数@var{shlibpath_overrides_runpath}が正しく設定されているかどうか調査
します.テストが失敗し,@var{VERBOSE}が設定されている場合,それは変数を
設定する必要がないことを示します.

@item noinst-link.test
@pindex noinst-link.test
libtoolが,たった今構築されたライブラリにリンクする方が良い時,以前にイ
ンストールされているのバージョンにリンクしようとしないかどうか調査します.

@item mdemo-conf.test
@itemx mdemo-exec.test
@itemx mdemo-inst.test
@itemx mdemo-make.test
@itemx mdemo-unst.test
@itemx mdemo-static.test
@itemx mdemo-shared.test
@pindex mdemo-conf.test
@pindex mdemo-exec.test
@pindex mdemo-inst.test
@pindex mdemo-make.test
@pindex mdemo-unst.test
@pindex mdemo-static.test
@pindex mdemo-shared.test
これらのプログラムは,libtool配布物の@file{mdemo}サブディレクトリが,コ
ンフィグレーション,構築,インストール,そしてアンインストールが正しくで
きることを知るために調査します.

@file{mdemo}サブディレクトリは,libtoolと,システム非依存のモジュールロー
ドのための,dlopenラッパー@file{libltdl}を使用するパッケージのデモンスト
レーションを含みます.ライブラリ@file{libltdl}は,様々なプラットフォーム
(Linux,Solaris,HP/UX等)に対する,dlpreopenモジュールに対するサポートを
含む(@pxref{Dlpreopening})dlopenラッパーを提供します.

テストの@file{mdemo-make.test},@file{mdemo-exec.test},
@file{mdemo-inst.test},そして@file{mdemo-unst.test}は,3つの異なる
libtoolのコンフィグレーションの下で,3回実行されます.
@file{mdemo-conf.test}は,スタティックと共有の両方のライブラリを構築する
ために@file{mdemo/libtool}をコンフィグレーションし,
@file{mdemo-static.test}は,スタティックライブラリのみ構築し
(@samp{--disable-shared}),そして@file{mdemo-shared.test}は,共有ライブ
ラリのみを構築します(@samp{--disable-static}).

@item dryrun.test
@pindex dryrun.test
このテストは,libtoolの@code{--dry-run}モードが正しく働くかどうかを調査
します.

@item assign.test
@pindex assign.test
libtoolスクリプト内の割り当てられている同じ行で,停止したり,続けたりし
ないかどうか調査します.

@item link.test
@pindex link.test
このテストは,libtoolでないスタティックライブラリに対する直接的なリンク
が正しく動作することを保証します.

@item link-2.test
@pindex link-2.test
このテストは,@samp{.lo}で終わるファイルがプログラムファイルに直接リンク
されないことを確かめます.

@item nomode.test
@pindex nomode.test
実際にlibtoolの助けが可能かどうか調査します.

@item quote.test
@pindex quote.test
このプログラムはlibtoolのメタ文字を引用符で囲むことを調査します.

@item sh.test
@pindex sh.test
`test'コマンドがlibtoolに忘れていないか調査します.

@item suffix.test
@pindex suffix.test
他のプログラミング言語がlibtoolで使用されるとき(@pxref{Other languages}),
ソースファイルは@samp{.c}以外の接尾子で終わるかもしれません.このテスト
は,サポートするすべてのファイル形式に対する接尾子を扱うこと可能で,接尾
子が不当なときは失敗することを確認します.
@end table


@node When tests fail
@subsection テストが失敗するとき
@cindex failed tests
@cindex tests, failed

上記のそれぞれのテストは,@kbd{make check}を実行するとき出力を生成しない
ように設計されています.それぞれのプログラムの終了ステータスで,テストが
成功しなかったかどうかを@file{Makefile}に伝えます.

テストが失敗した場合,それはlibtool内のプログラムエラー,またはプログラ
ム自身のエラーのどちらかが存在することを意味します.

特定のテストを調査するために,通常のプログラムで行うように,直接実行する
ことが可能です.テストがこの方法で呼び出されたとき,それは,問題を決定す
るのに役に立ちそうな出力を生成します.

テストプログラムに出力を生成させるもうひとつの方法は,実行前に
@var{VERBOSE}環境変数を@samp{yes}に設定することです.例えば,@kbd{env
VERBOSE=yes make check}ですべてのテストが実行され,それぞれについてデバッ
グ情報の表示が得られます.

@node Reporting bugs
@section バグの報告
@cindex bug reports
@cindex reporting bugs
@cindex problem reports

libtoolにバグを発見したと考えた場合,もう一度考えたほうが良いでしょう.
libtool管理者は,責任転嫁(または``バグを通過させる''かもしれません)で有
名です@footnote{訳注:原文では,passing the buck(責任転嫁)とpassing the
bug(バグを通過させる)をかけています}.libtoolは,共有ライブラリの実装で
既知の欠陥を修正するために開発されたので,libtoolのバグのほとんどは,あ
る程度は,他のオペレーティングシステムのバグになります.しかし,libtool 
の管理者は,他人のバギーなオペレーティングシステムに対するサポートを加え
ることを,確かに楽しんでいます.[Texinfoでウインクしている笑顔を表示する,
いい方法があれば良いのですが.]

libtoolの純粋なバグは,シェルスクリプトの移植性の問題,ドキュメントのエ
ラー,そしてテストスイートの失敗(@pxref{Libtool test suite})を含みます.

最初に,問題と考えられる動作が,既に特徴として言及されていないことを確か
めるために,ドキュメントとへルプ画面を調査してください.

そして,バグを報告することに関するEmacsガイド(@pxref{Bugs, , Reporting
Bugs, emacs, The Emacs Manual})を読んでください.リストアップされている
詳細は,Emacs特有のものもありますが,基本的な原則は一般的なものです.

最終的に,テストスイートの出力(@pxref{When tests fail}),バグを再生成す
るのに必要なすべての詳細,そして,動作がバグだと考えられる理由の概要のよ
うな,適切なあらゆる@emph{事実}とともに@value{BUGADDR}にバグの報告を送っ
てください.サブジェクト行に,単語``libtool''と,同様に使用しているバー
ジョンナンバー(それは,@kbd{ltconfig --version}の入力で分かります)が含ま
れていることを確認してください.


@node Maintaining
@chapter libtoolの管理用メモ

この章は,libtool管理者が見つける重要な情報を含みます.新しいシステムへ
の移植や,独自のlibtoolを書くことを考慮しない場合,役に立たないでしょう.

@menu
* New ports::                   How to port libtool to new systems.
* Tested platforms::            When libtool was last tested.
* Platform quirks::             Information about different library systems.
* libtool script contents::     Configuration information that libtool uses.
* Cheap tricks::                Making libtool maintainership easier.
@end menu

@node New ports
@section 新しいシステムへのlibtoolの移植

サポートされていないシステムへのlibtoolの移植に乗り出す前に,既存の仕事
と重複していないことを確認するために,@value{MAILLIST}に電子メールを送る
価値はあります.

移植の文章が見つからない場合,文句を言ってください!パッチを含む苦情と文
章やlibtool自身の改良は十分に歓迎されます.

@menu
* Information sources::         Where to find relevant documentation
* Porting inter-library dependencies::  Implementation details explained
@end menu

@node Information sources
@subsection ソースの情報

新たな移植の必要性が明らかになると,通常,以下の情報が必要となります.

@table @asis
@item 標準的なシステム名
他のシステムに影響しないようにlibtoolのコンフィグレーション処理を変更可
能にするため,このシステムに対する@code{config.guess}の出力が必要です.

@item @code{ld}と@code{cc}に対するmanページ
これらは通常,共有ライブラリを作成したり,共有ライブラリのみにリンクする
ため,そして,PICを生成するために使用するフラグを記述します.必要な情報
を見つけるため,以下の相互参照が必要かもしれません.

@item @code{ld.so},@code{rtld},または,その同等物のmanページ
これらは,システムで共有ライブラリがロードされる仕組みを理解するための,
有益な情報源です.

@item @code{ldconfig}やその同等物のmanページ
このページは,通常,共有ライブラリをインストールする方法を記述します.

@item @kbd{ls -l /lib /usr/lib}での出力
これは,システムの共有ライブラリの命名規則を表示し,それは,シンボリック
リンクの名も含みます.

@item あらゆる追加の文章
共有ライブラリの構築とインストール方法の特別な文章があるシステムもありま
す.
@end table

Bourneシェルプログラムの方法を知っている場合,完全に自分で移植することが
可能です.それ以外の場合,関連する作業を行う腕のある人を探す必要がありま
す.libtoolメーリングリストの人々は,新たな移植への援助を志願する意思が
あるので,彼らに情報を送ることができます.

独自に移植するためには,プラットフォーム特有のコンフィグレーションプロセ
スの変更を行うため,@code{ltconfig}スクリプトを明確に修正する必要があり
ます.@code{PORTME}キーワードに対するスクリプトを検索する必要があり,そ
れで,変更に必要なヒントを得られるでしょう.一般的に,呼び出されるものは,
適切なコンフィグレーション変数の編集です(@pxref{libtool script
contents}).

最善策は,既にサポートされている良く似たシステムを見つけ,変更の基本とす
ることです.しかし,システムが他のサポートされているシステムと,大きく異
なる場合や,新しいコンフィグレーション変数を加え,それに応じて
@code{ltmain.sh}スクリプトを変更する必要がある場合もあります.欲しいもの
を達成するための,最も効果的な方法の助言がある可能性があるので,
@code{ltmain.sh}を変更する前に,メーリングリストに書いて確認してください.


@node Porting inter-library dependencies
@subsection ライブラリ内部の依存性のサポートの移植
@cindex inter-library dependency
@vindex deplibs_check_method

バージョン1.2c以降,libtoolは,Toshio Kuratomi
@email{badger@@prtr-13.ucsc.edu}のパッチのおかげで,ライブラリ内部の依存
性を可能とする機能が再導入されてるプラットフォームもあります.パッチに含
まれるメッセージの短いバージョンメッセージが,ここにあります.

基本的な体系はこのようになります.@file{ltconfig.in}で,libtoolを書いて
いる人は,@samp{$deplibs}が@samp{$archive_cmds}のどこかに含まれているこ
と,また,変数@samp{$deplibs_check_method}と,
@samp{deplibs_check_method}がファイルマジックの場合は
@samp{$file_magic_cmd}が設定されていることを確認します.

@samp{deplibs_check_method}は,以下の5つの内の一つのはずです.
@table @samp
@item file_magic [@var{regex}]
@vindex file_magic
@vindex file_magic_cmd
@vindex file_magic_test_file
ライブラリリンクパスで正しいlibnameを持つライブラリを探します.そして,
ライブラリで@samp{$file_magic_cmd}を実行し,@code{egrep}を使用した
@samp{regex}に一致することを調査します.@var{file_magic_test_file}が
@file{ltconfig}で設定されているとき,正規表現がその出力と一致するかどう
かを検証し,それ以外ではユーザが警告を受けるようにするため,それは
@samp{$file_magic_cmd}への引数として使用されます.

@item test_compile 
@vindex test_compile
ライブラリリストの出力以外とプログラムがリンク可能かどうかのみを調査し,
それらが@code{ldd}の出力でリストアップされていることを調査します.それは
現在,使用されておらず,将来は打ち切る可能性があります.

@item pass_all
@vindex pass_all
調査せず,すべて通過します.例えばDEC OSF/1 3 と 4のような,デフォルトで,
コードが位置に依存せず,ライブラリ内部の依存性がダイナミックリンカで適切
にサポートされているプラットフォームで,これは動作するでしょう.

@item none
@vindex none
deplibsをdeplibs=""に再設定します.そのように,@samp{archive_cmds}は,す
べてのプラットフォームでdeplibsを含むはずですが,deplibは必要がなければ
使用されません.

@item unknown
@vindex unknown
@file{ltconfig.in}で優先されない場合,すべてのシステムでデフォルトです.
それは@samp{none}と同じですが,正しい値が何か,我々が本当に知らないこと
を文章化していて,我々はそれを改善するパッチを歓迎します.
@end table

@file{ltmain.in}で,我々は本当に一生懸命作業しました.それは,
(libname_spec等の評価を使用するための変数を設定/リリース行う)小さな初期
化と移植,そして使用するメソッドを決定するケース文です.これは,実際には
コードです@dots{}もう少し凝縮できれば良かったのですが,関数呼び出しを用
いずにできるとは思えませんでした.私はほとんどの(ループの外に出す等の)最
適化を行いましたが,余分なものがあるかもしれません.前に進めていく内にや
めるべきだと考えていたことは,明白な最適化を考える前に,発見したあらゆる
バグに対して作業することでした.


@node Tested platforms
@section テストされたプラットフォーム

この表は,共有ライブラリのサポートを謡っているプラットフォームで,
libtoolがテストされたことが分かっている最後の時期を記述しています.

@example
@include PLATFORMS.ja
@end example

注:ベンダー配布されているHP-UXの@code{sed}(1)プログラムは,ひどく壊れて
いて,libtoolの要求を処理することができないため,ユーザは異常の問題を報
告する可能性があります.これらのシステムで動作する(GNU @code{sed})のよう
な@code{sed}をインストールする以外に,回避方法はありません.

注:ベンダー配布されているNCR MP-RAS @code{cc}プログラムは,標準エラーに
著作権を出力し,@file{conftest.err}の大きさのテストで混乱します.回避方
法は,@code{configure}を実行するとき,@kbd{CC='cc -Hnocopyr'}を用いて
@code{CC} を指定します.


@node Platform quirks
@section プラットフォームの癖

このセクションは,libtoolの管理者の健康に捧げます.それは,libtoolが使用
するプログラム,システムごとの違い,そしてテストの方法を記述します.

libtoolはシェルスクリプトなので,最初から最後まで読むだけで理解すること
は難しいはずです.このセクションは,libtoolが特定の方法で行う理由の理解
を助けます.スクリプト自身が組み合わされているので,libtoolの改善や,独
自に書く方法の,より良いセンスが必要でしょう.

@menu
* References::                  Finding more information.
* Compilers::                   Creating object files from source files.
* Reloadable objects::          Binding object files together.
* Archivers::                   Programs that create static archives.
@end menu

@node References
@subsection 参照

以下は,価値のある文章の参照リストです.

@itemize @bullet
@item
SGIのIRIXのマニュアルページで,それは
@url{http://techpubs.sgi.com/cgi-bin/infosrch.cgi?cmd=browse&db=man}で見
つかります.

@item
Sunのフリーサービス領域
(@url{http://www.sun.com/service/online/free.html})とドキュメントサーバ
(@url{http://docs.sun.com/}).
@end itemize


@node Compilers
@subsection コンパイラ

libtoolに影響するコンパイラの特徴は,PICオブジェクトを生成するための(存
在する場合は)必要なフラグのみです.一般的に,Cコンパイラが特定のPICフラ
グをサポートする場合,あらゆる派生的なコンパイラは同じフラグをサポートし
ます.この規則に対し,注目すべき若干の例外があるまでは,このセクションで
はCコンパイラのみを説明します.

プラットフォームに関係なく,以下のCコンパイラは,標準のコマンドライオプ
ションがあります.

@table @code
@item gcc
これはGNU Cコンパイラで,多くのフリーオペレーティングシステム(少し例をあ
げると,FreeBSD,GNU/Hurd,GNU/Linux,Lites,NetBSD,そしてOpenBSDです)
に対する,システムコンパイラでもあります.

@samp{-fpic}や@samp{-fPIC}フラグは,位置に依存しないコードを生成するため
に使用可能です.@samp{-fPIC}は動作するコードを生成することを保証しますが,
m68k,m88k,そしてSparcチップ上ではコードは遅くなります.しかし,これら
のチップで@samp{-fpic}を使用すると,共有ライブラリでの自由なサイズが強制
的に制限されます.
@end table

バンドルされているオペレーティングシステムにより,このサブセクションの残
りでコンパイラをリストアップします.

@c FIXME these should all be better-documented

@table @code
@item aix3*
@itemx aix4*
AIXはPowerPCとRS/6000チップのみに移植されているので,AIXコンパイラはPIC 
フラグはありません.@footnote{PowerPCとRS/6000チップ(@code{powerpc-*-*},
@code{powerpcle-*-*},そして@code{rs6000-*-*})に対しコンパイルされている
すべてのコードは,オペレーティングシステムやコンパイラスイートに関係なく
位置に依存しません.そのため,``標準オブジェクト''はこれらのシステムの共
有ライブラリの構築で使用され,特別なPICコンパイラフラグは要求されません.}

@item hpux10*
PICを生成するために@samp{+Z}を使用してください.

@item osf3*
Digital/UNIX 3.xは,少なくともPowerPCプラットフォームでなければ,PICフラ
グはありません.

@item solaris2*
PICを生成するために@samp{-KPIC}を使用してください.

@item sunos4*
PICを生成するために@samp{-PIC}を使用してください.
@end table


@node Reloadable objects
@subsection 再ロード可能なオブジェクト

すべての既知のシステム上で,再ロード可能なオブジェクトは@kbd{ld -r -o
@var{output}.o @var{input1}.o @var{input2}.o}を実行することで生成可能で
す.この再ロード可能なオブジェクトは,他のオブジェクトと完全な同義語とし
て扱うことが可能です.


@node Archivers
@subsection アーカイバ

すべての既知のシステム上で,スタティックライブラリの構築は,@kbd{ar cru
lib@var{name}.a @var{obj1}.o @var{obj2}.o @dots{}}の実行で完成するはずで,
そこでは,@samp{.a}ファイルは出力ライブラリで,それぞれの@samp{.o}ファイ
ルはオブジェクトファイルです.

すべての既知のシステム上で,@code{ranlib}という名のプログラムがある場合,
リンクする前に@kbd{ranlib lib@var{name}.a}コマンドを用いて,作成されるラ
イブラリを``祝福''するために使用する必要があります.Irixのように,代わり
に@code{ar ts}を使用するシステムもあります.


@node libtool script contents
@section @code{libtool}スクリプトの内容
@cindex implementation of libtool
@cindex libtool implementation

@code{libtool}スクリプトは@code{ltconfig}で生成されます
(@pxref{Configuring}).libtoolのバージョン0.7から1.0までは,このスクリプ
トは単純にシェル変数を設定し,libtoolのバックエンドの@code{ltmain.sh}の
基となっていました.libtoolバージョン1.1以降の@code{ltconfig}は,
@code{ltmain.sh}の内容を生成された@code{libtool}にinline化し,それは多く
のシステムでパフォーマンスを改善します.

遅延評価に対するシェルコマンドを持つ変数の命名に使用される規則は,有効な
単一行のシェルスクリプトが必要とされるところで接尾子@code{_cmd},複数行
のシェルスクリプトが遅延評価@strong{可能な}ところで接尾子@code{_cmds}を
使用することです.規則では,@code{_cmds}変数は,必要なところで,@code{~}
文字で評価ユニットを区切ります.

ここに,それぞれのコンフィグレーション変数と,@code{ltmain.sh}で使用法の
リストがあります.

@defvar AR
システムライブラリアーカイバの名前です.
@end defvar

@defvar CC
libtoolをコンフィグレーションするために使用するCコンパイラの名前です.
@end defvar

@defvar LD
再ロード可能なリンクとおそらく共有ライブラリに対し,libtoolが内部で使用
するリンカの名前です.
@end defvar

@defvar LTCONFIG_VERSION
これは,@code{libtool}のコンフィグレーション情報間の不一致と,その情報が
@code{ltmain.sh}で使用されることを防ぐための,@code{ltconfig}スクリプト
のバージョンナンバーに設定されます.
@end defvar

@defvar NM
BSD互換の@code{nm}プログラムの名前で,それは以下の書式の一つで,大域的な
シンボルを生成します.

@example
@var{address} C @var{global-variable-name}
@var{address} D @var{global-variable-name}
@var{address} T @var{global-function-name}
@end example
@end defvar

@defvar RANLIB
存在する場合,ranlibプログラムの名前を設定します.
@end defvar

@defvar allow_undefined_flag
結果として生じる共有ライブラリに,未解決のシンボルがあることを宣言するた
めに,@samp{archive_cmds}で使用されるフラグです.そのようなフラグが不要
な場合は空です.ライブラリで定義されていないシンボルを参照して,共有ライ
ブラリを生成する方法がない場合,@samp{unsupported}を設定します.
@end defvar

@defvar always_export_symbols
アーカイブとリンクする前に,@var{export_symbols_cmds}を使用してエクスポー
トされるシンボルのリストを,libtoolが自動的に生成するかどうかです.
@samp{yes}または@samp{no}に設定します.デフォルトは@samp{no}です.
@end defvar

@defvar archive_cmds
@defvarx archive_expsym_cmds
@defvarx old_archive_cmds
それぞれ,共有ライブラリ,@samp{-export-symbols}を用いた共有ライブラリ,
そしてスタティックライブラリを生成するために使用するコマンドです.
@end defvar

@defvar old_archive_from_new_cmds
共有ライブラリがスタティックライブラリに依存する場合,
@samp{old_archive_from_new_cmds}はスタティックライブラリを生成するために
使用するコマンドを含みます.この変数が空の場合,@samp{old_archive_cmds}
は使用されません.
@end defvar

@defvar build_libtool_libs
このシステムで,libtoolが共有ライブラリを構築できるかどうかです.
@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar build_old_libs
このシステムで,libtoolがスタティックライブラリを構築できるかどうかです.
@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar compiler_c_o
コンパイラが,同時に@code{-c}と@code{-o}オプションをサポートするかどうか
です.@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar compiler_o_lo
コンパイラが,直接".lo"ファイルへのコンパイルをサポートするかどうかで,
例えば,オブジェクトファイルが,接尾子".o"を持つ必要があるかどうかです.
@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar dlopen
プラットフォームで,@code{dlopen}をサポートするかどうかです.@samp{yes} 
または@samp{no}に設定します.
@end defvar

@defvar dlopen_self
実行形式自身が@code{dlopen}可能かどうかです.@samp{yes}または@samp{no} 
に設定します.
@end defvar

@defvar dlopen_self_static
静的にリンクされているとき(@samp{-all-static}),実行形式自身が
@code{dlopen}可能かどうかです.@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar echo
バックスラッシュをエスケープ文字と解釈しない@code{echo}プログラムです.
@end defvar

@defvar exclude_expsyms
プリリードされているシンボルにリストアップされないシンボルのリストです.
@end defvar

@defvar export_dynamic_flag_spec
dlopenされる共有ライブラリが,プログラムで定義されているシンボルへの参照
を可能にするコンパイラリンクフラグです.
@end defvar

@defvar export_symbols_cmds
@var{libobjs}からファイル@var{export_symbols}へエクスポートされたシンボ
ルを抽出するコマンドです.
@end defvar

@defvar fast_install
libtoolが特権を与えるのを,インストール者または開発者のどちらか決定しま
す.ビルドツリーでインストール者がプログラムを滅多に実行せず,開発者は滅
多にインストールしないしないと仮定します.これは,
@var{shlibpath_overrides_runpath}が@samp{yes}でないプラットフォーム上で
のみ意味があるので,この場合,@var{fast_install}は@samp{needless}設定さ
れます.@var{fast_install}が@samp{yes}に設定される場合,libtoolはインス
トールされたライブラリを検索するプログラムを作成し,プログラムがビルドツ
リーで実行される場合,まだインストールされていないライブラリを使用するた
めに,要求があれば,新しいコピーがリンクされます.@samp{no}に設定されて
いる場合,libtoolは,まだインストールされていないライブラリを使用するプ
ログラムを作成し,インストール時にプログラムの新しいコピーをリンクします.
デフォルト値は@samp{yes}または@samp{needless}で,それは,プラットフォー
ムとコンフィグレーションフラグに依存し,コンフィグレーションフラグ
@samp{--disable-fast-install}を用いると,@samp{yes}から@samp{no}に切り替
えられます.
@end defvar

@defvar finish_cmds
指定されたディレクトリで共有ライブラリを見つける方法を,ダイナミックリン
カに伝えるコマンドです.
@end defvar

@defvar finish_eval
コマンドが表示されない以外,@var{finish_cmds}と同じです.
@end defvar

@defvar fix_srcfile_path
コンパイラに対するシェル変数$srcfileを修正する表現です.
@end defvar

@defvar global_symbol_pipe
@var{NM}の出力を受け,Cの名前が続く生のシンボルのリストを生成するパイプ
ラインです.例えば,以下のようになります.

@example
$ @kbd{eval "$NM progname | $global_symbol_pipe"}
D @var{symbol1} @var{C-symbol1}
T @var{symbol2} @var{C-symbol2}
C @var{symbol3} @var{C-symbol3}
@dots{}
$
@end example

最初の列は,(いくつかのプラットフォーム上でコードからデータを伝えるため
に使用される)シンボル形式を含みますが,その意味はシステムに依存します.
@end defvar

@defvar global_symbol_to_cdecl
@var{global_symbol_pipe}の出力を厳密なC宣言に変換するパイプラインです.
HP/UXのような,リンカがコードとデータを区別するプラットフォームでは,デー
タシンボルはそのように宣言され,コードシンボルは関数として宣言されます.
気にしないプラットフォームではすべてがデータと仮定されます.
@end defvar

@defvar hardcode_action
@samp{immediate}または@samp{relink}のいずれかで,共有ライブラリパスがイ
ンストールされる前に実行形式にハードコードされるか,または,再リンクする
必要があるかに依存します.
@end defvar

@defvar hardcode_direct
@var{hardcode_libdir_flag_spec}が指定されたとき,
(@samp{@var{dir}/lib@var{name}.a}のような)コマンド行でライブラリが直接し
ていされる場合,リンカがディレクトリをハードコードするかどうかに依存し,
@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar hardcode_libdir_flag_spec
実行時に,共有ライブラリに対しダイナミックリンカが@var{libdir}を検索する
ために,バイナリに@var{libdir}変数をハードコードするためのフラグです.空
の場合,libtoolは他のハードコーディングメカニズムの使用を試みます.
@end defvar

@defvar hardcode_libdir_separator
コンパイラが単一の@var{hardcode_libdir_flag}のみ受け入れる場合,この変数
はそのフラグに対する複数の引数を分ける文字列を含みます.
@end defvar

@defvar hardcode_minus_L
@var{hardcode_libdir_flag_spec}が指定されたとき,結果として生じる実行形
式に@samp{-L}フラグで指定されるディレクトリを,リンカがハードコードする
かどうかに依存し,@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar hardcode_shlibpath_var
@var{hardcode_libdir_flag_spec}が指定されたとき,結果として生じる実行形
式に@samp{$shlibpath_var}の内容を書き込むことで,リンカがディレクトリを
ハードコードするかどうかに依存し,@samp{yes}または@samp{no}に設定します.
@samp{$shlibpath_var}で指定されたディレクトリが,リンク時ではなく実行時
に検索される場合,@samp{unsupported}に設定します.
@end defvar

@defvar host
@defvarx host_alias
情報を目的として,libtoolがコンフィグレーションされたシステムの指定され
た標準名に設定します.
@end defvar

@defvar include_expsyms
@var{export_symbols}の使用時に,常にエクスポートされる必要があるシンボル
のリストです.
@end defvar

@defvar libext
標準的な,古いアーカイブの接尾子(通常は"a")です.
@end defvar

@defvar libname_spec
ライブラリ名の接頭辞の書式です.Unixシステムでは,スタティックライブラリ
は@samp{lib@var{name}.a}と呼ばれますが,(OS/2やMS-DOSのような)システムで
は,ライブラリは@samp{@var{name}.a}のみで呼ばれることもあります.
@end defvar

@defvar library_names_spec
共有ライブラリ名のリストです.最初はファイル名で,残りはファイルへのシン
ボリックリンクです.リスト内の名前は,@samp{-l@var{name}}で与えられたと
きリンカが見つけるファイル名です.
@end defvar

@defvar link_static_flag
ダイナミックリンクを避けるために使用する(Cコンパイラに渡す)リンカフラグ
です.
@end defvar

@defvar need_lib_prefix
自動的にモジュール名に'lib'接尾子を付けるかどうかです.@samp{yes}または
@samp{no}に設定します.デフォルトで,それは@samp{unknown}になり,それは
@samp{yes}と同じ意味ですが,本当に確かめたわけではないことを告げています.
@samp{yes}は@code{dlopen}と'lib'接頭辞がないライブラリにリンク可能なこと
を意味し,すなわち,それは@var{hardcode_direct}を@samp{yes}にすることを
要求します.
@end defvar

@defvar need_version
バージョン管理がライブラリに必要とされるかどうかで,すなわち,ダイナミッ
クリンカが,すべてのライブラリに対しバージョンの接尾子を必要とするかどう
かです.@samp{yes}または@samp{no}に設定します.デフォルトで,それは
@samp{unknown}で,それは@samp{yes}と同じ意味を持ちますが,それを実際に確
かめていないことを告げています.
@end defvar

@defvar need_locks
同時にコンパイルするとき,衝突を避けるためにファイルをロックする必要があ
るかどうかです.@samp{yes}または@samp{no}に設定します.
@end defvar

@defvar no_builtin_flag
@code{char}として外部グローバルシンボルを宣言することと衝突する組み込み
関数を,利用不可能にするコンパイラフラグです.
@end defvar

@defvar no_undefined_flag
結果として生じる共有ライブラリに,未解決のシンボルがないことを宣言するた
めの,@samp{archive_cmds}で使用されるフラグです.
@end defvar

@defvar objdir
一時的なlibtoolファイルが含まれるディレクトリ名です.
@end defvar

@defvar objext
標準的なオブジェクトファイルの接尾子(通常は"o")です.
@end defvar

@defvar pic_flag
ライブラリオブジェクトファイルを構築するための,あらゆる追加のコンパイル
フラグです.
@end defvar

@defvar postinstall_cmds
@defvarx old_postinstall_cmds
それぞれ,共有またはスタティックライブラリをインストールした後に実行する
コマンドです.
@end defvar

@defvar postuninstall_cmds
@defvarx old_postuninstall_cmds
それぞれ,共有またはスタティックライブラリをアンインストールした後に実行
するコマンドです.
@end defvar

@defvar reload_cmds
@defvarx reload_flag
再ロード可能なオブジェクトを作成するコマンドです.
@end defvar

@defvar runpath_var
結果として生じる実行形式内にハードコードするディレクトリをリンカに伝える
環境変数です.
@end defvar

@defvar shlibpath_overrides_runpath
環境変数でプログラムのハードコードされたライブラリ検索パスを優先可能かど
うかを示します.これが@samp{no}に設定されている場合,libtoolはビルドツリー
にプログラムのコピーを2つ作成する必要がある可能性があり,一つはインストー
ルされ,もう一つはビルドツリーのみで実行されます.これらのコピーのどちら
かが作成されるとき,@code{fast_install}の値に依存します.デフォルト値は
@samp{unknown}で,それは@samp{no}と同じです.
@end defvar

@defvar shlibpath_var
ダイナミックリンカに共有ライブラリを探す場所を伝える環境変数です.
@end defvar

@defvar soname_spec
共有ライブラリがファイルの本当の名前と異なる場合,その中に符号化されたコー
ドされた名前です.
@end defvar

@defvar sys_lib_dlsearch_path_spec
実行時にライブラリの検索パスを取得する表現です.このリストに現れるディレ
クトリが実行形式にハードコードされることは決してありません.
@end defvar

@defvar sys_lib_search_path_spec
コンパイル時にライブラリの検索パスを取得する表現です.この変数は,特定の
ライブラリが共有かスタティックかをテストする必要があるとき,libtoolが使
用します.@var{shlibpath_var}でリストアップされるディレクトリは,このリ
ストに自動的に現れ,ライブラリ検索パスを拡張するためにこの変数を使用する
リンカもあるので,毎回(すなわち,コンフィグレーション時以外)libtoolは実
行します.リンカは@code{-L}のような検索パス引数も切り替えます.
@end defvar

@defvar thread_safe_flag_spec
スレッドセーフなライブラリを生成するために使用する(Cコンパイラに渡す)リ
ンカフラグです.
@end defvar

@defvar version_type
ライブラリバージョンナンバーの形式です.@samp{libtool},@samp{linux},
@samp{osf},@samp{sunos},または@samp{none}の一つです.
@end defvar

@defvar whole_archive_flag_spec
便利なアーカイバから共有ライブラリを生成するコンパイラフラグです.
@end defvar

@defvar wl
libtoolが直接リンカにフラグを渡すことを可能とするCコンパイラフラグです.
@code{$@{wl@}@var{some-flag}}として使用されます.
@end defvar

@samp{_cmds}や@samp{_eval}で終わる変数は,セミコロンで分けられた,順番に
@code{eval}されるコマンドのリストを含みます.ゼロ以外の終了ステータスを
返すコマンドがある場合,libtoolは一般的にエラーメッセージとともに終了し
ます.

@samp{_spec}で終わる変数は,libtoolで使用される前に@code{eval}されます.


@node Cheap tricks
@section 安っぽい手段

ここに,簡単にメンテナーシップを作成するために使用することが可能な,いく
つかの手段があります.

@itemize @bullet
@item
人々がバグを報告したとき,彼らを助けたいと思う場合は,@samp{--config},
@samp{--debug},または@samp{--features}フラグを使用したかどうかを尋ねて
ください.これらのフラグは,中古の調査を信頼しなければならない代わりに,
情報を直接得る手助けとなるものです.

@item
@code{ltconfig.in}や@code{ltmain.in}を変更するたび毎に再コンフィグレーショ
ンする代わりに,@var{PATH}に永久的な@code{libtool}スクリプトを持ち続け,
それは直接@code{ltmain.in}の基となります.

以下のステップは,そのようなスクリプトを作成する方法を記述し,そこでは
@code{/home/src/libtool}はlibtoolソースツリーを含むディレクトリ,
@code{/home/src/libtool/libtool}はプラットフォームに対し以前にコンフィグ
レーションしたlibtooolスクリプト,そして@code{~/bin}は@var{PATH}にあるディ
レクトリです.

@example
trick$ @kbd{cd ~/bin}
trick$ @kbd{sed '/^# ltmain\.sh/q' /home/src/libtool/libtool > libtool}
trick$ @kbd{cat >> libtool
LTCONFIG_VERSION="@@VERSION@@"
. /home/src/libtool/ltmain.in
^D}
trick$ @kbd{chmod +x libtool}
trick$ @kbd{libtool --version}
ltmain.sh (GNU @@PACKAGE@@) @@VERSION@@
trick$
@end example
@end itemize

@samp{libtool --version}コマンドの最終的な出力は,@code{ltmain.in}スクリ
プトが直接使用されていることを示します.@code{ltconfig}を再実行する必要
なく新しい変更をテストするため,すぐに,@code{~/bin/libtool}や
@code{/home/src/libtool/ltmain.in}を編集してください.


@page
@node Index
@unnumbered 索引

@printindex cp

@c summarycontents
@contents
@bye

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>