update lintian overrides
[alioth/cvs.git] / NEWS
1 Changes since 1.12.13:
2 **********************
3
4 * many which are only documented in MirBSD CVS
5
6 * A new command line option, --allow-root-regexp, was added which allows
7   acceptable repositories to be specified using a list of regular expressions.
8
9 Changes since 1.12.12:
10 **********************
11
12 SECURITY FIXES
13
14 * CVS now uses version 1.2.3 of the ZLib compression libraries in order to
15   avoid two recently announced security vulnerabilities in them.  Both may be
16   used for denial of service attacks and one may reportedly allow execution of
17   arbitrary code, though this is not confirmed.  Please see the CERT
18   vulnerabilities advisories #238678 <http://www.kb.cert.org/vuls/id/238678> &
19   #680620 <http://www.kb.cert.org/vuls/id/680620> for more.
20
21 NEW FEATURES
22
23 * Thanks to Conrad Pino <conrad@pino.com>, a hang in the Windows client, which
24   had pretty much rendered the client useless, has been fixed.
25
26 * A minor problem preventing build of the Kerberos4 client has been fixed.
27
28 * The path to the config file may be set as an argument to the CVS server
29   commands.
30
31 * Sections of directives specific to one or more repositories and not others
32   may now be specified in the config file.
33
34 * %{sV} format strings are now available to the verifymsg trigger, similar to
35   the %{stVv} available to loginfo.
36
37 * `cvs watch add' on an empty directory no longer clears watchers, and
38   specifying a directory for `cvs watch add' now (correctly) sets default
39   attributes.
40
41 * Missing CVSROOT/history files will now cause CVS to attempt to create one.
42   To suppress history logging, set LogHistory equal to the empty string in
43   CVSROOT/config.
44
45 * There are several new options available in CVSROOT/config.  These are
46   TmpDir, HistoryLogPath, HistorySearchPath, MinCompressionLevel, &
47   MaxCompressionLevel.  Please see the manual for more.
48
49 * CVS on Solaris 10 was refusing to parse command options.  This has been
50   fixed.
51
52 * The Windows client now creates locks compatible with older versions of CVS by
53   default.  This should only be relevant if your client is accessing a local
54   repository concurrently with another, older client.  If you would like to
55   disable compatibility mode (because it is slightly faster), edit the
56   LOCK_COMPATIBILITY flag in windows-NT/config.h and recompile.
57
58 * Misc efficiency and portability improvements.
59
60 BUG FIXES
61
62 * Thanks to Serguei E. Leontiev <lse@CryptoPro.ru>, CVS with Kerberos 5 GSSAPI
63   should automatically link on FreeBSD 5.x. (bug #14639).
64
65 * Thanks to Rahul Bhargava <rahul@wandisco.com>, heavily loaded systems
66   suffering from a disk crash or power failure will not lose data they claimed
67   to have committed.
68
69 * CVS server now handles conflict markers in Entry requests as documented.
70
71 * CVS now remembers that binary file merge conflicts occurred until the
72   timestamp of the updated binary file changes.
73
74 * CVS client now saves some bandwidth by not sending the contents of files
75   with conflicts to the server when it isn't needed.
76
77 * CVS now does correct locking during import.
78
79 * A problem where the server could block indefinitely waiting for an EOF from
80   the client when compression was enabled has been fixed.
81
82 * `cvs diff' no longer splits its arguments on spaces.
83
84 * Thanks to an old report and patch from Stewart Brodie <stewart@eh.org>, a
85   potential crash in response to a corrupt RCS file has been fixed.
86
87 * CVS now locks the history and val-tags files before writing to them.
88   Especially with large repositories, users should no longer see new warnings
89   about corrupt history records when using the `cvs history' command.  Existing
90   corrupt history records will still need to be removed manually.  val-tags
91   corruption should have had less obvious effects, but removing the
92   CVSROOT/val-tags file and allowing a 1.11.21 or later version of CVS to
93   regenerate it may eliminate a few odd behaviors and possibly cause a slight
94   speed up of read transactions in large repositories over time.
95
96 BUILD ISSUES
97
98 * The RPM spec file works again with the most modern versions of `rpm'.  It
99   also finds the correct version of install-sh when building the CVS with
100   GSSAPI.
101
102 DEVELOPER ISSUES
103
104 * We've standardized on Automake 1.9.6 to get some at new features that make
105   our jobs easier.  See the HACKING file for more on using the autotools with
106   CVS.
107
108 Changes from 1.12.11 to 1.12.12:
109 ********************************
110
111 SERVER SECURITY FIXES
112
113 * Thanks to a report from Alen Zukich <alen.zukich@klocwork.com>, several minor
114   security issues have been addressed.  One was a buffer overflow that is
115   potentially serious but which may not be exploitable, assigned CAN-2005-0753
116   by the Common Vulnerabilities and Exposures Project
117   <http://www.cve.mitre.org>.  Other fixes resulting from Alen's report include
118   repair of an arbitrary free with no known exploit and several plugged memory
119   leaks and potentially freed NULL pointers which may have been exploitable for
120   a denial of service attack.
121
122 * Thanks to a report from Craig Monson <craig@malachiarts.com>, minor
123   potential vulnerabilities in the contributed Perl scripts have been fixed.
124   The confirmed vulnerability could allow the execution of arbitrary code on
125   the CVS server, but only if a user already had commit access and if one of
126   the contrib scripts was installed improperly, a condition which should have
127   been quickly visible to any administrator.  The complete description of the
128   problem is here: <https://ccvs.cvshome.org/issues/show_bug.cgi?id=224>.  If
129   you were making use of any of the contributed trigger scripts on a CVS
130   server, you should probably still replace them with the new versions, to be
131   on the safe side.
132
133   Unfortunately, our fix is incomplete.  Taint-checking has been enabled in all
134   the contributed Perl scripts intended to be run as trigger scripts, but no
135   attempt has been made to ensure that they still run in taint mode.  You will
136   most likely have to tweak the scripts in some way to make them run.  Please
137   send any patches you find necessary back to <bug-cvs@nongnu.org> so that we
138   may again ship fully enabled scripts in the future.
139
140   You should also make sure that any home-grown Perl scripts that you might
141   have installed as CVS triggers also have taint-checking enabled.  This can be
142   done by adding `-T' on the scripts' #! lines.  Please try running
143   `perldoc perlsec' if you would like more information on general Perl security
144   and taint-checking.
145
146 NEW FEATURES
147
148 * Thanks to a report from Ian Abbott <abbotti@mev.co.uk>, a problem that caused
149   CVS to stop with broken assertions in certain time zones when daylight
150   savings is in effect has been fixed.
151
152 * A problem where a proxy server could fail to notice that its primary closed
153   the connection has been fixed.
154
155 * Failures to open the CVS_CLIENT_LOG, CVS_SERVER_LOG, and CVS_SECONDARY_LOG
156   are no longer fatal.
157
158 * CVS's client and server IO buffers now rely on a GNULIB modules for memory
159   management rather than taking on the task themseleves.  This should be faster
160   on any system but may increase memory usage noticably on systems without the
161   POSIX mmap() function.  Benchmark reports to <bug-cvs@gnulib.org> would be
162   welcome.
163
164 * Some more GNULIB functions have been imported and/or updated for portability
165   reasons.  This change should not be visible to most users, though CVS may now
166   compile on a few more platforms.
167
168 * CVS creates a unique session id that gets written to the RCS files during
169   import and commit. When committing several files at once, they all get the
170   same 'commitid'. The commitid becomes visible with log and status commands,
171   and is derived and compatible with the cvsnt project.
172
173 * CVS once again compiles correctly configured with various combinations of
174   --disable-client, --disable-server, and --disable-proxy.
175
176 * CVS now accepts the <tag>:<date> format, which has long been acceptable as an
177   argument to -j options, in most places where <tag> used to be acceptable.  An
178   empty tag in this format (e.g. ":<date>"), which used to be rejected, is now
179   interpreted as specifying a date on the trunk.
180
181 * CVS now uses ZLib 1.2.2.  This fixes the minor vulnerability described here:
182   <http://www.kb.cert.org/vuls/id/238678>, as well as some other minor bugs we
183   are not aware of bug reports for in conjunction with CVS.
184
185 * `cvs -n release' now does what it should (see changes to the info-cleanup-0
186   test in sanity.sh for more).
187
188 * The configure script now prefers `ssh' to `rsh' when determining a default
189   executable to use when connecting via the :ext: method.
190
191 * A problem in the compression buffer that was causing some incompatibility
192   with some 3rd party CVS clients when compression was enabled has been fixed.
193
194 * Some files missing from the distribution have been added or readded.  The
195   missing files were mostly development support files, with a few docs and
196   .cvsignore files thrown in.
197
198 * The incomplete Brazillian Portugese translation of the CVS manual is now
199   included in the distribution.
200
201 BUG FIXES
202
203 * Misc bug and documentation fixes.
204
205 * CVS now detects write errors on standard output.  Before, e.g.,
206   `cvs update -p FILE > /dev/full' would fail to report the write error.
207
208 * Thanks to a report and a patch from Georg Scwharz <georg.scwarz@freenet.de>
209   CVS now builds without error on IRIX 5.3
210
211 DEVELOPER ISSUES
212
213 * We've standardized on Automake 1.9.5 to get some at new features that make
214   our jobs easier.  See the HACKING file for more on using the autotools with
215   CVS.
216
217 Changes from 1.12.10 to 1.12.11:
218 ********************************
219
220 NEW FEATURES
221
222 * Thanks to Conrad Pino <conrad@pino.com>, the Windows build works once again.
223
224 * CVSROOT methods and option names are now case insensitive
225
226 * CVSROOT methods :ext: and :fork: now support the CVS_SERVER option.
227
228 * CVSROOT method :ext: now supports the CVS_RSH and Redirect options.
229
230 * Date handling has been improved slightly.
231
232 * Miscellaneous bug fixes.
233
234 * Miscellaneous documentation fixes.
235
236 BUG FIXES
237
238 * An intermittant assertion failure in checkout has been fixed.
239
240 * Thanks to a report from Chris Bohn <cbohn@rrinc.com>, all the source files
241   needed to build on Windows are now included in the source distribution.
242
243 Changes from 1.12.9 to 1.12.10:
244 *******************************
245
246 NEW FEATURES
247
248 * The date formats which CVS accepts are now documented more fully in the
249   manual.
250
251 * CVS commands which accept dates now understand some more time zones,
252   including those which are some hours plus some fraction of an hour off of
253   universal coordinated time.
254
255 * `cvs ls filename' no longer causes an assertion failure.
256
257 * The maximum length of the discovered comment leader used in a Log keyword
258   substitution is now limited to 20 characters by default.  If a longer leader
259   is discovered, then the keyword is not expanded.  This default behavior may
260   be altered using the new MaxCommentLeaderLength & UseArchiveCommentLeader
261   config options.
262
263 * Commit messages once again include the full relative path to the file being
264   committed.
265  
266 * Thanks to funding from Juniper Networks <http://juniper.net>, "write proxy"
267   functionality has been added to the CVS server.  Write proxy functionality
268   allows any of multiple, read-only "secondary" servers to relay write requests
269   from clients to a single primary CVS server, allowing for a massive
270   redistribution of server load which is transparent to all known CVS clients.
271
272 * Thanks to funding from Juniper Networks <http://juniper.net>, some code has
273   been added which second-guesses the system file cache for a performance
274   boost.
275
276 * The loginfo scripting hook now runs after the administrative files in CVSROOT
277   are rebuilt, rather than before.
278
279 * Misc error message improvements.
280
281 * Thanks to funding from Juniper Networks <http://juniper.net>, new scripting
282   hooks have been added to the CVS server.  These are the postadmin, posttag,
283   and postwatch hooks.  See the manual for more info.
284
285 * Thanks to funding from Juniper Networks <http://juniper.net>, all the
286   existing scripting hooks may now optionally be passed a command name
287   argument.
288
289 * Thanks to funding from Juniper Networks <http://juniper.net>, new tags are
290   cached in the val-tags file at the time of tag creation.
291
292 * Thanks to a patch from Brian Murphy <brian@murphy.dk>, CVS now supports PAM
293   session management.
294
295 * Thanks to a report from Brian Murphy <brian@murphy.dk>, the demo PAM
296   configuration files mentioned in the manual are actually being distributed.
297
298 * Thanks again to Bart Robinson <lomew@pobox.com>, `cvs log' & `cvs ls' now
299   actually output local times when the server is version 1.12.9 or greater and
300   the client is version  1.12.10 or greater.  
301
302 * The CVS server now sends paths to files relative to the repository.  CVS
303   clients have been able to handle this since at least the 10 year old
304   CVS 1.9.2 release, so no attempt at verifying compatibility of clients has
305   been made.  This saves a small amount of bandwidth and may enable some future
306   functionality.
307
308 * The CVS client will send relative Directory requests if the server claims to
309   support it.  This saves a very small amount of bandwidth but may enable some
310   future functionality.
311
312 * "cvs import" now has a new option, `-X', which causes new files to be
313   imported in a way that they appear only on the vendor branch, and do not
314   automatically appear on the main trunk.
315
316   This option may be made the default on a repository-wide basis
317   using the new ImportNewFilesToVendorBranchOnly=yes option in
318   CVSROOT/config.
319
320 * contrib/cvs_acls.in has been revised. Users of the old version will
321   want to upgrade to use the new format. See the documentation in
322   contrib/cvs_acls.html for more information.
323
324 * Thanks to Dan Peterson <dbpete@aol.com>, the contrib/validate_repo script now
325   accepts and logs corrupted revision numbers in RCS archives.
326
327 BUG FIXES
328
329 * Thanks to a report from Gottfried Ganssauge <gotti@cvshome.org>, CVS no
330   longer exits when it encounters links pointing to paths containing more
331   than 128 characters.
332
333 * Thanks to a report from Dan Peterson <dbpete@aol.com>, error messages from
334   GSSAPI servers are no longer truncated.
335
336 * Thanks to a report from Dan Peterson <dbpete@aol.com>, attempts to resurrect
337   a file on the trunk that was added on a branch no longer causes an assertion
338   failure.
339
340 * Thanks to a report from Dan Peterson <dbpete@aol.com>, imports to branches
341   like "1.1." no longer create corrupt RCS archives.
342
343 * Thanks to a report from Chris Bohn <cbohn@rrinc.com>, links from J.C. Hamlin
344   <jchamlin@ibsys.com>, and code posted by Jonathan Gilligan, we think we have
345   finally corrected the Windows "red-file" (daylight savings time) bug once and
346   for all.
347
348 * Thanks to a patch from Jeroen Ruigrok/asmodai <asmodai@wxs.nl>, the
349   log_accum.pl script should no longer elicit warnings from Perl 5.8.5.
350
351 * The r* commands (rlog, rls, etc.) can once again handle requests to run
352   against the entire repository (e.g. `cvs rlog .').  Thanks go to Dan Peterson
353   <dbpete@aol.com> for the report.
354
355 * A problem where the attempted access of files via tags beginning with spaces
356   could cause the CVS server to hang has been fixed.  This was a particular
357   problem with WinCVS clients because users would sometimes accidentally
358   include spaces in tags pasted into a dialog box.  This fix also altered some
359   of the error messages generated by the use of invalid tags.  Thanks go to Dan
360   Peterson <dbpete@aol.com> for the report.
361
362 * Thanks to James E Wilson <wilson@specifixinc.com> for a bug fix to
363   modules processing "gcc-core -a !gcc/f gcc" will no longer exclude
364   gcc/fortran by mistake.
365
366 * Thanks to Conrad Pino <conrad@pino.com>, the Windows build works once again.
367
368 * Misc updates to the manual.
369
370 DEVELOPER ISSUES
371
372 * We've standardized on Automake 1.9.3 to get some at new features that make
373   our jobs easier.  See the note below on the Autoconf upgrade for more
374   details.
375
376 * We've standardized on Autoconf version 2.59 to get presumed bug fixes and
377   features, but nothing specific.  Mostly, once we decide to upgrade one of the
378   autotools we just figure it'll save time later to grab the most current
379   versions of the others too.  See the HACKING file for more on using the
380   autotools with CVS.
381
382 Changes from 1.12.8 to 1.12.9:
383 ******************************
384
385 SERVER SECURITY FIXES
386
387 * Thanks to Stefan Esser & Sebastian Krahmer, several potential security
388   problems have been fixed.  The ones which were considered dangerous enough
389   to catalogue were assigned issue numbers CAN-2004-0416, CAN-2004-0417, &
390   CAN-2004-0418 by the Common Vulnerabilities and Exposures Project.  Please
391   see <http://www.cve.mitre.org> for more information.
392
393 * A potential buffer overflow vulnerability in the server has been fixed.
394   This addresses the Common Vulnerabilities and Exposures Project's issue
395   #CAN-2004-0414.  Please see <http://www.cve.mitre.org> for more information.
396
397 NEW FEATURES
398
399 * `cvs log' & `cvs ls' now output local times when both the server and client
400   are 1.12.9 or greater.  (Thanks to Bart Robinson <lomew@pobox.com>.)
401
402 DEVELOPER NOTES
403
404 * The windows-NT/config.h.in file is now generated dynamically from the
405   root config.h.in file and a few inputs in the windows-NT directory in hopes
406   of keeping it more in sync with the root config.h.in file.
407
408 Changes from 1.12.7 to 1.12.8:
409 ******************************
410
411 SERVER SECURITY FIXES
412
413 * A potential buffer overflow vulnerability in the server has been fixed.
414   Prior to this patch, a malicious client could potentially use carefully
415   crafted server requests to run arbitrary programs on the CVS server machine.
416   This addresses the Common Vulnerabilities and Exposures Project's issue
417   #CAN-2004-0396.  Please see <http://www.cve.mitre.org> for more information.
418
419 NEW FEATURES
420
421 * Some redundant output generated by the `cvs commit' command has been removed.
422
423 * Most output from the `cvs commit' command is suppressed when the -Q global
424   option is specified.
425
426 * Repository directory browsing via `cvs rls' & `cvs ls' commands.  Expect
427   changes in the long format output soon.  The "entries" format output should
428   remain fairly stable for automated parsers.
429
430 * Glob matches, as specified in ignore lists and wrapper options, now conform
431   to the POSIX.2 specification for fnmatch on all platforms.
432
433 * The Windows MS Visual C++ project files, including the nmake build files,
434   are now generated with MSVC++ 6.0, but should still work with MSVC++ 5.0.
435
436 BUG FIXES
437
438 * The cvs.1 man page is now generated automatically from a section of the CVS
439   Manual.
440
441 * Thanks to a report from Mark Andrews at the Internet Systems Consortium, the
442   :ext: connection method no longer relies on a transparent transport that uses
443   an argument processor that can handle arbitrary ordering of options and other
444   arguments when using a username other than the caller's.
445
446 * Thanks to Ken Raeburn at MIT, directory deletion, whether via `cvs release'
447   or empty directory pruning, now works on network shares under Windows XP.
448
449 Changes from 1.12.6 to 1.12.7:
450 ******************************
451
452 SERVER SECURITY ISSUES
453
454 * Piped checkouts of paths above $CVSROOT no longer work.  Previously, clients
455   could have requested the contents of RCS archive files anywhere on a CVS
456   server.  This addresses CVE issue CAN-2004-0405.  Please see
457   <http://www.cve.mitre.org> for more information.
458
459 CLIENT SECURITY ISSUES
460
461 * Clients now check paths from the server to verify that they are within one of
462   the sandboxes the user requested be updated.  Previously, a trojan server
463   could have written or overwritten files anywhere the user had access,
464   presenting a serious security risk.  This addresses CVE issue CAN-2004-1080.
465   Please see <http://www.cve.mitre.org> for more information.
466
467 GENERAL USER ISSUES
468
469 * Imported the most recent version of regex from GNULIB, which actually means
470   some systems will use now their native regex functions instead of compiling
471   CVS's.  Users should notice no changes in CVS responses to regular
472   expressions.  If you do, please report them to <bug-cvs@gnu.org>.
473
474 * CVS now accepts the location of HTTP tunnel web proxies as part of the
475   CVSROOT string.  Actually using a proxy remains untested.  Please report
476   problems and successes to <bug-cvs@gnu.org>.
477
478 * Configure no longer checks the $TMPDIR, $TMP, & $TEMP variables to set the
479   default temporary directory.
480
481 * CVS on Cygwin correctly handles X:\ style paths.
482
483 * Import now uses backslash rather than slash on Windows when checking for
484   "CVS" directories to ignore in import commands.
485
486 * Relative paths containing up-references (`..') should now work in
487   client/server mode (client fix).
488
489 * A race condition between the ordering of messages from CVS and messages from
490   called scripts in client/server mode has been removed (server fix).
491
492 * The check_cvs and cvscheck scripts in the contrib directory have been renamed
493   validate_repo and sandbox_status, respectively, in the interests of clarity.
494
495 * The Windows MS Visual C++ 6.0 project files have been brought up to date.
496   The nmake build files were regenerated from these files with MSVC++ 5.0.
497
498 * A memory allocation bug on Windows that could cause at least executions of
499   `cvs status' to fail has been fixed (client fix).
500
501 * Resurrected files now get their modes and timestamps set correctly and a
502   longstanding bug involving resurrection of an uncommitted removal has been
503   fixed (server fix).
504
505 * Some resurrection (cvs add) status messages have changed slightly.
506
507 * `cvs release' now works with Kerberos or GSSAPI encryption enabled (server
508   fix).
509
510 * File resurrection from a previously existing revision no longer just reports
511   that it works (server fix).
512
513 * Misc error & status message corrections.
514
515 * Diffing of locally added files against arbitrary revisions in an RCS archive
516   is now allowed when a file of the same name exists or used to exist on some
517   branch (server fix).
518
519 * Some user messages have been updated for consistency and spelling.
520
521 DEVELOPER ISSUES
522
523 * The message source differentiation in the test suite between client and
524   server executables has been repaired.
525
526 Changes from 1.12.5 to 1.12.6:
527 ******************************
528
529 GENERAL USER ISSUES
530
531 * CVSROOT/*info scripts may not work as expected with executables compiled
532   using VC++ under Windows since all quoting is currently done according to
533   Bourne Shell rules, which probably don't look like command.com rules.
534   Patches gratefully accepted.
535
536 * Imports will now always ignore directories and files named `CVS' to avoid
537   violating assumptions made by other parts of CVS.
538
539 * Directories specified to `checkout -d' are no longer required to exist.  This
540   consolidates some behavior between `-d' options specified in the modules file
541   and `checkout -d' as well as removing some prior differences between local
542   and client/server mode operation.
543
544 * A problem with `cvs release' of subdirs that could corrupt CVS/Entries files
545   has been fixed (client/server).
546
547 * The CVS server's protocol check for unused data from the client is no longer
548   called automatically at program exit in order to avoid potential recursive
549   calls to error when the first close is due to memory allocation or similar
550   problems that cause calls to error() to fail.  The check is still made when
551   the server program exits normally.
552
553 * The CVSROOT/*info files want a new command format and the old style strings
554   have been deprecated.  Please see the manual for more information on the new
555   format.
556
557 * The spec file has been updated to work with more recent versions of RPM.
558
559 * Some more GNULIB functions have been imported and/or updated for portability
560   reasons.
561
562 * Several memory leaks have been plugged.
563
564 * A seg fault which always occurred after waiting on another process's lock
565   in order to establish a promotable lock is now avoided.
566
567 * An unlikely potential segfault when using the :fork: connection method has
568   been fixed.
569
570 * The CVS server has had the protocol check for unused data from the client
571   partially restored.
572
573 * A fix has been included that should avoid a very rare race condition that
574   could cause a CVS server to exit with a "broken pipe" message.
575
576 * Infinite alias loops in the modules file are now checked for and avoided.
577
578 * Clients on case insensitive systems now preserve the case of directories in
579   CVS/Entries, in addition to files, for use in communications with the CVS
580   server.
581
582 * Misc status message fixes for consistency.
583
584 * Some previously untested behavior is now being tested.
585
586 * Server no longer claims to support the "Case" request.
587
588 * Case insensitive clients once again preserve the case of filenames in
589   CVS/Entries for communication with the server, as specified in the CVS
590   client/server protocol spec.  Note that all CVS _servers_ still lack support
591   for case insensitive clients - servers are relying on the client to preserve
592   the case of checked out files.
593
594 * Thanks to Ville Skytt√§ the man page has a few less spelling errors and is
595   slightly more accurate.
596
597 * Thanks to Ville Skytt√§ some unused variables were removed from the log_accum
598   Perl script in contrib.
599
600 * Thanks to Alexey Mahotkin, a bug that prevented CVS from being compiled with
601   Kerberos 4 authentication enabled has been fixed.
602
603 * A minor bug that caused CVS to fail to report an inifinte alias loop in the
604   modules file when portions of the alias definition contained trailing slashes
605   has been fixed.
606
607 * A bug in the gzip code that could cause heap corruption and segfaults in CVS
608   servers talking to clients less than 1.8 and some modern third-party CVS
609   clients has been fixed.
610
611 * mktemp.sh is now included with the source distribution so that the rcs2log
612   and cvsbug executables may be run on systems which do not contain an
613   implementation of mktemp.
614
615 * Misc documentation fixes.
616
617 DEVELOPER ISSUES
618
619 * xmalloc, xstrdup, & some other memory allocating functions are now available
620   vi GNULIB versions imported into lib.
621
622 * The asnprintf() & vasnprintf() functions are now available due to a GNULIB
623   implementation.
624
625 * Misc cosmetic, readability, and commenting fixes.
626
627 Changes between 1.12.4 and 1.12.5:
628 **********************************
629
630 SERVER SECURITY ISSUES
631
632 * pserver can no longer be configured to run as root via the
633   $CVSROOT/CVSROOT/passwd file, so if your passwd file is compromised, it no
634   longer leads directly to a root hack.  Attempts to root will also be logged
635   via the syslog.
636
637 GENERAL USER ISSUES
638
639 * The Windows build files were updated to allow building of the current version
640   under Windows.
641
642 Changes between 1.12.3 and 1.12.4:
643 **********************************
644
645 GENERAL USER ISSUES
646
647 * The CVS server no longer locks more than a directory at a time for write, so
648   large commits & tags should now have a much harder time blocking other
649   operations.
650
651 * Add support for large files. Use --disable-largefile to omit support
652   for large files.
653
654 Changes between 1.12.2 and 1.12.3:
655 **********************************
656
657 SERVER SECURITY ISSUES
658
659 * Malformed module requests could cause the CVS server to attempt to create
660   directories and possibly files at the root of the filesystem holding the CVS
661   repository.  Filesystem permissions usually prevent the creation of these
662   misplaced directories, but nevertheless, the CVS server now rejects the
663   malformed requests.
664
665 GENERAL USER ISSUES
666
667 * Support for case insensitive clients has been removed.  This is not as
668   drastic as it sounds, as all of the current tests still pass without
669   modification when run from a case insensitive client to a case sensitive
670   server.  In the end this should provide a major stability improvement.
671
672 * A minor problem that prevented the correct version of a system ZLIB from
673   being detected on some platforms has been fixed.
674
675 * Attempts to use the global `-l' option, removed from both client and server
676   as of version 1.12.1, will now elicit a warning rather than a fatal error
677   from the server.
678
679 * The configure script now tests whether it is building CVS on a case
680   insensitive filesystem.  If it is, CVS assumes that all filesystems on this
681   platform will be case insensitive.  This is useful for getting the case
682   insensitivity flag set correctly when compiling on Mac OS X and under Cygwin
683   on Windows.  Autodetection can be overridden using the
684   --disable-case-sensitivity and --enable-case-sensitivity arguments to
685   configure.
686
687 DEVELOPER ISSUES
688
689 * A new set of tests to test issues specific to case insensitive clients and
690   servers has also been added.
691
692 * Support has been added to the test suite to support testing over a :ext: link
693   to another machine, subject to some stringent requirements.  This support can
694   be used, for instance, to test the operation of a case insensitive client
695   against a case sensitive server.  Please see the comments in TEST and the
696   src/sanity.sh test script itself for more.
697
698 * We've standardized on Automake 1.7.9 to get a bug fix.  See the note below
699   on the Autoconf upgrade for more details.
700
701 * We've standardized on Autoconf version 2.58 to avoid a bug and get at a few
702   new macros.  Again, this should only really affect developers, though it is
703   possible that CVS will now compile on a few new platforms.  Please see the
704   section of the INSTALL file about using the autotools if you are compiling
705   CVS yourself.
706
707 Changes between 1.12.1 and 1.12.2:
708
709 * Misc cleanup, reorganization, and other minor fixes.
710
711 * A behavior change in `cvs up -jrev1 -jrev2' for modified files with a base
712   revision of rev2 (ie, checked-out version matches rev2 and file has been
713   modified).  The operation is no longer ignored and instead is passed to
714   diff3.  This will potentially re-apply the diffs between the two revisions to
715   a modified local file.  Status messages like from a standard merge have also
716   been added when the file would not or does not change due to this merge
717   request ("[file] already contains the changes between [revisions]...").
718
719 * A build problem that caused warnings and slower builds on systems without a
720 working getline() function (e.g. Mac OS X 10.1) has been fixed.
721
722 * A build problem that prevented the CVS executable from being built on systems
723 with the gettext library installed has been fixed.
724
725 * A bug which could stop `cvs admin -mTAG:message' from recursing has been
726   fixed.
727
728 * Misc documentation cleanup and fixes.
729
730 * Some of the contrib scripts, some of the documentation, and sanity.sh were
731   modified to use and recommend more portable commands rather than using and
732   recommending commands which were not compatible with the POSIX 1003.1-2001
733   specification.
734
735 * CVS now knows how to report, as well as record, `P' record types.
736
737 * When running the `cvs history' command, clients will now send the
738   long-accepted `-e' option, for all records, rather than explicitly requesting
739   `P' record types, a request which servers prior to 1.11.7 will reject with a
740   fatal error message.
741
742 * A problem with locating files requested by case insensitive clients which was
743   accidentally introduced in 1.11.6 as part of a fix for a data loss problem
744   involving `cvs add's from case insensitive clients has been fixed.  The
745   relevant error message was `cvs [<command> aborted]: filE,v is ambiguous;
746   could mean FILE,v or file,v'.
747
748 * A problem in the CVS getpass library that could cause passwords to echo on
749   some systems has been fixed.
750
751 * A segfault that could occur in very rare cases where the stat of a file
752   failed during a diff has been fixed.
753
754 * Any user with write privleges to the CVSROOT/checkoutlist file could pass
755 arbitrary format strings directly through to a printf function.  This was
756 probably bad and has been fixed.  White space at the beginning of error strings
757 in checkoutlist is now ignored properly.
758
759 * A chmod 0600 that CVS performed on temp files it created designed to work
760 around a bug in versions of GLIBC eariler than 2.0.7 has been removed since it
761 still left a race condition open to exploitation and provided a false sense of
762 security.  If you are linking CVS against a version of GLIBC prior to 2.0.7,
763 you should consider upgrading GLIBC.
764
765 * The CVSROOT/editinfo file is no longer referenced by CVS.  This funcitonality
766 has been deprecated for over six years and removing it will presumably not
767 cause anyone any problems.
768
769 * In client/server mode, most messages from CVS now contain the actual
770 command name rather than the generic "server".
771
772 * A long-standing bug that prevented most client/server updates from being
773 logged in the history file has been fixed.
774
775 * Updates done via a patch ("P" status) are now logged in the history file
776 by default and the corresponding "P" history record type is now documented.
777 If you're setting the LogHistory option in your CVSROOT/config file, you may
778 want to add "P" to the list of record types.
779
780 * CVS now will always compile its own getpass() function (originally from
781 GNULIB) in favor of any system one that may exist.  This avoids some problems
782 with long passwords on some systems and updates us to POSIX.2 compliance, since
783 getpass() was removed from the POSIX.2 specification.
784
785 * Support for pre-ANSI compilers has been removed.  Our minimum support level
786 now assumes at least a freestanding C89 compilers.  See the HACKING file for
787 more information.  If you *really* need K&R support, our Makefile.am files
788 should only need minor tweaking to get them to run the ansi2knr script from the
789 Automake project.  If you get this working, please send a patch to
790 <bug-cvs@gnu.org>.
791
792 * Experimental support for Pluggable Authentication Modules (PAM) has been
793 added, though it is not compiled by default.  If you like this feature (or
794 don't), please send us feedback.  See the Cederqvist, `./configure --help',
795 and the INSTALL file for more.
796
797 * Command line keyword expansion modes no longer override binary keyword
798 expansion modes.
799
800 * New LocalKeyword and KeywordExpand options to CVSROOT/config which
801 FreeBSD, OpenBSD, and NetBSD users may find familiar as the "tag" and
802 "tagexpand" options used for many years. The CVSHeader keyword has
803 also been added to the mixture.
804
805 * A bug that allowed a write lock to be created in a directory despite
806 there being existing read locks when using LockDir in CVSROOT/config has
807 been fixed.
808
809 * A bug with short patches (`rdiff -s') which caused rdiff to sometimes report
810 differences that did not exist has been fixed.
811
812 * Some minor corrections were made to the diff code to keep diff & rdiff from
813 printing diff headers with empty change texts when two files have different
814 revision numbers but the same content.
815
816 * The global '-l' option, which suppressed history logging, has been removed
817 from both client and server.
818
819 Changes from 1.11.5 to 1.12.1:
820
821 * The new --with-external-zlib option can be passed to configure to compile
822 CVS against an external installed zlib.
823
824 * A warning message is now issued if an administrative file contains
825 more than one DEFAULT entry.
826
827 * An error running a verifymsg script (such as referencing an unset user
828 variable or the script not existing) now causes the verification to
829 fail.
830
831 * Errors in administrative files commands (like unset user variables)
832 are no longer reported unless the command is actually executed.
833
834 * When a file is initially checked out, its last access time is now set
835 to the current time rather than being set to the time the file was last
836 checked in like the modification time is.
837
838 * The Checkin.prog and Update.prog functionality has been removed.  This
839 fuctionality previously allowed executables to be specified in the modules file
840 to be run at update and checkin time, but users could edit these files on a per
841 workspace basis, creating a security hole.
842
843 * CVSROOTs which contain a symlink to a real repository should work.
844
845 * contrib/rcs2log and src/cvsbug now use the BSD mktemp program to create
846 their temp files and directories on systems which provide it.
847
848 * Added a UserAdminOptions configuration option to CVSROOT/config to
849 control which `cvs admin' commands are not restricted to the `cvsadmin'
850 group.
851
852 * If the rcsinfo specified template changes after a user has checked
853 out a tree, the template in the users' tree will be updated rather
854 than remaining static from the time of the original checkout.
855
856 * Added a CVSREADONLYFS environment variable and `-R' cvs global
857 option to turn on read-only repository mode for local repositories.
858 This allows users to checkout from a CDROM repository or other
859 read-only filesystem.
860
861 * There is a new CVS_LOCAL_BRANCH_NUM environment variable, which
862 may be used to give control over the branch number to be used next.
863 Useful for having local changes in a CVSup mirrored repository.
864
865 * Miscellaneous documentation corrections.
866
867 * Corrected the path in a failed write error message.
868
869 * Autoconf and Automake are no longer run automatically unless you run
870 configure with --enable-maintainer-mode.  Accordingly, noautomake.sh is
871 no longer needed and has been removed.
872
873 * We've standardized on Automake version 1.7.5 and Autoconf version 2.57 to get
874 at a few new macros.  Again, this should only really affect developers.  See
875 the section of the INSTALL file about using the autotools if you are compiling
876 CVS yourself.
877
878 Changes from 1.11.4 to 1.11.5:
879
880 * Fixed a security hole in the CVS server by which users with read only access
881 could gain write access.  This issue does not affect client builds.  The
882 Common Vulnerabilities and Exposures project (cve.mitre.org) has assigned the
883 name CAN-2003-0015 to this issue.  See
884 <http://cve.mitre.org/cgi-bin/cvename.cgi?name=CAN-2003-0015> for more
885 information.
886
887 * Fixed some bugs where revision numbers starting with 0 (like 0.3)
888 weren't correctly handled.  (CVS doesn't normally use such revision
889 numbers, but users may be able to force it to do so and old RCS files
890 might.)
891
892 Changes from 1.11.3 to 1.11.4:
893
894 * Some minor changes to allow the code to compile on Windows platforms.
895
896 Changes from 1.11.2 to 1.11.3:
897
898 * The tag/rtag code has been fixed to once again lock just a single
899 directory at a time.
900
901 * There was a bug where certain error conditions could cause the server
902 to go into an infinite loop.  There was also a bug that caused a
903 compressed connection from an older client to hang on shutdown.  These
904 bugs have been fixed.
905
906 * Fixed a bug that caused the server to reject most watch commands.
907
908 * When waiting for another user's lock, the message timestamps are now
909 in UTC rather than the server's local time.
910
911 * The options.h file is no longer used.  This fixes a bug that occurred when
912 1.11.2 was compiled on Windows platforms.
913
914 * We've standardized on Automake version 1.6.3 and Autoconf version 2.53.
915 They are cleaner, less bug prone, and will hopfully allow me to start updating
916 sanity.sh to use Autotest and Autoshell.  Again, this should only really affect
917 developers.  See the section of the INSTALL file about using the autotools if
918 you are compiling CVS yourself.
919
920 * Fixed a bug in the log/rlog code when a revision range crosses a
921 branch point.
922
923 * Fixed a bug where filenames starting with - would be misinterpreted as
924 options when using client/server mode.
925
926 Changes from 1.11.1p1 to 1.11.2:
927
928 * There is a new feature, enabled by RereadLogAfterVerify in CVSROOT/config,
929 which tells CVS to reread the log message after running the verifymsg
930 script.  This allows the verifymsg script to reformat or otherwise
931 modify the log message.
932
933 * The interpretation of revision ranges using :: in "log" and "rlog"
934 has changed: a::b now excludes the log message from revision a but
935 includes the log message from revision b.  Also, revision ranges that
936 cross branch points should now work.
937
938 * zlib has been updated to version 1.4.  There is a security advisory
939 out in regards to 1.3.  This should fix that problem.
940
941 * The "log" and "rlog" commands now have a -S option to suppress the
942 header information when no revisions are selected.
943
944 * A serious error that allowed read-only users to tag files has been
945 corrected.
946
947 * The "annotate" command will no longer annotate binary files unless
948 you specify the new -F option.
949
950 * The "tag" and "rtag" commands will no longer move or delete branch
951 tags unless you use the new -B option.  (This prevents accidental
952 changes to branch tags that are hard to undo.)
953
954 * We've standardized on the 1.5 Automake release for the moment.  Again, this
955 should only really affect developers.  See the section of the INSTALL file
956 about using the autotools if you are compiling CVS yourself.
957
958 Changes from 1.11.1 to 1.11.1p1:
959
960 * Read only access was broken - now fixed.
961
962 Changes from 1.11 to 1.11.1:
963
964 * There was a locking bug in the tag/rtag code that could lose changes
965 made to a file while the tag operation was in progress.  This has been
966 fixed, but all of the directories being tagged are now locked for the
967 entire duration of the tag operation rather than only one directory at a
968 time.
969
970 * The "cvs diff" command now accepts the -y/--side=by-side and -T/
971 --initial-tab options.  (To use these options with a remote repository,
972 both the client and the server must support them.)
973
974 * The expansion of the loginfo format string has changed slightly. 
975 Previously, the expansion was surrounded by single quotes ('); if a file
976 name contained a single quote character, the string would not be parsed
977 as a single entity by the Unix shell (and it would not be possible to
978 parse it unambiguously).  Now the expansion is surrounded by double
979 quotes (") and any embedded dollar signs ($), backticks (`), backslashes
980 (\), and double quotes are preceded by a backslash.  This is parsed as a
981 single entity by the shell reguardless of content.  This change should
982 not be noticable unless you're not using a Unix shell or you have
983 embedded the format string inside a double quoted string.
984
985 * There was a bug in the diff code which sometimes caused conflicts to
986 be flagged which shouldn't have been.  This has been fixed.
987
988 * New "cvs rlog" and "cvs rannotate" commands have been added to get log
989 messages and annotations without having to have a checked-out copy.
990
991 * Exclusive revision ranges have been added to "cvs log" using ::
992 (similar to "cvs admin -o").
993
994 * The VMS client now accepts wildcards if you're running VMS 7.x.
995
996 * ZLIB has been updated to version 1.1.3, the most current version.  This
997 includes mostly some optimizations and minor bug fixes.
998
999 * The ~/.cvspass file has a slightly modified format.  CVSROOTs are now
1000 stored in a new canonical form - hostnames are now case insensitive and
1001 port numbers are always stored in the new format.  Until a new login for
1002 a particular CVSROOT is performed with the new version of CVS, new and
1003 old versions of CVS should interoperate invisibly.  After that point, an
1004 extra login using the old version of CVS may be necessary to continue to
1005 allow the new and old versions of CVS to interoperate using the same
1006 ~/.cvspass file and CVSROOT. The exception to this rule occurs when the
1007 CVSROOTs used with the different versions use case insensitively
1008 different hostnames, for example, "empress", and "empress.2-wit.com".
1009
1010 * A password and a port number may now be specified in CVSROOT for
1011 pserver connections.  The new format is:
1012
1013     :pserver:[[user][:password]@]host[:[port]]/path
1014
1015 Note that passwords specified in a checkout command will be saved in the
1016 clear in the CVS/Root file in each created directory, so this is not
1017 recommended, except perhaps when accessing anonymous repositories or the
1018 like.
1019
1020 * The distribution has been converted to use Automake.  This shouldn't
1021 affect most users except to ease some portability concerns, but if you
1022 are building from the repository and encounter problems with the
1023 makefiles, you might try running ./noautomake.sh after a fresh update
1024 -AC.
1025
1026 Changes from 1.10 to 1.11:
1027
1028 * The "cvs update" command has a new -C option to get clean copies from
1029 the repository, abandoning any local changes.
1030
1031 * The new "cvs version" command gives a short version message.  If
1032 the repository is remote, both the client and server versions are
1033 reported.
1034
1035 * "cvs admin -t" now works correctly in client/server mode.
1036
1037 * The "cvs history" command output format has changed -- the date
1038 now includes the year and is given is ISO 8601 format (yyyy-mm-dd).
1039 Also, the new LogHistory option in CVSROOT/config can be used to
1040 control what information gets recorded in the log file and code has
1041 been added to record file removals.
1042
1043 * The buggy PreservePermissions code has been disabled.
1044
1045 * Anonymous read-only access can now be done without requiring a
1046 password.  On the server side, simply give that user (presumably
1047 `anonymous') an empty password in the CVSROOT/passwd file, and then
1048 any received password will authenticate successfully.
1049
1050 * There is a new access method :fork: which is similar to :local:
1051 except that it is implemented via the CVS remote protocol, and thus
1052 has a somewhat different set of quirks and bugs.
1053
1054 * The -d command line option no longer updates the CVS/Root file.  For
1055 one thing, the CVS 1.9/1.10 behavior never had updated CVS/Root in
1056 subdirectories, and for another, it didn't seem that popular in
1057 general.  So this change restores the CVS 1.8 behavior (which is also
1058 the CVS 1.9/1.10 behavior if the environment variable
1059 CVS_IGNORE_REMOTE_ROOT is set; with this change,
1060 CVS_IGNORE_REMOTE_ROOT no longer has any effect).
1061
1062 * It is now possible for a single CVS command to recurse into several
1063 CVS roots.  This includes roots which are located on several servers,
1064 or which are both remote and local.  CVS will make connections to as
1065 many servers as necessary.
1066
1067 * It is now possible to put the CVS lock files in a directory
1068 set by the new LockDir option in CVSROOT/config.  The default
1069 continues to be to put the lock files in the repository itself.
1070
1071 Changes from 1.9 to 1.10:
1072
1073 * A bug was discovered in the -t/-f wrapper support that can cause
1074 serious data loss.  Because of this (and also the fact that it doesn't
1075 work at all in client/server mode), the -t/-f wrapper code has been
1076 disabled until it can be fixed.
1077
1078 * There is a new feature, enabled by TopLevelAdmin in CVSROOT/config,
1079 which tells CVS to modify the behavior of the "checkout" command.  The
1080 command now creates a CVS directory at the top level of the new
1081 working directory, in addition to CVS directories created within
1082 checked-out directories.  See the Cederqvist for details.
1083
1084 * There is an optional set of features, enabled by PreservePermissions
1085 in CVSROOT/config, which allow CVS to store unix-specific file
1086 information such as permissions, file ownership, and links.  See the
1087 Cederqvist for details.
1088
1089 * One can now authenticate and encrypt using the GSSAPI network
1090 security interface.  For details see the Cederqvist's description of
1091 specifying :gserver: in CVSROOT, and the -a global option.
1092
1093 * All access to RCS files is now implemented internally rather than by
1094 calling RCS programs.  The main user-visible consequence of this is
1095 that there is no need to worry about making sure that CVS finds the
1096 correct version of RCS.  The -b global option and the RCSBIN setting
1097 in CVSROOT/config are still accepted but don't do anything.  The
1098 $RCSBIN internal variable in administrative files is no longer
1099 accepted.
1100
1101 * There is a new syntax, "cvs admin -orev1::rev2", which collapses the
1102 revisions between rev1 and rev2 without deleting rev1 or rev2
1103 themselves.
1104
1105 * There is a new administrative file CVSROOT/config which allows one
1106 to specify miscellaneous aspects of CVS configuration.  Currently
1107 supported here:
1108
1109   - SystemAuth, allows you to prevent pserver from checking for system
1110   usernames/passwords.
1111
1112 For more information see the "config" section of cvs.texinfo.
1113
1114 * When setting up the pserver server, one now must specify the
1115 allowable CVSROOT directories in inetd.conf.  See the Password
1116 authentication server section of cvs.texinfo for details.  Note that
1117 this implies that everyone who is running a pserver server must edit
1118 inetd.conf when upgrading their CVS.
1119
1120 * The client no longer needs an external patch program (assuming both
1121 the client and the server have been updated to the new version).
1122
1123 * "cvs admin [options]" will now recurse.  In previous versions of
1124 CVS, it was an error and one needed to specify "cvs admin [options] ."
1125 to recurse.  This change brings admin in line with the other CVS
1126 commands.
1127
1128 * New "logout" command to remove the password for a remote cvs
1129 repository from the cvspass file.
1130
1131 * Read-only repository access is implemented for the
1132 password-authenticated server (other access methods are just governed
1133 by Unix file permissions, since they require login access to the
1134 repository machine anyway).  See the "Repository" section of
1135 cvs.texinfo for details, including a discussion of security issues.
1136 Note that the requirement that read-only users be able to create locks
1137 and write the history file still applies.
1138
1139 * There is a new administrative file verifymsg which is like editinfo
1140 but merely validates the message, rather than also getting it from the
1141 user.  It therefore works with client/server CVS or if one uses the -m
1142 or -F options to commit.  See the verifymsg section of cvs.texinfo for
1143 details.
1144
1145 * The %s format formerly accepted in loginfo has been extended to
1146 formats such as %{sVv}, so that loginfo scripts have access to the
1147 version numbers being changed.  See the Loginfo section of cvs.texinfo
1148 for details.
1149
1150 * The postscript documentation (doc/cvs.ps) shipped with CVS is now
1151 formatted for US letter size instead of A4.  This is not because we
1152 consider this size "better" than A4, but because we believe that the
1153 US letter version will print better on A4 paper than the other way
1154 around.
1155
1156 * The "cvs export" command is now logged in the history file and there
1157 is a "cvs history -x E" command to select history file entries
1158 produced by export.
1159
1160 * CVS no longer uses the CVS_PASSWORD environment variable.  Storing
1161 passwords in cleartext in an environment variable is a security risk,
1162 especially since (on BSD variants) any user on the system can display
1163 any process's environment using 'ps'.  Users should use the 'cvs
1164 login' command instead.
1165
1166
1167 Changes from 1.8 to 1.9:
1168
1169 * Windows NT client should now work on Windows 95 as well.
1170
1171 * New option "--help-synonyms" prints a list of all recognized command
1172 synonyms.
1173
1174 * The "log" command is now implemented internally rather than via the
1175 RCS "rlog" program.  The main user-visible consequence is that
1176 symbolic branch names now work (for example "cvs log -rbranch1").
1177 Also, the date formats accepted by -d have changed.  They previously
1178 had been a bewildering variety of poorly-documented date formats.  Now
1179 they are the same as the date formats accepted by the -D options to
1180 the other CVS commands, which is also a (different) bewildering
1181 variety of poorly-documented date formats, but at least we are
1182 consistently bewildering :-).
1183
1184 * Encryption is now supported over a Kerberos client/server
1185 connection.  The new "-x" global option requests it.  You must
1186 configure with the --enable-encryption option in order to enable
1187 encryption.
1188
1189 * The format of the CVS commit message has changed slightly when
1190 committing changes on a branch.  The tag on which the commit is
1191 ocurring is now reported correctly in all cases.
1192
1193 * New flag -k in wrappers allows you to specify the keyword expansion
1194 mode for added files based on their name.  For example, you can
1195 specify that files whose name matches *.exe are binary by default.
1196 See the Wrappers section of cvs.texinfo for more details.
1197
1198 * Remote CVS with the "-z" option now uses the zlib library (included
1199 with CVS) to compress all communication between the client and the
1200 server, rather than invoking gzip on each file separately.  This means
1201 that compression is better and there is no need for an external gzip
1202 program (except to interoperate with older version of CVS).
1203
1204 * The "cvs rlog" command is deprecated and running it will print a
1205 warning; use the synonymous "cvs log" command instead.  It is
1206 confusing for rlog to mean the same as log because some other CVS
1207 commands are in pairs consisting of a plain command which operates on
1208 a working directory and an "r" command which does not (diff/rdiff;
1209 tag/rtag).
1210
1211 * "cvs diff" has a bunch of new options, mostly long options.  Most of
1212 these work only if rcsdiff and diff support them, and are named the
1213 same as the corresponding options to diff.
1214
1215 * The -q and -Q command options to "cvs diff" were removed (use the
1216 global options instead).  This brings "cvs diff" into line with the
1217 rest of the CVS commands.
1218
1219 * The "annotate" command can now be used to annotate a revision other
1220 than the head revision on the trunk (see the -r, -D, and -f options in
1221 the annotate node of cvs.texinfo for details).
1222
1223 * The "tag" command has a new option "-c" which checks that all files
1224   are not locally modified before tagging.
1225
1226 * The -d command line option now overrides the cvsroot setting stored
1227 in the CVS/Root file in each working directory, and specifying -d will
1228 cause CVS/Root to be updated.
1229
1230 * Local (non-client/server) CVS now runs on Windows NT.  See
1231 windows-NT/README for details.
1232
1233 * The CVSROOT variable specification has changed to support more
1234 access methods.  In addition to "pserver," "server" (internal rsh
1235 client), "ext" (external rsh client), "kserver" (kerberos), and
1236 "local" (local filesystem access) can now be specified.  For more
1237 details on each method, see cvs.texinfo (there is an index entry for
1238 :local: and each of the other access methods).
1239
1240 * The "login" command no longer prompts the user for username and
1241 hostname, since one will have to provide that information via the `-d'
1242 flag or by setting CVSROOT.
1243
1244 Changes from 1.7 to 1.8:
1245
1246 * New "cvs annotate" command to display the last modification for each
1247 line of a file, with the revision number, user checking in the
1248 modification, and date of the modification.  For more information see
1249 the `annotate' node in cvs.texinfo.
1250
1251 * The cvsinit shell script has been replaced by a cvs init command.
1252 The cvs init command creates some example administrative files which
1253 are similar to the files found in the examples directory (and copied
1254 by cvsinit) in previous releases.
1255
1256 * Added the patterns *.olb *.exe _$* *$ to default ignore list.
1257
1258 * There is now a $USER internal variable for *info files.
1259
1260 * There is no longer a separate `mkmodules' program; the functionality
1261 is now built into `cvs'.  If upgrading an old repository, it is OK to
1262 leave in the lines in the modules file which run mkmodules (the
1263 mkmodules actions will get done twice, but that is harmless); you will
1264 probably want to remove them once you are no longer using the old CVS.
1265
1266 * One can now specify user variables in *info files via the
1267 ${=varname} syntax; there is a -s global option to set them.  See the
1268 Variables node in cvs.texinfo for details.
1269
1270 Changes from 1.6 to 1.7:
1271
1272 * The default ignore list has changed slightly: *.obj has been added
1273 and CVS* has been changed to CVS CVS.adm.
1274
1275 * CVS now supports password authentication when accessing remote
1276 repositories; this is useful for sites that can't use rsh (because of
1277 a firewall, for example), and also don't have kerberos.  See node
1278 "Password authenticated" (in "Remote repositories", in
1279 doc/cvs.texinfo) for more details.  Note: This feature requires both
1280 the client and server to be upgraded.
1281
1282 * Using the -kb option to specify binary files now works--most cases
1283 did not work before.  See the "Binary files" section of
1284 doc/cvs.texinfo for details.
1285
1286 * New developer communication features.  See the "Watches" section of
1287 doc/cvs.texinfo for details.
1288
1289 * RCS keyword "Name" supported for "cvs update -r <tag>" and "cvs
1290 checkout -r <tag>".
1291
1292 * If there is a group whose name matches a compiled in value which
1293 defaults to "cvsadmin", only members of that group can use "cvs
1294 admin".  This replaces the CVS_NOADMIN option.
1295
1296 * CVS now sets the modes of files in the repository based on the
1297 CVSUMASK environment variable or a compiled in value defaulting to
1298 002.  This way other developers will be able to access the files in
1299 the repository regardless of the umask of the developer creating them.
1300
1301 * The command names in .cvsrc now match the official name of the
1302 command, not the one (possibly an alias) by which it was invoked.  If
1303 you had previously relied on "cvs di" and "cvs diff" using different
1304 options, instead use a shell function or alias (for example "alias
1305 cvsdi='cvs diff -u'").  You also can specify global CVS options (like
1306 "-z") using the command name "cvs".
1307
1308 Changes from 1.5 to 1.6:
1309
1310 * Del updated the man page to include all of the new features
1311 of CVS 1.6.
1312
1313 * "cvs tag" now supports a "-r | -D" option for tagging an already
1314 tagged revision / specific revision of a file.
1315
1316 * There is a "taginfo" file in CVSROOT that supports filtering and
1317 recording of tag operations.
1318
1319 * Long options support added, including --help and --version options.
1320
1321 * "cvs release" no longer cares whether or not the directory being
1322 released has an entry in the `modules' file.
1323
1324 * The modules file now takes a -e option which is used instead of -o
1325 for "cvs export".  If your modules file has a -o option which you want
1326 to be used for "cvs export", change it to specify -e as well as -o.
1327
1328 * "cvs export" now takes a -k option to set RCS keyword expansion.
1329 This way you can export binary files.  If you want the old behavior,
1330 you need to specify -kv.
1331
1332 * "cvs update", "cvs rdiff", "cvs checkout", "cvs import", "cvs
1333 release", "cvs rtag", and "cvs tag" used to take -q and -Q options
1334 after the command name (e.g. "cvs update -q").  This was confusing
1335 because other commands, such as "cvs ci", did not.  So the options
1336 after the command name have been removed and you must now specify, for
1337 example, "cvs -q update", which has been supported since CVS 1.3.
1338
1339 * New "wrappers" feature.  This allows you to set a hook which
1340 transforms files on their way in and out of cvs (apparently on the
1341 NeXT there is some particular usefulness in tarring things up in the
1342 repository).  It also allows you to declare files as merge-by-copy
1343 which means that instead of trying to merge the file, CVS will merely
1344 copy the new version.  There is a CVSROOT/cvswrappers file and an
1345 optionsl ~/.cvswrappers file to support this feature.
1346
1347 * You can set CVSROOT to user@host:dir, not just host:dir, if your
1348 username on the server host is different than on the client host.
1349
1350 * VISUAL is accepted as well as EDITOR.
1351
1352 * $CVSROOT is expanded in *info files.
1353
1354 Changes from 1.4A2 to 1.5:
1355
1356 * Remote implementation.  This is very helpful when collaborating on a
1357 project with someone across a wide-area network.  This release can
1358 also be used locally, like other CVS versions, if you have no need for
1359 remote access.
1360
1361 Here are some of the features of the remote implementation:
1362 - It uses reliable transport protocols (TCP/IP) for remote repository
1363   access, not NFS.  NFS is unusable over long distances (and sometimes
1364   over short distances)
1365 - It transfers only those files that have changed in the repository or
1366   the working directory.  To save transmission time, it will transfer
1367   patches when appropriate, and can compress data for transmission.
1368 - The server never holds CVS locks while waiting for a reply from the client;
1369   this makes the system robust when used over flaky networks.
1370
1371 The remote features are documented in doc/cvsclient.texi in the CVS
1372 distribution, but the main doc file, cvs.texinfo, has not yet been
1373 updated to include the remote features.
1374
1375 * Death support.  See src/README-rm-add for more information on this.
1376
1377 * Many speedups, especially from jtc@cygnus.com.
1378
1379 * CVS 1.2 compatibility code has been removed as a speedup.  If you
1380 have working directories checked out by CVS 1.2, CVS 1.3 or 1.4A2 will
1381 try to convert them, but CVS 1.5 and later will not (if the working
1382 directory is up to date and contains no extraneous files, you can just
1383 remove it, and then check out a new working directory).  Likewise if
1384 your repository contains a CVSROOT.adm directory instead of a CVSROOT
1385 directory, you need to rename it.
1386
1387 Fri Oct 21 20:58:54 1994  Brian Berliner  <berliner@sun.com>
1388
1389         * Changes between CVS 1.3 and CVS 1.4 Alpha-2
1390
1391         * A new program, "cvsbug", is provided to let you send bug reports
1392         directly to the CVS maintainers.  Please use it instead of sending
1393         mail to the info-cvs mailing list.  If your build fails, you may
1394         have to invoke "cvsbug" directly from the "src" directory as
1395         "src/cvsbug.sh".
1396
1397         * A new User's Guide and Tutorial, written by Per Cederqvist
1398         <ceder@signum.se> of Signum Support.  See the "doc" directory.  A
1399         PostScript version is included as "doc/cvs.ps".
1400
1401         * The Frequesntly Asked Questions file, FAQ, has been added to the
1402         release.  Unfortunately, its contents are likely out-of-date.
1403
1404         * The "cvsinit" shell script is now installed in the $prefix/bin
1405         directory like the other programs.  You can now create new
1406         CVS repositories with great ease.
1407
1408         * Index: lines are now printed on output from 'diff' and 'rdiff',
1409         in order to facilitate application of patches to multiple subdirs.
1410
1411         * Support for a ~/.cvsrc file, which allows you to specify options
1412         that are always supposed to be given to a specific command.  This
1413         feature shows the non-orthogonality of the option set, since while
1414         there may be an option to turn something on, the option to turn
1415         that same thing off may not exist.
1416
1417         * You can now list subdirectories that you wish to ignore in a
1418         modules listing, such as:
1419
1420                 gcc  -a gnu/gcc, !gnu/gcc/testsuites
1421
1422         which will check out everything underneath gnu/gcc, except
1423         everything underneath gnu/gcc/testsuites.
1424
1425         * It is now much harder to accidentally overwrite an existing tag
1426         name, since attempting to move a tag name will result in a error,
1427         unless the -F (force) flag is given to the tag subcommands.
1428
1429         * Better error checking on matching of the repository used to
1430         check code out from against the repository the current cvs
1431         commnands would use. (Thanks to Mark Baushke <mdb@cisco.com>)
1432
1433         * Better support for sites with multiple CVSROOT repositories has
1434         been contributed.  The file "CVS/Root" in your working directory
1435         is created to hold the full path to the CVS repository and a
1436         simple check is made against your current CVSROOT setting.
1437
1438         * You can now specify an RCS keyword substitution value when you
1439         import files into the repository.
1440
1441         * Uses a much newer version of Autoconf, and conforms to the GNU
1442         coding standards much more closely.  No, it still doesn't have
1443         long option names.
1444
1445         * Code cleanup.  Many passes through gcc -Wall helped to identify
1446         a number of questionable constructs.  Most arbitrary length limits
1447         were removed.
1448
1449         * Profiling to determine bottlenecks helped to identify the best
1450         places to spend time speeding up the code, which was then done.  A
1451         number of performance enhancements in filename matching have sped
1452         up checkouts.
1453
1454         * Many more contributions have been added to the "contrib"
1455         directory.  See the README file in that directory for more
1456         information.
1457
1458         * "cvs commit" will try harder to not change the file's
1459         modification time after the commit.  If the file does not change
1460         as a result of the commit operation, CVS will preserve the
1461         original modification time, thus speeding up future make-type
1462         builds.
1463
1464         * "cvs commit" now includes any removed files in the (optional)
1465         pre-commit checking program that may be invoked.  Previously, only
1466         added and modified files were included.
1467
1468         * It is now possible to commit a file directly onto the trunk at a
1469         specific revision level by doing "cvs commit -r3.0 file.c", where
1470         "3.0" specifies the revision you wish to create.  The file must be
1471         up-to-date with the current head of the trunk for this to succeed.
1472
1473         * "cvs commit" will now function with a pre-commit program that
1474         has arguments specified in the "commitinfo" file.
1475
1476         * The "mkmodules" program will now look within the
1477         $CVSROOT/CVSROOT/checkoutlist" file for any additional files that
1478         should be automatically checked out within CVSROOT; mkmodules also
1479         tries harder to preserve any execute bits the files may have
1480         originally had.
1481
1482         * "cvs diff" is much more accurate about its exit status now.  It
1483         now returns the maximum exit status of any invoked diff.
1484
1485         * The "-I !" option is now supported for the import and update
1486         commands correctly.  It will properly clear the ignore list now.
1487
1488         * Some problems with "cvs import" handling of .cvsignore have been
1489         fixed; as well, some rampant recursion problems with import have
1490         also been fixed.
1491
1492         * "cvs rdiff" (aka "cvs patch") now tries to set the modify time
1493         of any temporary files it uses to match those specified for the
1494         particular revision.  This allows a more accurate patch image to
1495         be created.
1496
1497         * "cvs status" has improved revision descriptions.  "Working
1498         revision" is used for the revision of the working file that you
1499         edit directly; "Repository revision" is the revision of the file
1500         with the $CVSROOT source repository.  Also, the output is clearer
1501         with regard to sticky and branch revisions.
1502
1503         * CVS no longer dumps core when given a mixture of directories and
1504         files in sub-directories (as in "cvs ci file1 dir1/file2").
1505         Instead, arguments are now clumped into their respective directory
1506         and operated on in chunks, together.
1507
1508         * If the CVSEDITOR environment variable is set, that editor is
1509         used for log messages instead of the EDITOR environment variable.
1510         This makes it easy to substitute intelligent programs to make more
1511         elaborate log messages.  Contributed by Mark D Baushke
1512         (mdb@cisco.com).
1513
1514         * Command argument changes:
1515         cvs:                    The "-f" option has been added to ignore
1516                                 the ~/.cvsrc file.
1517         commit:                 Renamed the "-f logfile" option to the
1518                                 "-F logfile" option.  Added the "-f"
1519                                 option to force a commit of the specified
1520                                 files (this disables recursion).
1521         history:                Added "-t timezone" option to force any
1522                                 date-specific output into the specified
1523                                 timezone.
1524         import:                 Added "-d" option to use the file's
1525                                 modification time as the time of the
1526                                 import. Added "-k sub" option to set the
1527                                 default RCS keyword substitution mode for
1528                                 newly-created files.
1529         remove:                 Added "-f" option to force the file's
1530                                 automatic removal if it still exists in
1531                                 the working directory (use with caution).
1532         rtag:                   Added "-F" option to move the tag if it
1533                                 already exists -- new default is to NOT
1534                                 move tags automatically.
1535         tag:                    Added "-F" option to move the tag if it
1536                                 already exists -- new default is to NOT
1537                                 move tags automatically.
1538
1539 Tue Apr  7 15:55:25 1992  Brian Berliner  (berliner at sun.com)
1540
1541         * Changes between CVS 1.3 Beta-3 and official CVS 1.3!
1542
1543         * A new shell script is provided, "./cvsinit", which can be run at
1544         install time to help setup your $CVSROOT area.  This can greatly
1545         ease your entry into CVS usage.
1546
1547         * The INSTALL file has been updated to include the machines on
1548         which CVS has compiled successfully.  I think CVS 1.3 is finally
1549         portable.  Thanks to all the Beta testers!
1550
1551         * Support for the "editinfo" file was contributed.  This file
1552         (located in $CVSROOT/CVSROOT) can be used to specify a special
1553         "editor" to run on a per-directory basis within the repository,
1554         instead of the usual user's editor.  As such, it can verify that
1555         the log message entered by the user is of the appropriate form
1556         (contains a bugid and test validation, for example).
1557
1558         * The manual pages cvs(1) and cvs(5) have been updated.
1559
1560         * The "mkmodules" command now informs you when your modules file
1561         has duplicate entries.
1562
1563         * The "add" command now preserves any per-directory sticky tag when
1564         you add a new directory to your checked-out sources.
1565
1566         * The "admin" command is now a fully recursive interface to the
1567         "rcs" program which operates on your checked-out sources.  It no
1568         longer requires you to specify the full path to the RCS file.
1569
1570         * The per-file sticky tags can now be effectively removed with
1571         "cvs update -A file", even if you had checked out the whole
1572         directory with a per-directory sticky tag.  This allows a great
1573         deal of flexibility in managing the revisions that your checked-out
1574         sources are based upon (both per-directory and per-file sticky
1575         tags).
1576
1577         * The "cvs -n commit" command now works, to show which files are
1578         out-of-date and will cause the real commit to fail, or which files
1579         will fail any pre-commit checks.  Also, the "cvs -n import ..."
1580         command will now show you what it would've done without actually
1581         doing it.
1582
1583         * Doing "cvs commit modules" to checkin the modules file will no
1584         properly run the "mkmodules" program (assuming you have setup your
1585         $CVSROOT/CVSROOT/modules file to do so).
1586
1587         * The -t option in the modules file (which specifies a program to
1588         run when you do a "cvs rtag" operation on a module) now gets the
1589         symbolic tag as the second argument when invoked.
1590
1591         * When the source repository is locked by another user, that user's
1592         login name will be displayed as the holder of the lock.
1593
1594         * Doing "cvs checkout module/file.c" now works even if
1595         module/file.c is in the Attic (has been removed from main-line
1596         development).
1597
1598         * Doing "cvs commit */Makefile" now works as one would expect.
1599         Rather than trying to commit everything recursively, it will now
1600         commit just the files specified.
1601
1602         * The "cvs remove" command is now fully recursive.  To schedule a
1603         file for removal, all you have to do is "rm file" and "cvs rm".
1604         With no arguments, "cvs rm" will schedule all files that have been
1605         physically removed for removal from the source repository at the
1606         next "cvs commit".
1607
1608         * The "cvs tag" command now prints "T file" for each file that was
1609         tagged by this invocation and "D file" for each file that had the
1610         tag removed (as with "cvs tag -d").
1611
1612         * The -a option has been added to "cvs rtag" to force it to clean
1613         up any old, matching tags for files that have been removed (in the
1614         Attic) that may not have been touched by this tag operation.  This
1615         can help keep a consistent view with your tag, even if you re-use
1616         it frequently.
1617
1618 Sat Feb 29 16:02:05 1992  Brian Berliner  (berliner at sun.com)
1619
1620         * Changes between CVS 1.3 Beta-2 and CVS 1.3 Beta-3
1621
1622         * Many portability fixes, thanks to all the Beta testers!  With any
1623         luck, this Beta release will compile correctly on most anything.
1624         Hey, what are we without our dreams.
1625
1626         * CVS finally has support for doing isolated development on a
1627         branch off the current (or previous!) revisions.  This is also
1628         extremely nice for generating patches for previously released
1629         software while development is progressing on the next release.
1630         Here's an example of creating a branch to fix a patch with the 2.0
1631         version of the "foo" module, even though we are already well into
1632         the 3.0 release.  Do:
1633
1634                 % cvs rtag -b -rFOO_2_0 FOO_2_0_Patch foo
1635                 % cvs checkout -rFOO_2_0_Patch foo
1636                 % cd foo
1637                 [[ hack away ]]
1638                 % cvs commit
1639
1640         A physical branch will be created in the RCS file only when you
1641         actually commit the change.  As such, forking development at some
1642         random point in time is extremely light-weight -- requiring just a
1643         symbolic tag in each file until a commit is done.  To fork
1644         development at the currently checked out sources, do:
1645
1646                 % cvs tag -b Personal_Hack
1647                 % cvs update -rPersonal_Hack
1648                 [[ hack away ]]
1649                 % cvs commit
1650
1651         Now, if you decide you want the changes made in the Personal_Hack
1652         branch to be merged in with other changes made in the main-line
1653         development, you could do:
1654
1655                 % cvs commit                 # to make Personal_Hack complete
1656                 % cvs update -A              # to update sources to main-line
1657                 % cvs update -jPersonal_Hack # to merge Personal_Hack
1658
1659         to update your checked-out sources, or:
1660
1661                 % cvs checkout -jPersonal_Hack module
1662
1663         to checkout a fresh copy.
1664
1665         To support this notion of forked development, CVS reserves
1666         all even-numbered branches for its own use.  In addition, CVS
1667         reserves the ".0" and ".1" branches.  So, if you intend to do your
1668         own branches by hand with RCS, you should use odd-numbered branches
1669         starting with ".3", as in "1.1.3", "1.1.5", 1.2.9", ....
1670
1671         * The "cvs commit" command now supports a fully functional -r
1672         option, allowing you to commit your changes to a specific numeric
1673         revision or symbolic tag with full consistency checks.  Numeric
1674         tags are useful for bringing your sources all up to some revision
1675         level:
1676
1677                 % cvs commit -r2.0
1678
1679         For symbolic tags, you can only commit to a tag that references a
1680         branch in the RCS file.  One created by "cvs rtag -b" or from
1681         "cvs tag -b" is appropriate (see below).
1682
1683         * Roland Pesch <pesch@cygnus.com> and K. Richard Pixley
1684         <rich@cygnus.com> were kind enough to contribute two new manual
1685         pages for CVS: cvs(1) and cvs(5).  Most of the new CVS 1.3 features
1686         are now documented, with the exception of the new branch support
1687         added to commit/rtag/tag/checkout/update.
1688
1689         * The -j options of checkout/update have been added.  The "cvs join"
1690         command has been removed.
1691
1692         With one -j option, CVS will merge the changes made between the
1693         resulting revision and the revision that it is based on (e.g., if
1694         the tag refers to a branch, CVS will merge all changes made in
1695         that branch into your working file).
1696
1697         With two -j options, CVS will merge in the changes between the two
1698         respective revisions.  This can be used to "remove" a certain delta
1699         from your working file.  E.g., If the file foo.c is based on
1700         revision 1.6 and I want to remove the changes made between 1.3 and
1701         1.5, I might do:
1702
1703                 % cvs update -j1.5 -j1.3 foo.c          # note the order...
1704
1705         In addition, each -j option can contain on optional date
1706         specification which, when used with branches, can limit the chosen
1707         revision to one within a specific date.  An optional date is
1708         specified by adding a colon (:) to the tag, as in:
1709
1710                 -jSymbolic_Tag:Date_Specifier
1711
1712         An example might be what "cvs import" tells you to do when you have
1713         just imported sources that have conflicts with local changes:
1714
1715                 % cvs checkout -jTAG:yesterday -jTAG module
1716
1717         which tells CVS to merge in the changes made to the branch
1718         specified by TAG in the last 24 hours.  If this is not what is
1719         intended, substitute "yesterday" for whatever format of date that
1720         is appropriate, like:
1721
1722                 % cvs checkout -jTAG:'1 week ago' -jTAG module
1723
1724         * "cvs diff" now supports the special tags "BASE" and "HEAD".  So,
1725         the command:
1726
1727                 % cvs diff -u -rBASE -rHEAD
1728
1729         will effectively show the changes made by others (in unidiff
1730         format) that will be merged into your working sources with your
1731         next "cvs update" command.  "-rBASE" resolves to the revision that
1732         your working file is based on.  "-rHEAD" resolves to the current
1733         head of the branch or trunk that you are working on.
1734
1735         * The -P option of "cvs checkout" now means to Prune empty
1736         directories, as with "update".  The default is to not remove empty
1737         directories.  However, if you do "checkout" with any -r options, -P
1738         will be implied.  I.e., checking out with a tag will cause empty
1739         directories to be pruned automatically.
1740
1741         * The new file INSTALL describes how to install CVS, including
1742         detailed descriptions of interfaces to "configure".
1743
1744         * The example loginfo file in examples/loginfo has been updated to
1745         use the perl script included in contrib/log.pl.  The nice thing
1746         about this log program is that it records the revision numbers of
1747         your change in the log message.
1748
1749         Example files for commitinfo and rcsinfo are now included in the
1750         examples directory.
1751
1752         * All "#if defined(__STDC__) && __STDC__ == 1" lines have been
1753         changed to be "#if __STDC__" to fix some problems with the former.
1754
1755         * The lib/regex.[ch] files have been updated to the 1.3 release of
1756         the GNU regex package.
1757
1758         * The ndbm emulation routines included with CVS 1.3 Beta-2 in the
1759         src/ndbm.[ch] files has been moved into the src/myndbm.[ch] files
1760         to avoid any conflict with the system <ndbm.h> header file.  If
1761         you had a previous CVS 1.3 Beta release, you will want to "cvs
1762         remove ndbm.[ch]" form your copy of CVS as well.
1763
1764         * "cvs add" and "cvs remove" are a bit more verbose, telling you
1765         what to do to add/remove your file permanently.
1766
1767         * We no longer mess with /dev/tty in "commit" and "add".
1768
1769         * More things are quiet with the -Q option set.
1770
1771         * New src/config.h option:  If CVS_BADROOT is set, CVS will not
1772         allow people really logged in as "root" to commit changes.
1773
1774         * "cvs diff" exits with a status of 0 if there were no diffs, 1 if
1775         there were diffs, and 2 if there were errors.
1776
1777         * "cvs -n diff" is now supported so that you can still run diffs
1778         even while in the middle of committing files.
1779
1780         * Handling of the CVS/Entries file is now much more robust.
1781
1782         * The default file ignore list now includes "*.so".
1783
1784         * "cvs import" did not expand '@' in the log message correctly.  It
1785         does now.  Also, import now uses the ignore file facility
1786         correctly.
1787
1788         Import will now tell you whether there were conflicts that need to
1789         be resolved, and how to resolve them.
1790
1791         * "cvs log" has been changed so that you can "log" things that are
1792         not a part of the current release (in the Attic).
1793
1794         * If you don't change the editor message on commit, CVS now prompts
1795         you with the choice:
1796
1797                 !)reuse this message unchanged for remaining dirs
1798
1799         which allows you to tell CVS that you have no intention of changing
1800         the log message for the remainder of the commit.
1801
1802         * It is no longer necessary to have CVSROOT set if you are using
1803         the -H option to get Usage information on the commands.
1804
1805         * Command argument changes:
1806         checkout:               -P handling changed as described above.
1807                                 New -j option (up to 2 can be specified)
1808                                 for doing rcsmerge kind of things on
1809                                 checkout.
1810         commit:                 -r option now supports committing to a
1811                                 numeric or symbolic tags, with some
1812                                 restrictions.  Full consistency checks will
1813                                 be done.
1814                                 Added "-f logfile" option, which tells
1815                                 commit to glean the log message from the
1816                                 specified file, rather than invoking the
1817                                 editor.
1818         rtag:                   Added -b option to create a branch tag,
1819                                 useful for creating a patch for a previous
1820                                 release, or for forking development.
1821         tag:                    Added -b option to create a branch tag,
1822                                 useful for creating a patch for a previous
1823                                 release, or for forking development.
1824         update:                 New -j option (up to 2 can be specified)
1825                                 for doing rcsmerge kind of things on
1826                                 update.
1827
1828 Thu Jan  9 10:51:35 MST 1992 Jeff Polk (polk at BSDI.COM)
1829
1830         * Changes between CVS 1.3 Beta-1 and CVS 1.3 Beta-2
1831
1832         * Thanks to K. Richard Pixley at Cygnus we now have function
1833         prototypes in all the files
1834
1835         * Some small changes to configure for portability.  There have
1836         been other portability problems submitted that have not been fixed
1837         (Brian will be working on those).  Additionally all __STDC__
1838         tests have been modified to check __STDC__ against the constant 1 
1839         (this is what the Second edition of K&R says must be true).
1840
1841         * Lots of additional error checking for forked processes (run_exec)
1842         (thanks again to K. Richard Pixley)
1843
1844         * Lots of miscellaneous bug fixes - including but certainly not 
1845         limited to:
1846                 various commit core dumps
1847                 various update core dumps
1848                 bogus results from status with numeric sticky tags
1849                 commitprog used freed memory
1850                 Entries file corruption caused by No_Difference
1851                 commit to revision broken (now works if branch exists)
1852                 ignore file processing broken for * and !
1853                 ignore processing didn't handle memory reasonably
1854                 miscellaneous bugs in the recursion processor
1855                 file descriptor leak in ParseInfo
1856                 CVSROOT.adm->CVSROOT rename bug
1857                 lots of lint fixes
1858
1859         * Reformatted all the code in src (with GNU indent) and then 
1860         went back and fixed prototypes, etc since indent gets confused.  The
1861         rationale is that it is better to do it sooner than later and now
1862         everything is consistent and will hopefully stay that way.
1863         The basic options to indent were: "-bad -bbb -bap -cdb -d0 -bl -bli0 
1864         -nce -pcs -cs -cli4 -di1 -nbc -psl -lp -i4 -ip4 -c41"  and then
1865         miscellaneous formatting fixes were applied.  Note also that the 
1866         "-nfc1" or "-nfca" may be appropriate in files where comments have
1867         been carefully formatted (e.g, modules.c).
1868
1869 Sat Dec 14 20:35:22 1991  Brian Berliner  (berliner at sun.com)
1870
1871         * Changes between CVS 1.2 and CVS 1.3 Beta are described here.
1872
1873         * Lots of portability work.  CVS now uses the GNU "configure"
1874         script to dynamically determine the features provided by your
1875         system.  It probably is not foolproof, but it is better than
1876         nothing.  Please let me know of any portability problems.  Some
1877         file names were changed to fit within 14-characters.
1878
1879         * CVS has a new RCS parser that is much more flexible and
1880         extensible.  It should read all known RCS ",v" format files.
1881
1882         * Most of the commands now are fully recursive, rather than just
1883         operating on the current directory alone.  This includes "commit",
1884         which makes it real easy to do an "atomic" commit of all the
1885         changes made to a CVS hierarchy of sources.  Most of the commands
1886         also correctly handle file names that are in directories other than
1887         ".", including absolute path names.  Commands now accept the "-R"
1888         option to force recursion on (though it is always the default now)
1889         and the "-l" option to force recursion off, doing just "." and not
1890         any sub-directories.
1891
1892         * CVS supports many of the features provided with the RCS 5.x
1893         distribution - including the new "-k" keyword expansion options.  I
1894         recommend using RCS 5.x (5.6 is the current official RCS version)
1895         and GNU diff 1.15 (or later) distributions with CVS.
1896
1897         * Checking out files with symbolic tags/dates is now "sticky", in
1898         that CVS remembers the tag/date used for each file (and directory)
1899         and will use that tag/date automatically on the next "update" call.
1900         This stickyness also holds for files checked out with the the new
1901         RCS 5.x "-k" options.
1902
1903         * The "cvs diff" command now recognizes all of the rcsdiff 5.x
1904         options.  Unidiff format is available by installing the GNU
1905         diff 1.15 distribution.
1906
1907         * The old "CVS.adm" directories created on checkout are now called
1908         "CVS" directories, to look more like "RCS" and "SCCS".  Old CVS.adm
1909         directories are automagically converted to CVS directories.  The
1910         old "CVSROOT.adm" directory within the source repository is
1911         automagically changed into a "CVSROOT" directory as well.
1912
1913         * Symbolic links in the source repository are fully supported ONLY
1914         if you use RCS 5.6 or later and (of course) your system supports
1915         symlinks.
1916
1917         * A history database has been contributed which maintains the
1918         history of certain CVS operations, as well as providing a wide array
1919         of querying options.
1920
1921         * The "cvs" program has a "-n" option which can be used with the
1922         "update" command to show what would be updated without actually
1923         doing the update, like:  "cvs -n update".  All usage statements
1924         have been cleaned up and made more verbose.
1925
1926         * The module database parsing has been rewritten.  The new format
1927         is compatible with the old format, but with much more
1928         functionality.  It allows modules to be created that grab pieces or
1929         whole directories from various different parts of your source
1930         repository.  Module-relative specifications are also correctly
1931         recognized now, like "cvs checkout module/file.c".
1932
1933         * A configurable template can be specified such that on a "commit", 
1934         certain directories can supply a template that the user must fill
1935         before completing the commit operation.
1936
1937         * A configurable pre-commit checking program can be specified which
1938         will run to verify that a "commit" can happen.  This feature can be
1939         used to restrict certain users from changing certain pieces of the
1940         source repository, or denying commits to the entire source
1941         repository.
1942
1943         * The new "cvs export" command is much like "checkout", but
1944         establishes defaults suitable for exporting code to others (expands
1945         out keywords, forces the use of a symbolic tag, and does not create
1946         "CVS" directories within the checked out sources.
1947
1948         * The new "cvs import" command replaces the deprecated "checkin"
1949         shell script and is used to import sources into CVS control.  It is
1950         also much faster for the first-time import.  Some algorithmic
1951         improvements have also been made to reduce the number of
1952         conflicting files on next-time imports.
1953
1954         * The new "cvs admin" command is basically an interface to the
1955         "rcs" program.  (Not yet implemented very well).
1956
1957         * Signal handling (on systems with BSD or POSIX signals) is much
1958         improved.  Interrupting CVS now works with a single interrupt!
1959
1960         * CVS now invokes RCS commands by direct fork/exec rather than
1961         calling system(3).  This improves performance by removing a call to
1962         the shell to parse the arguments.
1963
1964         * Support for the .cvsignore file has been contributed.  CVS will
1965         now show "unknown" files as "? filename" as the result of an "update"
1966         command.  The .cvsignore file can be used to add files to the
1967         current list of ignored files so that they won't show up as unknown.
1968
1969         * Command argument changes:
1970         cvs:            Added -l to turn off history logging.
1971                         Added -n to show what would be done without actually
1972                         doing anything.
1973                         Added -q/-Q for quiet and really quiet settings.
1974                         Added -t to show debugging trace.
1975         add:            Added -k to allow RCS 5.x -k options to be specified.
1976         admin:          New command; an interface to rcs(1).
1977         checkout:       Added -A to reset sticky tags/date/options.
1978                         Added -N to not shorten module paths.
1979                         Added -R option to force recursion.
1980                         Changed -p (prune empty directories) to -P option.
1981                         Changed -f option; forcing tags match is now default.
1982                         Added -p option to checkout module to standard output.
1983                         Added -s option to cat the modules db with status.
1984                         Added -d option to checkout in the specified directory.
1985                         Added -k option to use RCS 5.x -k support.
1986         commit:         Removed -a option; use -l instead.
1987                         Removed -f option.
1988                         Added -l option to disable recursion.
1989                         Added -R option to force recursion.
1990                         If no files specified, commit is recursive.
1991         diff:           Now recognizes all RCS 5.x rcsdiff options.
1992                         Added -l option to disable recursion.
1993                         Added -R option to force recursion.
1994         history:        New command; displays info about CVS usage.
1995         import:         Replaces "checkin" shell script; imports sources
1996                         under CVS control.  Ignores files on the ignore
1997                         list (see -I option or .cvsignore description above).
1998         export:         New command; like "checkout", but w/special options
1999                         turned on by default to facilitate exporting sources.
2000         join:           Added -B option to join from base of the branch;
2001                         join now defaults to only joining with the top two
2002                         revisions on the branch.
2003                         Added -k option for RCS 5.x -k support.
2004         log:            Supports all RCS 5.x options.
2005                         Added -l option to disable recursion.
2006                         Added -R option to force recursion.
2007         patch:          Changed -f option; forcing tags match is now default.
2008                         Added -c option to force context-style diffs.
2009                         Added -u option to support unidiff-style diffs.
2010                         Added -V option to support RCS specific-version
2011                         keyword expansion formats.
2012                         Added -R option to force recursion.
2013         remove:         No option changes.  It's a bit more verbose.
2014         rtag:           Equivalent to the old "cvs tag" command.
2015                         No option changes.  It's a lot faster for re-tag.
2016         status:         New output formats with more information.
2017                         Added -l option to disable recursion.
2018                         Added -R option to force recursion.
2019                         Added -v option to show symbolic tags for files.
2020         tag:            Functionality changed to tag checked out files
2021                         rather than modules; use "rtag" command to get the
2022                         old "cvs tag" behaviour.
2023         update:         Added -A to reset sticky tags/date/options.
2024                         Changed -p (prune empty directories) to -P option.
2025                         Changed -f option; forcing tags match is now default.
2026                         Added -p option to checkout module to standard output.
2027                         Added -I option to add files to the ignore list.
2028                         Added -R option to force recursion.
2029
2030         Major Contributors:
2031
2032         * Jeff Polk <polk@bsdi.com> rewrote most of the grody code of CVS
2033         1.2.  He made just about everything dynamic (by using malloc),
2034         added a generic hashed list manager, re-wrote the modules database
2035         parsing in a compatible - but extended way, generalized directory
2036         hierarchy recursion for virtually all the commands (including
2037         commit!), generalized the loginfo file to be used for pre-commit
2038         checks and commit templates, wrote a new and flexible RCS parser,
2039         fixed an uncountable number of bugs, and helped in the design of
2040         future CVS features.  If there's anything gross left in CVS, it's
2041         probably my fault!
2042
2043         * David G. Grubbs <dgg@odi.com> contributed the CVS "history" and
2044         "release" commands.  As well as the ever-so-useful "-n" option of
2045         CVS which tells CVS to show what it would do, without actually
2046         doing it.  He also contributed support for the .cvsignore file.
2047
2048         * Paul Sander, HaL Computer Systems, Inc. <paul@hal.com> wrote and
2049         contributed the code in lib/sighandle.c.  I added support for
2050         POSIX, BSD, and non-POSIX/non-BSD systems.
2051
2052         * Free Software Foundation contributed the "configure" script and
2053         other compatibility support in the "lib" directory, which will help
2054         make CVS much more portable.
2055
2056         * Many others have contributed bug reports and enhancement requests.
2057         Some have even submitted actual code which I have not had time yet
2058         to integrate into CVS.  Maybe for the next release.
2059
2060         * Thanks to you all!
2061
2062 Wed Feb  6 10:10:58 1991  Brian Berliner  (berliner at sun.com)
2063
2064         * Changes from CVS 1.0 Patchlevel 1 to CVS 1.0 Patchlevel 2; also
2065         known as "Changes from CVS 1.1 to CVS 1.2".
2066
2067         * Major new support with this release is the ability to use the
2068         recently-posted RCS 5.5 distribution with CVS 1.2.  See below for
2069         other assorted bug-fixes that have been thrown in.
2070
2071         * ChangeLog (new): Added Emacs-style change-log file to CVS 1.2
2072         release.  Chronological description of changes between release.
2073
2074         * README: Small fixes to installation instructions.  My email
2075         address is now "berliner@sun.com".
2076
2077         * src/Makefile: Removed "rcstime.h".  Removed "depend" rule.
2078
2079         * src/partime.c:  Updated to RCS 5.5 version with hooks for CVS.
2080         * src/maketime.c: Updated to RCS 5.5 version with hooks for CVS.
2081         * src/rcstime.h:  Removed from the CVS 1.2 distribution.
2082         Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
2083
2084         * src/checkin.csh: Support for RCS 5.5 parsing.
2085         Thanks to Paul Eggert <eggert@twinsun.com> for this change.
2086
2087         * src/collect_sets.c (Collect_Sets): Be quieter if "-f" option is
2088         specified.  When checking out files on-top-of other files that CVS
2089         doesn't know about, run a diff in the hopes that they are really
2090         the same file before aborting.
2091
2092         * src/commit.c (branch_number): Fix for RCS 5.5 parsing.
2093         Thanks to Paul Eggert <eggert@twinsun.com> for this change.
2094
2095         * src/commit.c (do_editor): Bug fix - fprintf missing argument
2096         which sometimes caused core dumps.
2097
2098         * src/modules.c (process_module): Properly NULL-terminate
2099         update_dir[] in all cases.
2100
2101         * src/no_difference.c (No_Difference): The wrong RCS revision was
2102         being registered in certain (strange) cases.
2103
2104         * src/patch.c (get_rcsdate): New algorithm.  No need to call
2105         maketime() any longer.
2106         Thanks to Paul Eggert <eggert@twinsun.com> for this change.
2107
2108         * src/patchlevel.h: Increased patch level to "2".
2109
2110         * src/subr.c (isdir, islink): Changed to compare stat mode bits
2111         correctly.
2112
2113         * src/tag.c (tag_file): Added support for following symbolic links
2114         that are in the master source repository when tagging.  Made tag
2115         somewhat quieter in certain cases.
2116
2117         * src/update.c (update_process_lists): Unlink the user's file if it
2118         was put on the Wlist, meaning that the user's file is not modified
2119         and its RCS file has been removed by someone else.
2120
2121         * src/update.c (update): Support for "cvs update dir" to correctly
2122         just update the argument directory "dir".
2123
2124         * src/cvs.h: Fixes for RCS 5.5 parsing.
2125         * src/version_number.c (Version_Number): Fixes for parsing RCS 5.5
2126         and older RCS-format files.
2127         Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
2128
2129         * src/version_number.c (Version_Number): Bug fixes for "-f" option.
2130         Bug fixes for parsing with certain branch numbers.  RCS
2131         revision/symbol parsing is much more solid now.
2132
2133 Wed Feb 14 10:01:33 1990  Brian Berliner  (berliner at sun.com)
2134
2135         * Changes from CVS 1.0 Patchlevel 0 to CVS 1.0 Patchlevel 1; also
2136         known as "Changes from CVS 1.0 to CVS 1.1".
2137
2138         * src/patch.c (get_rcsdate): Portability fix.  Replaced call to
2139         timelocal() with call to maketime().
2140
2141 Mon Nov 19 23:15:11 1990  Brian Berliner  (berliner at prisma.com)
2142
2143         * Sent CVS 1.0 release to comp.sources.unix moderator and FSF.
2144
2145         * Special thanks to Dick Grune <dick@cs.vu.nl> for his work on the
2146         1986 version of CVS and making it available to the world.  Dick's
2147         version is available on uunet.uu.net in the
2148         comp.sources.unix/volume6/cvs directory.