Use proper tags for references to man pages
[yaz-moved-to-github.git] / doc / installation.xml
index 834358b..4f89d4d 100644 (file)
@@ -1,4 +1,4 @@
-<!-- $Id: installation.xml,v 1.7 2001-10-26 20:13:44 adam Exp $ -->
+<!-- $Id: installation.xml,v 1.13 2002-09-17 20:17:44 adam Exp $ -->
  <chapter id="installation"><title>Compilation and Installation</title>
   
   <sect1><title>Introduction</title>
@@ -22,7 +22,8 @@
        <listitem><para>HP/UX</para></listitem>
        <listitem><para>SunOS/Solaris</para></listitem>
        <listitem><para>DEC Unix</para></listitem>
-       <listitem><para>OpenBSD/FreeBSD</para></listitem>
+       <listitem><para>BSDs: FreeBSD, OpenBSD, NetBSD, MAC OSX
+        </para></listitem>
        <listitem><para>Linux</para></listitem>
        <listitem><para>IBM AIX</para></listitem>
        <listitem><para>Data General DG/UX (with some CFLAGS tinkering)
@@ -34,7 +35,7 @@
       <itemizedlist>
        <listitem><para>Apple Macintosh (using the Codewarrior programming
          environment and the GUSI socket libraries)</para></listitem>
-       <listitem><para>MS Windows 95/98/NT/W2K (Win32)</para></listitem>
+       <listitem><para>MS Windows 95/98/NT/2K/XP (Win32)</para></listitem>
        <listitem><para>IBM AS/400</para></listitem>
       </itemizedlist></listitem>
     </itemizedlist>
@@ -45,8 +46,8 @@
     let us know about it. If you run into difficulties, we will try to help
     if we can, and if you solve the problems, we would be happy to include
     your fixes in the next release. So far, we have mostly avoided
-    &num;ifdefs for individual platforms, and we'd like to keep it that
-    way as far as it makes sense.
+    <literal>&num;ifdefs</literal> for individual platforms, and we'd
+    like to keep it that way as far as it makes sense.
    </para>
    
    <para>
@@ -54,7 +55,9 @@
     bug-fixes, as well as general discussion. Subscribe by sending mail to
     <ulink url="mailto:yaz-request@indexdata.dk">
      yaz-request@indexdata.dk
-    </ulink>.
+    </ulink> or fill-in the form
+    <ulink url="http://www.indexdata.dk/mailman/listinfo/yazlist">
+     here</ulink>.
     General questions and problems can be directed at 
     <ulink url="mailto:yaz-help@indexdata.dk">
      yaz-help@indexdata.dk
    <para>
     Note that if your system doesn't have a native ANSI C compiler, you may
     have to acquire one separately. We recommend
-    <ulink url="http://gcc.gnu.org">GCC</ulink>.
+    <ulink url="http://gcc.gnu.org/">GCC</ulink>.
    </para>
    <para>
     For UNIX, the GNU tools
     <ulink url="http://www.gnu.org/software/autoconf/">Autoconf</ulink>,
     <ulink url="http://www.gnu.org/software/automake/">Automake</ulink> and
     <ulink url="http://www.gnu.org/software/libtool/">Libtool</ulink>
-    is used to generate Makefiles and configure &yaz; for the system.
+    are used to generate Makefiles and configure &yaz; for the system.
     You do <emphasis>not</emphasis> these tools unless you're using the
     CVS version of &yaz;.
     Generally it should be sufficient to run configure without options,
    </screen>
    
    <para>
-    To customize &yaz; the configure script also accepts a set of options.
+    To customize &yaz;, the configure script also accepts a set of options.
     The most important are:
     
     <variablelist>
         <ulink url="ftp://ftp.porcupine.org/pub/security/index.html">
          TCP wrapper library</ulink>. It allows you to allow/deny
         clients depending on IP number. The TCP wrapper library is
-        commonly used in Linux/BSD distributions.
+        often used in Linux/BSD distributions.
+        See
+        <citerefentry>
+         <refentrytitle>hosts_access</refentrytitle>
+         <manvolnum>5</manvolnum>
+        </citerefentry>
+        and 
+        <citerefentry>
+         <refentrytitle>tcpd</refentrytitle>
+         <manvolnum>8</manvolnum>
+        </citerefentry>.
        </para></listitem>
      </varlistentry>
      <varlistentry><term><literal>--enable-threads</literal></term>
        compilation.
        </para></listitem>
      </varlistentry>
