4d01a8b7366c1e8c97a6ce503aeda6a305f25160
[yaz-moved-to-github.git] / CHANGELOG
1 Possible compatibility problems with earlier versions marked with '*'.
2
3 OPAC support ZOOM. ZOOM_record_get returns OPAC info (as XML) if
4 type is "opac".
5
6 Add three new utility functions for translating OIDs between various
7 formats -- symbolic name such as "Usmarc", minus-1-terminated int
8 arrays and dotted strings such as "1.2.840.10003.9.5.1":
9  int *oid_name_to_oid(oid_class oclass, const char *name, int *oid);
10  char *oid_to_dotstring(const int *oid, char *oidbuf);
11  char *oid_name_to_dotstring(oid_class oclass, const char *name, char *oidbuf);
12
13 Reverted modifications for ES Update definition for z_IU0Update 
14 (OID 1.2.840.10003.9.5.1 and 1.2.840.10003.9.5). The definition
15 is back to YAZ 2.0.2.
16
17 String value attributes for CCL parser.
18
19 --- 2.0.3 2003/06/20
20
21 Fix CCL directive @case handling so that it affects string match for
22 both CCL keywords and qualifiers.
23
24 * ESFormat-Update updates. Packages with OID 1.2.840.10003.9.5.1 and
25 1.2.840.10003.9.5 are now handled by the same decoder z_IU0Update .
26 Decoder has been updated with ASN.1 changes as listed in
27 http://lcweb.loc.gov/z3950/agency/defns/updateES.html
28 Note that the "latest" DB Update, OID 1.2.840.10003.9.5.1.1 , handler
29 z_IUUpdate, remains unchanged. 
30
31 ZOOM_record_get may now return a record in a specific character set.
32 For type use "form; charset=from[,to]" where form (render, xml, ..) ,
33 "from" is the character set of record as returned by target. "to" is
34 the character set to be returned. If omitted, "to" is UTF-8.
35
36 YAZ ASN.1 compiler renamed from yaz-comp to yaz-asncomp
37
38 New ODR utility, odr_getelement, which returns name of element for
39 which encoding/decoding failed.
40
41 Fixed ODR so that it returns error code OREQUIRED rather than ONONE
42 in cases where a required element was omitted.
43
44 Bug fix: some MARC8 sequences were not converted.
45
46 New ZOOM option "step" which specifies number of records to be
47 retrieved in one chunk. Used in conjunction with "start" and "count".
48
49 SRW support for yaz-client. Use scheme http: to use it, e.g.
50  http://host:port/db
51
52 yaz-client no longer does (un)intelligent character set conversions
53 by default. Can be enabled with charset and marc_charset commands.
54
55 xmalloc trace fix for 64-bit systems such as DEC alpha. 
56
57 Solaris 2.6 compile fix.
58
59 New function, cql_strerror() translates SRW error codes, as returned
60 by cql_transform_error(), into human-readable English strings.  Used
61 in yaz-client diagnostics when appropriate.
62
63 New CQL2RPN query-type for the command-line yaz-client, parses CQL and
64 converts it into a type-1 query which is sent to the server.  This
65 makes CQL available for use with all Z-servers, as opposed to the tiny
66 minority that can handle CQL queries themselves.
67
68 --- 2.0.2 2003/04/28
69
70 New Debian package layout similar to the Redhat Package layout.
71
72 New ZOOM events ZOOM_EVENT_RECV_{RECORD,SEARCH} for receiving a record
73 and search result respectively.
74
75 --- 2.0.1 2003/04/25
76
77 Redhat package is now several packages: libyaz (runtime libraries),
78 libyaz-devel (development and documentation, and yaz (utility programs).
79 Package spec file by Morten Bøgeskov.
80
81 New member 'schema' in struct bend_fetch_rr which the name of requested
82 schema (SRW/SRU) for record (or NULL if none was given). The fetch
83 handler MAY set this to reflect the schema of the returned record.
84
85 New member 'display_term' in struct scan_entry. GFS now sets member entries
86 and allocates scan entries to be filled by user scan handler. In previous
87 version, entries member was allocated by the scan handler. That still works,
88 but the GFS will ignore member display_term - assuming it was NOT set by
89 the handler. The fact that the GFS now allocates the entries both allows
90 for new members and makes a scan handler easier to write.
91
92 Fix CQL lex buffer overflow.
93
94 SRW/SRU recordPacking. For SRW default recordPacking is string. For
95 SRU default recordPacking is string.
96
97 SRU protocol support for frontend server.
98
99 Fix compile bug for systems that have nl_langinfo but CODESET undefined.
100
101 Added missing PQF transform rules for <= and >= . Thanks to Peter Popovics.
102
103 Added scan for the ZOOM shell (zoomsh).
104
105 --- 2.0 2003/02/23
106
107 * String Identifers for Schemas (Amendment 5).
108 http://lcweb.loc.gov/z3950/agency/amend/am5.html
109 Old definition for schema
110   Odr_oid *schema; /* OPT */
111 New:
112   int which;
113   union {
114      Odr_oid *oid;
115      Z_InternationalString *uri;
116   #define Z_Schema_oid 1
117   #define Z_Schema_uri 2
118   } schema; /* OPT */
119
120 * resultCount parameter to Sort Response (Amendment 1).
121 http://lcweb.loc.gov/z3950/agency/amend/am1.html
122
123 Support for SRW 1.0 over HTTP. This is an optional feature and
124 requires libxml2 to operate. Enable SOAP by specifying --with-xml2
125 for configure.
126
127 Generic frontend server supports HTTP/SOAP/SRW and Z39.50/BER
128 on the same port.  SRW SearchRetrieveRequests are mapped
129 to bend_init,bend_search,bend_fetch,bend_close. 
130
131 Z39.50 Query Type-104 added - to facilitate CQL within Z39.50.
132
133 CQL support. Source is directory 'cql'. CQL is supported in ZOOM
134 (both SRW and Z39.50) and the YAZ client (Z39.50 only).
135
136 ZOOM connections are SRW based if schem http is used for hostname
137 in connect, e.g.  z = ZOOM_connection_new("http://myserver");
138 ZOOM_query may be of type CQL, e.g. ZOOM_query_cql(q, "dc.title=x");
139
140 CCL proximity operators !n, %n converts to PQF @prox 0 n 1 2 k 2
141 and @prox 0 n 0 1 k 2 respectively, meaning: exlusion=false,
142 distance=n, order=true/false, relation=le, prox unit=word. If
143 n is omitted, distance 1 is used.
144
145 Fixed problem with C compiler include path in wrong order.
146
147 For TCP/IP COMSTACK, set recv buffer to an appropriate "large" value
148 on Solaris. Patch from Ko van der Sloot.
149
150 New MARC decode API. All new functions operate on a yaz_marc_t
151 handle. The most important new functions are: yaz_marc_create,
152 yaz_marc_decode_{buf,wrbuf}, yaz_marc_destroy, .. to create handler,
153 decode and destroy respectively. Decoder can produce formats
154 MARC line, simple XML, OAI MARC and MARC XML (LoC). See
155 include/yaz/marcdisp.h.
156
157 YAZ Iconv utility now supports MARC8 decoding (marc8.c). Converts
158 to UTF-8, UCS-32, wchar_t or Latin-1.
159
160 * Prototypes for yaz_iconv_-functions moved to separate header 
161 include/yaz/yaz-iconv.h.
162
163 Make a few private functions 'static' in unix.c. This prevents
164 duplicate unix_close in PHP with YAZ and imap. PHP Bug 20977.
165
166 For ZOOM connection, the options targetImplementation{Id,Name,Version}
167 are set when Init Response is received.
168
169 New function ZOOM_connection_error_x similar to ZOOM_connection_error
170 but returns diagnostic set as well.
171
172 New function yaz_strerror which is a portable wrapper for
173 strerror/strerror_r/GetLastMessage.
174
175 * ZOOM_record_get supports type "xml" in which case MARC XML (from LOC)
176 is returned for MARC. If type is "oai", then OAI MARC is returned.
177
178 Fix creation of lib/yaz-config so it works if srcdir != objdir. Patch
179 from Kang-Jin Lee.
180
181 --- 1.9.2 2002/11/26
182
183 yaz_marc_decode uses OAI MARC as XML format for ISO2709 records.
184
185 Fix bad race conditions on SIGTERM and terminate gracefully in
186 frontend server.
187
188 Move retrieval (data1) module to Zebra since nobody seems to be
189 using it.
190
191 Add GRS-1 render for ZOOM using same format as yaz-client.
192
193 --- 1.9.1 2002/10/05
194
195 Added man pages: yaz-client(1), yaz-ztest(8), yaz(7), zoomsh(1).
196
197 Fix broken ESpec handling in data1 module.
198
199 SGML reader parses comments and makes them part of the data1 tree.
200
201 Added several type casts so that YAZ compiles as C++ code.
202
203 ZOOM didn't handle PDU encoding failures properly.
204
205 Added more Bib-1 diagnostics (approved extensions).
206
207 GNU configure: better check for iconv.
208
209 More portable use of accept, getpeername. Check for socklen_t. Use
210 int/size_t if socklen_t is not defined.
211
212 --- 1.9 2002/09/06
213
214 PQF parser rejects bad queries - including those with extra
215 characters in them. PQF parser used to silently ignore that.
216 Cleaner API for PQF added, which allows you to get detailed
217 error information for bad queries (see yaz/pquery.h).
218
219 Fixed bug in ZOOM_record_get for type "database".
220
221 Implemented mini iconv library supporting conversions between
222 UTF-8, UCS4, UCS4LE and ISO-8859-1. Implemented in util/siconv.c.
223
224 * Removed XML reader (d1_expat.c). It's part of Zebra instead.
225
226 --- 1.8.9 2002/08/20
227
228 Fixed ZOOM C record cache so that preferredRecordSyntax and
229 elementSetName is used to check for already fetched records.
230
231 --- 1.8.8 2002/08/02
232
233 Added three members in bend_initrequest structure to facilitate
234 character set negotiation.
235
236 Fixed a bug in frontend server that could cause indefinite
237 loops under rare conditions. 
238
239 Revised character set utilities (charneg.h) so that encoding
240 UCS-4, UCSA-4, UTF-16 and UTF-8 are encoded non-privately.
241
242 For PQF, directive @term <type> sets term type for Scan/Search.
243 Here <type> is general, string, numeric, null. The term type
244 is inherited - just like @attr.
245
246 New call odr_set_charset that sets character set conversion for
247 international-strings on a ODR stream. Prototype is:
248  int odr_set_charset(ODR o, const char *to, const char *from);
249 The InternationalString is still represented as C string in YAZ 
250 so native strings of type UTF-8, ASCII, etc. will work (UTF-16
251 won't). On the protocol level, you can use any encoding.
252
253 Support for UNIX sockets in ZOOM.
254
255 Solaris recv sometimes returns errno == ENOENT. It is treated as
256 EINPROGRESS. COMSTACK patch by Ko van der Sloot.
257
258 New COMSTACK of type UNIX Socket. Use "unix:/path" as address for
259 both client and server. Code by Morten Bøgeskov.
260
261 --- 1.8.7 2002/05/22
262
263 On Windows ZOOM functions are of type __stdcall rather than __cdecl, so
264 that they can be used directly from Visual Basic. You must recompile
265 your windows APP if you're using ZOOM.
266
267 Character Set and Language Negotiation(3) for ZOOM API and YAZ client.
268 Commands "lang" and "charset" sets language and character set respectively.
269 Options "lang" and "charset" is interpreted by the ZOOM API. Note, these
270 are not part of the official ZOOM spec) All is due to Oleg Kolobov. 
271
272 Attributes from multiple CCL fields may be OR'ed rather than merged
273 using directive "@field or". Fields are still merged by default -
274 equivalent to "@field merge".
275
276 Fixed bug in ZOOM connect that occurred on OpenBSD (maybe others). Patch
277 by Oleg Kolobov.
278
279 Fixed bug in zget for parameter ExtendedServicesResponse.
280
281 Fix OID for ILL.
282
283 --- 1.8.6 2002/03/25
284
285 Added PQF feature: '@attr type=value' may be written as '@type=value'.
286
287 Client displays USR.1:SearchResult-1 (hits per term).
288
289 Additional Search Info for search in Generic Frontend Server.
290
291 Fixed CCL parsing of "field=s".
292
293 WIN32 installer - using the excellent NSIS software from nullsoft.
294
295 Fixed CCL parsing of "field = - <number>".
296
297 Added function yaz_marc_decode that decodes MARC for line mode
298 display or XML (similar to that used by JZKit).
299
300 Fixed BER decoding of OPTIONAL CHOICE. The bug didn't affect the
301 Z39.50. But ISO/ILL was, however.
302
303 Added patch by Rustam T. Usmanov that implements Z39.50 duplicate
304 detection service (Z39.50-1995 Amendment 2) and Language Negotiation (3).
305 See:
306  http://lcweb.loc.gov/z3950/agency/amend/am2.html
307  http://lcweb.loc.gov/z3950/agency/defns/charneg-3.html
308
309 --- 1.8.5 2002/02/03
310
311 New YAZ client features: Command completion and new commands:
312 push_command, set_apdufile, set_marcdump, set_cclfields, register_oid.
313 Code provided by Jacob Poulsen.
314
315 New call oid_trav, that visits all registered OIDs via callback.
316
317 Function ZOOM_record_get now returns const char pointer rather than
318 void pointer. It saves a lot of type casts.
319
320 For YAZ client, command "auth" now allows you to set authentication
321 in IdPass style. It is enabled when three tokens are given - order
322 is user, group and password.
323
324 Fix memory leaks in MARC record handling for ZOOM.
325
326 New option for YAZ client, -k <kilobytes> that sets
327 maximum record size. Similar to -k option for generic frontend
328 server and yaz-ztest.
329
330 More fixes for scan. Non-zero stepSize handled. OID's fixes.
331
332 Prefix query parser reports "fail" when bad attribute set is given.
333
334 Fix in MARC decoder. Proximity logging. Fix for attribute set
335 in scan handler for server. Patches by Shigeru Ishida.
336
337 SSL/COMSTACK updates. cs_rcvconnect completes SSL handshake. ZOOM
338 works with SSL.
339
340 Configure option --with-openssl=<dir> now works when a directory is
341 specified. Patch provided by Morten Bøgeskov.
342
343 New option for YAZ client, -u <auth>, that sets authentication.
344
345 ZOOM fix: error information was sometimes "missing", since error
346 was cleared/reset too when it shouldn't.
347
348 ZOOM_record_get returns ISO2709 buffer when "raw" is given.
349
350 --- 1.8.4 2002/01/04
351
352 Scan for ZOOM API. New object ZOOM_scanset. New functions
353 ZOOM_connection_scan, ZOOM_scanset_size, ZOOM_scanset_term and
354 ZOOM_scanset_destroy.
355
356 New ZOOM function, ZOOM_connection_last_event, that returns type
357 of last event (such as "receive data", "send data", "apdu received",
358 etc.
359
360 New ZOOM option, schema, that specifies schema for retrieval.
361
362 New CCL feature. Qualifiers can be aliases for one or more
363 other qualifiers (if more than one is given, OR is used).
364
365 ZOOM uses named result sets if target supports it.
366
367 Two new YAZ client commands: .  (dot, which sources a script of YAZ
368 client commands), and ! (to execute shell command.). Implemented
369 by Jacob Poulsen.
370
371 Working on Debian packages.
372
373 --- 1.8.3 2001/11/19
374
375 YAZ client enables named result sets only if target supports it.
376
377 *** ZOOM. Prefix for ZOOM definitions changed from Z3950_ to ZOOM_.
378
379 * ZOOM. Removed Z3950_connection_host. Use Z3950_connection_option_get
380 with key="host" to get same result.
381
382 * ZOOM. Added Z3950_record_clone and removed Z3950_resultset_get.
383 Function Z3950_resultset_record(s) returns references to records
384 "owned" by resultset. To become owner use Z3950_record_clone.
385
386 Function z_ext_record handles Extended Services. Thanks to
387 Irina Dijour.
388
389 --- 1.8.2 2001/11/12
390
391 CCL Parser fix: ignore token comma when dealing with and-lists.
392
393 Documentation updates for COMSTACK.
394
395 * ZOOM changes. Query object renamed from Z3950_search to Z3950_query.
396 Changed prototype Z3950_records. For some functions, int parameters
397 were changed to size_t.
398
399 TCP/IP COMSTACK no longer uses getprotobyname to avoid memory leak
400 on some Unices.
401
402 New MARC decode/display function, marc_display_exl, which properly rejects
403 non-ISO2709 records. YAZ client uses it.
404
405 --- 1.8.1 2001/10/29
406
407 Fix bug: local attribute set wasn't set correctly in PQF strings.
408
409 --- 1.8 2001/10/25
410
411 * Old Z39.50 codecs no longer supported. 
412
413 Added ZOOM C binding. See http://zoom.z3950.org/
414
415 Renamed states for COMSTACKs to avoid confusion with events.
416
417 Implemented cs_look and proper cs_rcvconnect.
418
419 Fixed COMSTACK error that occurred on HPUX. Fix by Giannis Kosmas.
420
421 Configure detects POSIX threads on OpenBSD.
422
423 When sort flag 'i' was specified in yaz-client the caseSensitivy flag
424 was set to a wrong value.  Thanks to Robert Sanderson for reporting this.
425
426 When error is returned from present handler, non-surrogate diagnostic
427 is returned in present response (and fetch handler is no longer called).
428
429 * Minor adjustments to pquery parser (PQF). Token characters may be
430 escaped by using backslash (C-style).
431
432 PQF parser allows string attribute values to be specified. For @attr,
433 non-numeric characters after the equal-sign are treated as strings
434 (e.g. @attr 9=title).
435
436 CCL trunction character may be defined (@truncation in file)
437
438 * function zget_ExtendedServicesRequest sets waitAction to
439   waitIfPossible (was wait).
440
441 Added cs_set_blocking to set change blocking mode of a COMSTACK. Thanks
442 to Matthew Carey.
443
444 CCL operator names may be set in field definition files (CCL_bibset).
445 See ccl/bib1 for an example.
446
447 Fixes in ASN.1 compiler for C++ compatibility.
448
449 * Renamed members "and" and "or" in struct Z_Operator to "op_and"
450 and "op_or" to avoid conflict with C++.
451
452 Fixed problem with GNU readline detection on Redhat 7.0.
453
454 Added step-size for Scan backend handler.
455
456 Fixed bug that made the frontend server crash when no attribute
457 set was specified for scan.
458
459 Front-end server automatically switches to original working directory
460 when installed as an NT service. Previously -w had to be specified to
461 make it work.
462
463 Added extended attributes for retrieval module (data1), so that data1
464 records carry d1_readXML/SGML attributes. d1_read also supports
465 null-data rules ( <tag/>)
466
467 On UNIX when POSIX threads are available, a separate library libyazthread
468 is created. Programmers should link with that library and the yaz library
469 when using threads. The reason for the split was that some applications
470 on Linux, such as Apache, doesn't work well when using shared objects that
471 relies on threads.
472
473 Added SSL support for the COMSTACK. You start yaz-client and yaz-ztest
474 (or any frontend server) in SSL mode by specifying ssl: followed by
475 address. Only tested on UNIX.
476
477 Added feature for CCL module. Virtual structure s=al or s=ol generates
478 and-list and or-list respectively instead of phrase search.
479
480 Added some OID's.
481
482 * Added prefix "yaz_" for the functions log_init.., log_file..  and
483 log_mask_str. This was done to avoid name conflicts with other libraries
484 (such as other PHP extensions).
485
486 Added raw OID member for preferred record syntax (request_format_raw)
487 and returned record syntax (output_format_raw) for backend fetch method.
488
489 Config file yaz-config now accepts options so that it returns specific
490 compile settings, etc. Thanks to Morten Bøgeskov <morten@bogeskov.dk>
491
492 Shared library support for UNIX using GNU libtool.
493
494 * Modified backend interface. Request/Response struct's replaced by
495 one read/write C struct. For example bend_fetchrequest and
496 bend_fetchresult have been replaced by single bend_fetch_rr struct.
497 Every handler - even search has to be registered in bend_init
498 handler. This means that the YAZ library no longer refers to
499 external functions and it makes it possible to make the whole
500 thing a single DLL/SO.
501
502 Added Segment handler for backend server.
503
504 Added Zmbol/Zebra administrative functions to YAZ client.
505
506 Threaded frontend server on UNIX (when POSIX Threads are available).
507 Starting the server with option -T enables multi-threading.
508
509 --- 1.6 2000/03/03
510
511 Added configure option --enable-comp/disable-comp to control use
512 of YAZ ASN.1 compiler. Use --disable-comp to use the old *coders
513 located in sub directory asn.
514
515 YAZ ASN.1 compiler renamed to yaz-comp in sub directory. It's installed
516 in ${exec_prefix}/bin along with the other programs yaz-client and
517 yaz-ztest.
518
519 GNU automake used to maintain makefiles.
520
521 Added several OID's.
522
523 Changed retrieval module so that we can load records with no abstract
524 syntax defined. Tagpaths in these records are fully composed of string
525 tags.
526
527 Implemented ISO ILL protocol. Refer to stuff in sub directory ill.
528
529 --- 1.5 1999/12/10
530
531 On UNIX, the generated makefile now supports a proper 'make install'.
532 The prefix can be set via GNU configure to set the install location
533 (default is /usr/local).
534
535 * YAZ programs client and ztest were renamed to yaz-client and
536 yaz-ztest to avoid conflicts when users install YAZ in "standard"
537 locations, such as /usr/bin,/usr/local/bin,etc.
538
539 * YAZ Header files were moved from include to include/yaz. YAZ Header
540 files are referred to as include <yaz/log.h> rather than <log.h>.
541 The YAZ include path (-I ..) is therefore the same as before. Programmers
542 should update their #include statements or use -Ipath/include/yaz
543 instead. The main motivation for doing this change is that YAZ header files
544 can be installed in "standard" locations /usr/include,/usr/local/include 
545 without introducing conflicts, since ALL YAZ header files are stored
546 in subdirectory yaz (under /usr/include for example).
547
548 Compilation of YAZ for WIN32 is now handled by an nmake-style makefile 
549 rather than project/workspace files. We switched because project files
550 are incompatible between Visual C++ 5 and 6. Refer to windows.txt for
551 details.
552
553 Changed name of logging function, logf, to yaz_log, to prevent name
554 clash with some math-log functions. The YAZ header log.h defines logf
555 to yaz_log (#define) so there should be no incompatibilities by this
556 modification.
557
558 Added bend_start/bend_stop handlers for server. These handler are
559 called on start/stop of server. For windows they are called whenever
560 a service is started/stopped.
561
562 * YAZ now auto-generates decoders/encoders for the Z39.50 protocol using
563 a fairly small ASN.1 compiler written in Tcl. The compiler is located
564 in util/yc.tcl. The auto-generated C code structures are, in a few
565 cases, incompatible with the old decoders. There are differences in the
566 following C structures Z_DiagRec, Z_External, Z_SortRequest, Z_SortResponse,
567 Z_AttributesPlusTerm, Z_ProximityOperator, Z_DefaultDiagFormat.
568 The preprocessor variable ASN_COMPILED is defined when the compiled
569 ASN.1 is being used. Encoder/decoder routines as well as the Z39.50
570 protocol ASN.1 is located sub directory <tt>z39.50</tt>. If you
571 wish to use the old encoders/decoders you can specify --disable-yc
572 for configure.
573
574 Assigned OID for old DB Update (VAL_DBUPDATE0). Updated YAZ compiled
575 version so that it supports both new - and old version of DB Update
576
577 * Added 'name' parameter to ODR encoder/decoder routines to facilitate
578 pretty ODR print. Updated whole Z39.50 encoder/decoder to reflect the
579 change. The name parameter can be set to 0 in which no name is specified
580 for the construction. The macros odr_implicit and odr_explicit sets name
581 parameter to zero for the construction involved. New macros
582 odr_implicit_tag and odr_explicit_tag are similar to the others,
583 except that a name parameter is added. For programmers' that don't use
584 ODR they probably only need to change the call to z_APDU and z_External.
585
586 Added access control facility by interfacing the TCP wrapper library.
587 YAZ automatically attempts to find the TCP wrapper Library (-lwrap) and
588 tcpd.h on Unix systems. For the server, option -d<daemon> specifies the
589 name of the daemon and enables the access control as specified in
590 hosts.allow/hosts.deny. Refer to man pages tcpd(8) and hosts_access(5).
591
592 Fixed memory leak in ccl_find_str and ccl_qual_rm. Thanks to Hans van
593 den Dool <H.M.vdnDool@kub.nl>.
594
595 Added reference ID parameter to most functions in server API - refer
596 to backend.h. Thanks to Hans van den Dool <H.M.vdnDool@kub.nl>.
597
598 Changed name of ccl library to libccl.a (was ccl.a).
599
600 Fixed bug in decoder for Explain (Category TargetInfo).
601
602 Added support for GNU readline in client. Thanks to Jacob Poulsen
603 <ja7@dbc.dk>. GNU configure attempts to detect if readline is available.
604
605 * CHANGED DEFINITION OF ES: UPDATE (INCLUDING THE OID) to reflect the
606 new definition from the ZIG. NOTE THIS IF YOU HAVE AN UPDATE
607 IMPLEMENTATION! This change was made to the development version before
608 the ZIG decided to retract the amendment. If any users MUST be
609 compatible with the original Update definition, PLEASE CONTACT US, and
610 we will include a separate definition corresponding to the old Update
611 ES. Note that because of the change to the ASN.1 of the
612 TaskPackageRecordStructure we cannot define a single structure that
613 will support both versions.
614
615 * Added const modifier to buffer parameter for some ODR/BER encoding
616 routines: ber_dectag, ber_declen, odp_more_chunks, completeBER,
617 completeWAIS, odr_dumpBER.
618
619 Fixed bug in client.c which caused a crash when a scanResponse didn't
620 contain positionOfTerm.
621
622 * Fixed inconsistency in the ScanResponse/ListEntries protocol. This
623 * will cause an error in a client if a non-YAZ target sends both a
624 * list of Scan entries and non-surrogate diagnostics.
625
626 Retrieval module enhancements. Tag sets may be typed in the reference
627 to it. From the .abs-file the "tagset" directive takes a third optional
628 integer type for the tag set referenced. From a .tag-file the "include"
629 directive takes a third optional type as well. The old "type" directive
630 in the tag set itself is still recognized but acts as the default type
631 for the tag set.
632
633 Backend interface change. Individual Scan terms returned from bend_scan
634 may also be tagged as Surrogate Diagnostics. Refer to struct scan_entry
635 in include/backend.h.
636
637 Retrieval module enhancements. Multiple tag sets and attribute sets may
638 be specified in abstract syntax specs. Revised the error/warning for
639 logging messages reported by the retrieval module when reading the
640 various spec files.
641
642 Object Identifier system (oid_..) changed. The API is backwards
643 compatible but the oid-routines now allocates new OID's when needed.
644 Raw OID's may be specified in oid_getvalbyname.
645
646 YAZ now uses GNU configure to generate Makefile(s).
647
648 * Minor changes in some of the member names of DeleteResultSetRequest and
649 DeleteResultSetResponse. See include/proto.h.
650
651 * Changed some C definitions regarding EXPLAIN record syntax (prt-exp.h)
652 and added member 'languages' in TargetInfo (which was missing).
653
654 Changed the way attribute sets are handled in the retrieval
655 module. These are now cached, just like the abstract syntaxes
656 (schemas).
657
658 Changed YAZ so that it links with compiled ASN.1.
659
660 Added Explain-schema definitions and mapping routines. The following
661 Explain categories have been implemented: AttributeDetails,
662 AttributeSetInfo, DatabaseInfo, CategoryList and TargetInfo.
663
664 Fixed minor bug in Windows version of Server Library.
665
666 --- 1.4pl2+ 1998/4/17 (Released with Zebra)
667
668 Added Extended Services to server (backend.h). Thanks to Charles Woodfield.
669
670 Added EXTERNAL: UNIverse Resource Report (non-standard).
671
672 Implemened odr_enum and odr_set_of functions to handle ASN.1 types
673 ENUMERATED and SET OF.
674
675 * Added 'const' to some of the char pointer arguments for the
676 functions, data1_read_node, data1_getelementbytagname,
677 data1_insert_taggeddata, data1_getesetbyname, data1_getelementbyname,
678 data1_get_absyn.
679
680 Fixed bug in data1_insert_taggeddata - the last_child member of
681 parent wasn't initialised.
682
683 * Changed data1_read_record and data1_read_node so that the supplied
684 "SGML"-buffer is read-only. In particular the resulting data1 - tree
685 doesn't refer to any parts of the "SGML"-buffer.
686
687 Fixed bug in server library (Windows version of statserv_remove).
688
689 * Changed code so that it compiles as C++. The type definition
690 of Odr_fun which is a member of Odr_arm was changed. The result is,
691 that an explicit typecast is needed for the fun pointer when
692 using Odr_arm - as in:
693     {1, -1, -1, Z_IdAuthentication_idPass, (Odr_fun)z_IdPass},
694
695 Updated TagSet-G and -M definitions (tagsetm.tag and tagsetg.tag).
696
697 Implemented the new structured date and time definition as approved
698 by the ZIG. Added schemaId element to the specificTag in Espec-1
699 (also approved at the last ZIG). Thanks to RVDM.
700
701 Added some Object identifiers (RVDM).
702
703 Changed the Update Extended Service (RVDM).
704
705 Added command "refid" to client which specifies referenceId for
706 the following requests.
707
708 Implemented extended service handling for server. See ztest.c
709 for an example as well as backend.h. New handlers are registerd
710 in the Init handler.
711
712 * Changed interface for sort in server.
713
714 Added new members to statserv_options_block. It allows a server
715 to read options from another source than just the command line. Thanks
716 to Charles Woodfield.
717
718 * Changed definition of Z_Triple in file prt-grs.h - member boolean
719 renamed to zboolean. Some C++ compilers complained about the name.
720
721 Minor changes to gils.abs. Added index 's' (sort) on title
722 and date/time-last-modified.
723
724 --- 1.4pl2 1998/1/30
725
726 Fixed bug in server library regarding inetd mode (-i). This bug
727 was introduced by release 1.4.
728
729 --- 1.4pl1 1998/1/29
730
731 Added sort facility in client and backend server interface.
732
733 Fixed problem with dependencies in Makefile(s).
734
735 Fixed bugs for encoders/decoders of extended services and 
736 SearchInfoReport.
737
738 Implemented sub-tree feature for schemas. Sub-trees are
739 referenced in *.abs-files. See explain.abs for an example
740 of the use of this feature.
741
742 Modified bib1.att; local attributes for ANY didn't include
743 ANY itself (only affects use of the retrieval module).
744
745 Fixed bug in plain SGML reader in function data1_read_node:
746 tags with prefix "var" was incorrectly interpreted as variants.
747
748 Added feature "sub-schemas" to enable references to - and definitions
749 of - group of elements.
750
751 * Removed member parent from type data1_element (in data1.h).
752
753 Implemented function odr_nullval() that returns the value of
754 ODR_NULLVAL.
755
756 * Removed member num_children from data1_node (in data1.h).
757
758 Made NT service interface part of the server library. The
759 function statserv_main uses the NT service when required and
760 calls the statserv_start / statserv_close routines.
761
762 Routine zget_SearchRequest and zget_PresentRequest fills
763 resultSetName/Id member with "default" instead of "Default".
764
765 Fixed memory leak in server. Request queue member wasn't freed.
766
767 Fixed nmem_exit so that memory is freed.
768
769 --- 1.4 1997/10/2
770
771 Revised the CCL parser utility to be thread safe.
772
773 Added function, oid_ent_to_oid, to replace the function 
774 oid_getoidbyent, which is not thread safe.
775
776 * Added nmem_init and nmem_exit to initialize and release
777 NMEM resources. Function nmem_init should be called once in the
778 initial thread before NMEM/ODR is used. statserv.c and client.c
779 have been changed accordingly. The change was necessary to make
780 NMEM thread safe. The NMEM memory pool is shared amongst threads
781 in a process. Unix-based applications will still work fine without
782 calling this.
783
784 Added NT Services interface for the the Z39.50 (statserv) Server. 
785 Refer to the ztest.c source on the usage.
786
787 Windows 95/NT port using MSVC5.0. Project files are included in the
788 distribution.
789
790 * Defined new 'global' handle for the retrieval (data1) system. The
791 new handled, data1_handle, describes the state of the data1 system.
792 This handle is passed as first argument to virtually all
793 data1 related routines. The functions data1_create and data1_destroy
794 creates and destroys a data1 handle respectively.
795
796 Added ODR encode stream member to all backend request structures
797 init, search, scan etc. This stream should be used to allocate all
798 memory used for the response when thread safe operation is needed.
799
800 Changed the comstack utility, cs_addstr, to be thread safe. The
801 returned hostname string returned by the function is now part the
802 COMSTACK instance.
803
804 Added comstack utility, cs_straddr, which replaces the tcpip_strtoaddr
805 function. The cs_straddr takes a COMSTACK handle as argument, so this
806 function must be used after cs_create and before bind/connect.
807 This function is thread safe.
808
809 Moved test server to 'ztest' directory - generic server code still
810 in 'server' directory.
811
812 Made prefix query (pquery.c) utility thread safe.
813
814 Added new function modifier YAZ_EXPORT to 'export' public DLL
815 functions when using windows (see include/yconfig.h).
816
817 Added definitions to the OID database (util/oid.c) (RVDM).
818
819 Added new BIB-1 diagnostic messages to the handler diagbib1_str.
820
821 Added call to ccl_rpn_delete in client program.
822
823 Added ODR argument to ccl_rpn_query and ccl_scan_query to provide
824 release of RPN structure.
825
826 Added support for C++, headers uses extern "C" for public definitions.
827 With input from RVDM.
828
829 In handling of SEQUENCE OF: Counter set to zero when SEQUENCE OF is absent.
830 Thanks to Ronald van der Meer (RVDM).
831
832 Added initializers (zget_ routines) for a number of PDUs. Thanks to RVDM.
833
834 Added support for private extensions to the OID database
835 (oid_setprivateoids()). Thanks to RVDM.
836     
837 Added optional, physical ANY (key replication)
838
839 Fixed null-reference problem in GRS-1 output filter.
840
841 Proximity operator added to Prefix Query Format (PQF).
842
843 In test client command "base" accepts multiple databases.
844
845 Fixed bug in cs_close stack that caused trouble with WINSOCK.
846
847 --- 1.3 1996/10/11
848
849 Fixed tagging bug in ResourceReportResponse PDU encoder/decode.
850
851 Smallish bug-fixes in the new encoders/decoders (explain).
852
853 Bug fixed in DeleteRequest.
854
855 Fixed tagging bug of type 101 query in SearchRequest-Query PDU encoder/decoder.
856
857 Fixed tagging bug in ResourceReportResponse PDU encoder/decode.
858
859 Added SOIF syntax (using private OID for now) to retrieval module and client.
860
861 Added Update extended service.
862
863 Added SearchResult-1 additional info structure.
864
865 Added optional CCL (ISO8777) interpreter as separate module. Available
866 in linemode client.
867
868 --- 1.2 1996/6/10 (1st anniversary release)
869
870 Added Summary record syntax. Lightly tested.
871
872 Added OPAC record syntax. Untested.
873
874 Added ResourceReport service encoders/decoders. Untested.
875
876 Fixed bug in z_Unit - wrong tagging on unitSystem.
877
878 Fixed bug in the DiagRecs decoder.
879
880 Added options for max PDU size and session timeout to frontend-server.
881
882 Added documentation of query-language parsers and other supporting utilities.
883
884 [frontend-server] Added Attribute set to the bend_scanrequest API.
885
886 [frontend-server] NextResultSetPosition was sometimes set incorrectly when
887 surrogate diagnostics were generated.
888
889 [retrieval] Allow multiple local values for attribute.
890
891 [retrieval] Allow multiple attributes per element in .abs files. index type.
892
893 [retrieval] Added Summary tagset, abstract syntax, and d1-node/ASN filter.
894
895 --- 1.1pl2  1996/4/10
896
897 Minor changes, mostly specific to Zebra's requirements (retrieval)
898
899 --- 1.1  1996/2/20
900
901 Repaired bug in frontend server when running multiple listening
902 endpoints in dynamic mode.
903
904 z_External() now won't break if a known, ASN.1 value comes encapsulated
905 in an octet-string. The value will pass through unmodified in an Odr_oct.
906
907 Added a bit of code to the demo client to decode & display
908 ASN.1-structured records represented in the octet-aligned branch of
909 the EXTERNAL CHOICE. Thanks to CAS for prodding us to finally do this.
910
911 Added z_ext_getentbyref() to the ASN module. Doc updated.
912
913 * Completed the SCAN definition in the ASN module. This may break SCAN
914 code based on older YAZ-versions at compile-time. The fix is easy -
915 look in proto.h.
916
917 * Added 'displayTerm' and OtherInformation to the TermInfo structure
918 under the SCAN definition. Remember to initialize this, server-people.
919
920 Comstack should now support the WAIS protocol in TCP/IP mode. Note
921 that this does not extend to ODR and ASN.
922
923 Comstack allows insertion of established socket (primarily for
924 inetd-operation of servers). Doc updated.
925
926 Front-end server can now start from the inetd in TCP mode. Doc
927 updated.
928
929 --- 1.0pl4 1996/1/24
930
931 Added Sort PDU.
932
933 Fixed small problem in SUTRS-filter. A newline was sometimes inserted before
934 the rank and record number.
935
936 Adjustments to the frontend server.
937
938 Fixed diagnostic BER dumper. It ignored the file argument.
939
940 --- 1.0pl3 1996/1/2
941
942 Various changes to retrieval module.
943
944 Changed the union discriminators of the protocol files from enums to
945 ints paired with #defines.
946
947 *Changed oident.class to oident.oclass to avoid a reserved word in C++
948  compilers.
949
950 *Changed operator in the RPN structure to 'roperator', again to avoid a
951  conflict with C++.
952
953 Fixed problems in Explain decoders/encoders.
954
955 --- 1.0pl2 1995/12/6
956
957 Memory bug in log module fixed.
958
959 --- 1.0pl1 1995/12/5
960
961 Occasional malloc() of 0 bytes fixed in d1_espec.c.
962
963 Bug in Explain DatabaseInfo module fixed.
964
965 Some '\r' snuck into one or two of the ret'l config tables. A curse on Windows.
966
967 --- 1.0 1995/11/28
968
969 The shift to v1.0 signals that we now consider the *core* functionality
970 of YAZ reasonably stable (the core being more or less equivalent to
971 Z39.50-1992). Some of the really nifty v3 stuff is still not heavily
972 tested (Explain not at all - though that will happen soonish).
973
974 Minor changes to code to support Windows port.
975
976 Various minor changes after we're getting to use GRS-1 & co. more.
977
978 Added Espec-1 format.
979
980 Added VisibleString field body type to GRS-1. It is illegal acc. to my copy
981 of the protocol and it cannot be selected when encoding (maps into 'string'
982 when decoding). Needed to talk to some servers.
983
984 Demo client can request simple element set names.
985
986 Added Diagnostic Format encoders/decoders.
987
988 Added simple Close handling to frontend server (no hooks for resource
989 reporting yet), and demonstration client.
990
991 Added cs_addrstr() command to COMSTACK to retrieve peer hostname/address.
992
993 --- 1.0b3 1995/08/24
994
995 Fixed bug in the frontend-server. The numberOfRecordsReturned field was
996 handled incorrectly when records were requested in the searchResponse. This
997 will only affect you if you use the frontend-server.
998
999 Added GRS-1 encoders/decoders to the service-level API. Lightly tested.
1000 Test-client will ask for and print GRS1. Ztest will return dummy records
1001 on request.
1002
1003 Added Explain encoders/decoders to the service-level API. Untested.
1004
1005 Added Extended Services: Item Order encoders and decoders to the Service-
1006 level API. Untested. We could use a recent copy of the pertinent bits
1007 of the ILL protocol to add those bits.
1008
1009 Added diagnostic format 1 encoders/decoders to the service-level API.
1010 Untested.
1011
1012 Moved pretty-printing of structure-wrappers ({..}) from odr_seq.c to
1013 odr_cons.c, which causes a more correct output.
1014
1015 Fixed handling of searchRequest in frontend server. NextResultSetPosition
1016 was always set to 0 when no records were requested in the searchRequest.
1017
1018 * Added better external-handling. This shouldn't harm old code that
1019 *encodes* externals. It can break code that looks for a
1020 'single-ASN1-type' representation, since those types that are known
1021 are now decoded immediately. Look at the SUTRS sample code in
1022 seshigh.c and client.c. Documentation updated.
1023
1024 Handling of structured records in bend_fetchresponse. Length -1 marks
1025 structured record, type is deduced from format field.
1026
1027 --- 1.0b2 1995/06/27
1028 Fairly quick maintenance release to add SUTRS support.
1029
1030 Fixed handling of SUTRS records in the demonstration client.
1031
1032 * Added format field to the bend_fetchrequest and bend_fetchresponce
1033 structures of the backend API (frontend server). When the record is
1034 returned, the value of the format field is mapped to an OID. The
1035 value VAL_SUTRS will also cause a slightly different ASN.1 packaging
1036 of the record. The special value VAL_NONE in the bend_request means
1037 that no specific format was requested by the client. Documentation
1038 updated accordingly. Test server (ztest) will return a fixed dummy
1039 SUTRS record if your client requests SUTRS.
1040
1041 Documentation updated accordingly.
1042
1043 You can now set external libraries and RANLIB support in the top-level
1044 Makefile.
1045
1046 --- 1.0b 1995/06/19
1047 First public release.