Merge branch 'master' into yaz-744
[yaz-moved-to-github.git] / README
diff --git a/README b/README
index 54241d1..3f26587 100644 (file)
--- a/README
+++ b/README
+YAZ toolkit
 
-Copyright (C) 1995-2000, Index Data ApS.
+Copyright (C) 1995-2014 Index Data.
 See the file LICENSE for details.
 
-Compilation and installation instructions for YAZ 
-  $Id: README,v 1.32 2000-11-23 10:58:32 adam Exp $
-
-The primary output of the source here is the lib/libyaz.a library,
-which contains support functions for implementing the server or client
-role of Z39.50.
-
-Windows programmers: refer to the file windows.txt which describes how
-to build the software using Microsoft Visual C++.
+The primary output of the source here is the YAZ library, which
+contains support functions for implementing the server or client
+role of Z39.50 and SRU.
 
 On Unix, GNU configure is used to configure YAZ and generate Makefiles.
-Type "./configure", then "make" to build YAZ.
-
-Two test-programs of interest are generated when you type 'make' at the
-top level: ztest/yaz-ztest and client/yaz-client. Ztest is a dummy
-database server which returns canned responses to all queries. It's good
-for verifying that the protocol works ok, and ztest.c shows an
-implementation of a 'backend' interface.
-
-yaz-client is a linemode Z39.50 client. It supports a fair amount of the
-functionality of Z39.50v2/SR, but some things you need to enable or
-disable by recompilation. Its primary purpose is to excersise the
-package, and verify that the protocol works OK. It can be started by
-typing
-
-  yaz-client tcp:<hostname>:<port>[/<database>]
-
-at the UNIX prompt, to connect to a Z39.50 server.
-
-Use '?' to get a list of the available commands.
-
-The current query language for the find command is a bit awkward, but
-functional:
-
- query     ::= ['@attrset' <attribute-set>] rpn
- rpn       ::= complex | simple | attr rpn
- complex   ::= operator rpn rpn
- operator  ::= '@and' | '@or' | '@not' | '@prox' proximity
- simple    ::= term | set.
- term      ::= <word> | '"' <term> ... '"'.
- set       ::= '@set' <setname>.
- attr      ::= '@attr' [<attribute-set>] <number> '=' <number>.
- proximity ::= exclusion distance ordered relation which unit
- exclusion ::= '1' | '0' | 'void'
- distance  ::= <number>
- ordered   ::= '1' | '0'
- relation  ::= <number>
- which     ::= 'known' | 'private'
- unit      ::= <number>
-
-Eg.:
-
- Andersen
-
- "Hans Andersen"
+Type "./configure", then "make" to build YAZ. Read
+doc/installation.unix.html for details.
 
- @and @attr 1=1 andersen @attr 1=4 @attr 4=2 duckling
+On Windows, a MS Visual Studio makefile is provided (nmake). The commands
+  cd \win
+  nmake
+should do. Refer to doc/installation.win32.html for details.
 
- @attrset Bib-1 @and @attr GILS 2=2008 Washington @attr 1=21 weather
+Note: If you are using the Git snapshot of YAZ you must have autoconf,
+automake, libtool and xsltproc installed. Before running configure, create
+support files by running buildconf.sh in the top-level directory of YAZ.  
 
-The sort command takes a sequence of sort specifications. A sort
-specification holds a field (sort criteria) and is followed by flags.
-If the sort critieria includes = it is assumed that the sort SortKey
-is of type sortAttributes using Bib-1. The integer before the = is
-the attribute type and the integer following the = is the attribute
-value. If no = is in the SortKey it is treated as a sortfield-type
-of type InternationalString. Flags observed are s (sort case
-sensitive), i (sort case insensitive), < (ascending), > (descending).
-Eg.:
-   1=4   i<                  (use is title, insensitive, ascending).
-   Title s>                  (String Title, sensitive, descending).
+In any case refer to the documentation in sub directory doc or read
+it online at http://www.indexdata.com/yaz/
 
-The directories:
+File organisation:
 
-doc     - Documentation.
+doc      Documentation.
 
-util    - Various little utility functions. Logging, memory debugging,
-       primitive ISO 2709 presentation for the yaz-client, etc. You'll
-       find the ASN.1 Compiler for YAZ here as well (yc.tcl).
+src      Source for the YAZ library.
 
-odr    - Open Data Representation. This module implements the BER
-       encoding rules. Documentation is found in the files odr-use.man
-       and odr.txt.
+util     Utility programs, ASN.1 compiler, MARC dump utility, and others.
 
-asn     - This module implements the Z39.50/SR protocol. The best way
-       to find out how it works is to look in the sample
-       client/server code in server/seshigh.c. The interface is still
-        wholly described by the file proto.h which defines structure
-        and type definitions for each of the types introduced in the
-        protocol specification.
+client   A demonstration client for testing the protocol. It's bug'n
+         ugly. But, it supports many features.
 
-z39.50  - This module implements the Z39.50 protocol. This module
-        does the same job as the 'asn' module except that the source
-        files are auto-generated using an YAZ' ASN.1 Compiler (YC).
+ztest    A demonstration server that implements a backend.
 
-zutil   - This module implements a collection of Z39.50 utilities, such
-        as query parsing, EXTERNAL handling, etc.
+etc      Various configuration files.
 
-ill     - This module implements the ISO ILL protocol.
-
-comstack - This module implements the transport transparency
-       stack (COMSTACK). The comstack implements a generic interface
-       for exchanging BER-encoded records over a network. It supports
-       the 'American' mode of exchanging the records straight over
-       TCP/IP, and uses Peter Furniss' XTIMOSI package over RFC1006.
-       Look for documentation in the file comstack.man.
-
-rfc1006 - Xtimosi requires an implementation of the OSI transport
-       layer with an XTI-based API. Some systems (HP and DEC,
-       notably) provide this. For others, we provide an
-       implementation of the RFC1006 protocol (which is what
-       ISODE-based implementations often use). This module is not
-       needed if you don't use xtimosi, and it's not included in the
-       libyaz.a library.
-
-server  - This is the implementation of the server frontend. It
-       provides event-handling and server managament functions,
-       and calls the backend primitives (best documentation of these
-       is in the file include/yaz/backend.h).
-
-client  - A demonstration client. If we come upon a good design for a
-       higher level client API, that will live here.
-
-ztest   - A demonstration server that implements a backend.
-
-include/yaz - The various header files.
-
-lib     - The libraries. Primarily libyaz.a. The makefile gathers the
-          libraries from previous modules into libyaz.a.
+include/yaz The various header files.
 
 To get more information or assistance, send mail to yaz-help@indexdata.dk.
-
-We maintain a mailing-list for the purpose of announcing new versions of
-the software, bug-reports, discussion etc. You can sign up by sending
-mail to yaz-request@indexdata.dk and include the following command
-command in your email:
-    subscribe yaz-l
+Even better, sign on to the YAZ mailing list here:
+http://lists.indexdata.dk/cgi-bin/mailman/listinfo/yazlist