+     <varlistentry><term><literal>--with-openssl</literal></term>
+      <listitem><para>&yaz; will be linked with the OpenSSL libraries and
+        an SSL COMSTACK will be provided. Note that SSL support is still
+        experimental.
+       </para></listitem>
+     </varlistentry>
+     <varlistentry><term><literal>--enable-shared</literal></term>
+      <listitem><para>The make process will create shared
+        libraries (also known as shared objects <filename>.so</filename>).
+        By default, no shared libraries are created -
+        equivalent to <literal>--disable-shared</literal>.
+       </para></listitem>
+     </varlistentry>
+     <varlistentry><term><literal>--disable-shared</literal></term>
+      <listitem><para>The make process will not create
+        static libraries (<filename>.a</filename>).
+        By default, static libraries are created -
+        equivalent to <literal>--enable-static</literal>.
+       </para></listitem>
+     </varlistentry>
     </variablelist>
     
    </para>
     <screen>
      make
     </screen>
-    
    </para>
    
    <para>
 
      <varlistentry><term><filename>lib/libyazthread.la</filename></term>
       <listitem><para>
-        When threading is supported/enabled by configure this GNU libtool
+        When threading is supported/enabled by configure this Libtool
         library is created. It includes functions that allows &yaz;
         to use threads.
        </para></listitem></varlistentry>
        </para></listitem></varlistentry>
      
      <varlistentry><term><filename>yaz-config</filename></term>
-      <listitem><para>A Bourne-shell script, generate by configure, that
+      <listitem><para>A Bourne-shell script, generated by configure, that
         specifies how external applications should compile - and link with
         &yaz;.
        </para></listitem></varlistentry>
         A simple shell implemented on top of the 
         <link linkend="zoom">ZOOM</link> functions.
         The shell is a command line application that allows you to enter
-        simple commands perform to perform ZOOM operations.
+        simple commands to perform ZOOM operations.
        </para></listitem></varlistentry>
 
      <varlistentry><term><filename>zoom/zoomtst1</filename>, 
        <filename>zoom/zoomtst2</filename>, ..</term>
       <listitem><para>
-        Several small applications that demonstrates the use of ZOOM.
+        Several small applications that demonstrates the ZOOM API.
        </para></listitem></varlistentry>
     </variablelist>
     
    </para>
    
    <para>
-    If you wish to install &yaz; in system directories such as 
+    If you wish to install &yaz; in system directories  
     <filename>/usr/local/bin</filename>,
-    <filename>/usr/local/lib</filename> you can type:
+    <filename>/usr/local/lib</filename> .. etc, you can type:
    </para>
    
    <screen>
    </para>
    
    <para>
-    If you wish to perform an un-installation of &yaz; use:
+    If you wish to perform an un-installation of &yaz;, use:
    </para>
    
    <screen>
     remove directories created by make install, e.g.
     <filename>/usr/local/include/yaz</filename>.
    </para>
-   
+
+   <sect2><title>How to make apps using YAZ on UNIX</title>
+    <para>
+     This section describes how to compile - and link your own
+     applications using the &yaz; toolkit.
+     If you're used to Makefiles this shouldn't be hard. As for
+     other libraries you have used before, you have to set a proper include
+     path for your C/C++ compiler and specify the location of
+     &yaz; libraries. You can do it by hand, but generally we suggest
+     you use the <filename>yaz-config</filename> that is generated
+     by <filename>configure</filename>. This is especially
+     important if you're using the threaded version of &yaz; which
+     require you to pass more options to your linker/compiler.
+    </para>
+    <para>
+     The <filename>yaz-config</filename> script accepts command line
+     options that makes the <filename>yaz-config</filename> script print
+     options that you should use in your make process.
+     The most important ones are:
+     <literal>--cflags</literal>, <literal>--libs</literal>
+     which prints C compiler flags, and linker flags respectively.
+     </para>
+    <para>
+     A small and complete <literal>Makefile</literal> for a C
+     application consisting of one source file,
+     <filename>myprog.c</filename>, may look like this:
+     <screen>
+      YAZCONFIG=/usr/local/bin/yaz-config
+      CFLAGS=`$(YAZCONFIG) --cflags`
+      LIBS=`$(YAZCONFIG) --libs`
+      myprog: myprog.o
+         $(CC) $(CFLAGS) -o myprog myprog.o $(LIBS)
+      </screen>
+     </para>
+    <para>
+     The CFLAGS variable consists of a C compiler directive that will set
+     the include path to the <emphasis>parent</emphasis> directory
+     of <filename>yaz</filename>. That is, if &yaz; header files were
+     installed in <filename>/usr/local/include/yaz</filename>,
+     then include path is set to <filename>/usr/local/include</filename>.
+     Therefore, in your applications you should use
+     <screen>
+      #include &lt;yaz/proto.h>
+     </screen>
+     and <emphasis>not</emphasis>
+     <screen>
+      #include &lt;proto.h>
+     </screen>
+    </para> 
+    <para>
+     For Libtool users, the <filename>yaz-config</filename> script provides
+     a different variant of option <literal>--libs</literal>, called
+     <literal>--lalibs</literal> that returns the name of the
+     Libtool acrhive(s) for &yaz; rather than the ordinary ones.
+    </para>
+    <para>
+     For applications using the threaded version of &yaz;,
+     specify <literal>threads</literal> after the
+     other options. When <literal>threads</literal> is given,
+     more flags and linker flags will be printed by
+     <filename>yaz-config</filename>. If our previous example was
+      using threads, you'd have to modify the lines that set
+     <literal>CFLAGS</literal> and <literal>LIBS</literal> as
+     follows:
+     <screen>
+      CFLAGS=`$(YAZCONFIG) --cflags threads`
+      LIBS=`$(YAZCONFIG) --libs threads`
+     </screen>
+     There is no need specify POSIX thread libraries in your Makefile.
+     The <literal>LIBS</literal> variable includes that as well.
+    </para>
+   </sect2>
   </sect1>
   <sect1 id="installation.win32"><title>WIN32</title>
    
     is located. Customize the installation by editing the
     <filename>makefile</filename> file (for example by using notepad).
     
-    The following summarises the most important settings in that file:
+    The following summarizes the most important settings in that file:
 
     <variablelist>
      <varlistentry><term><literal>DEBUG</literal></term>
     </variablelist>
    </para>
    <para>
-    When satisfied with the settings in the makefile type
+    When satisfied with the settings in the makefile, type
     <screen>
      nmake
     </screen>
        Z39.50 multi-threaded test/example server. It's a WIN32
         console application.
        </para></listitem></varlistentry>
-
+     
      <varlistentry><term><filename>bin/zoomsh.exe</filename></term>
       <listitem><para>
         Simple console application implemented on top of the
         The application is a command line shell that allows you to enter
         simple commands perform to perform ZOOM operations.
        </para></listitem></varlistentry>
-
+     
      <varlistentry><term><filename>bin/zoomtst1.exe</filename>, 
        <filename>bin/zoomtst2.exe</filename>, ..</term>
       <listitem><para>
-        Several small applications that demonstrates the use of ZOOM.
+        Several small applications that demonstrates the ZOOM API.
        </para></listitem></varlistentry>
-
+     
     </variablelist>
     
    </para>
+   <sect2><title>How to make apps using YAZ on WIN32</title>
+    <para>
+     This section will go though the process of linking your WIN32
+     applications with &yaz;.
+    </para>
+    <para>
+     Some people are confused by the fact that we use the nmake
+     tool to build &yaz;. They think they have to do that too - in order
+     to make their WIN32 applications work with &yaz;. The good news is that
+     you don't have to. You can use the integrated environment of
+     Visual Studio if desired for your own application.
+    </para>
+    <para>
+     When setting up a project or Makefile you have to set the following:
+     <variablelist>
+      <varlistentry><term>include path</term><listitem><para>
+         Set it to the <filename>include</filename> directory of &yaz;.
+        </para></listitem></varlistentry>
+      <varlistentry><term>import library <filename>yaz.lib</filename>
+       </term><listitem><para>
+         You must link with this library. It's located in the 
+         sub directory <filename>lib</filename> of &yaz;.
+        </para></listitem></varlistentry>
+      <varlistentry><term>dynamic link library <filename>yaz.dll</filename>
+       </term><listitem><para>
+         This DLL must be in your execution path when you invoke
+         your application. Specifically, you should distribute this
+         DLL with your application.
+        </para></listitem></varlistentry>
+     </variablelist>
+    </para>
+   </sect2>
   </sect1>
  </chapter>