PageRenderTime 58ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 0ms

/contrib/cvs/NEWS

https://bitbucket.org/freebsd/freebsd-head/
#! | 1905 lines | 1423 code | 482 blank | 0 comment | 0 complexity | 4757c658c84975a79a2bc2338854851d MD5 | raw file
Possible License(s): MPL-2.0-no-copyleft-exception, BSD-3-Clause, LGPL-2.0, LGPL-2.1, BSD-2-Clause, 0BSD, JSON, AGPL-1.0, GPL-2.0
  1. Changes since 1.11.22:
  2. **********************
  3. NEW FEATURES
  4. * A new log option -n reverts the -N option which may be in a .cvsrc
  5. file.
  6. * The `cvs blame' command is now a synonym for the `cvs annotate' command.
  7. * The :extssh: method will use $CVS_SSH if set, or fall back on "ssh"
  8. by default (but may be explicitly set using the --with-ssh flag to
  9. configure).
  10. * There is a new IgnoreUnknownConfigKeys option available for
  11. CVSROOT/config to aid in the transition to newer versions of CVS.
  12. BUG FIXES
  13. * Merges of file removals using -j options are a little smarter.
  14. * `cvs add' checks more thoroughly for `CVS' directories in the argument list.
  15. * `cvs server' now accepts `--allow-root=PATH' options.
  16. * `cvs import' no longer attempts to send CVS metadata to the server.
  17. * `cvs import' makes more of an effort not to import paths containing files
  18. and directories named `CVS'.
  19. * The CVS server will no longer allow clients to run `cvs init'.
  20. * Applying diffs when checking out very old revisions has been reduced from an
  21. O(n^2) operation to an O(n) thanks to a patch from Michael J. Smith
  22. <msmith@ideorlando.org> and additional touch-up work from the CVS team.
  23. * Thanks to report from Paul Eggert <eggert@CS.UCLA.EDU>, an assertion failure
  24. that could occur when "." was in the path (e.g. `cvs co /cvsroot/./module')
  25. has been removed.
  26. * Thanks to a report from Peter Toft <pto@linuxbog.dk>, CVS server now sends
  27. correct patch files more often when the RCS `Name' keyword is present in
  28. a working file (bug #17302).
  29. * Thanks to a report from Dan Peterson <dbpete@aol.com>, clients now send the
  30. right set of commands to the server when asked to update directories with
  31. trailing slashes on their name.
  32. * Thanks to a report and patch from <mbarabas@redhat.com>, potential stack
  33. corruption during pserver login is avoided (bug #16961).
  34. * The :extssh: method is now properly recognized as an alias for :ext:.
  35. DEVELOPER ISSUES
  36. * We've standardized on Autoconf version 2.61 to get a bug fix that notes
  37. that the AIX C compiler's default mode isn't quite C89 and sets the
  38. correct mode instead.
  39. * We've standardized on Autoconf version 1.10 because it lets us simplify our
  40. sources.
  41. Changes from 1.11.21 to 1.11.22:
  42. ********************************
  43. BUG FIXES
  44. * The CVS client again correctly reports files with conflicts when using
  45. servers running CVS 1.11.20/1.12.12, or earlier (and maybe 3rd party
  46. servers).
  47. * The GSSAPI server should now build under HP-UX.
  48. * `cvs rtag' now correctly tags files that have been removed from the trunk.
  49. * Code efficiency has been improved slightly.
  50. * A rare race condition that could leave a lock on the val-tags file has been
  51. avoided.
  52. * A potential buffer overflow in the history command has been fixed.
  53. * Thanks to a report and patch from Garrett Rooney <grooney@collab.net>, paused
  54. trigger processes no longer cause the CVS server to consume 100% CPU.
  55. * Thanks to a suggestion from Joseph P. Skudlarek <Jskud@Jskud.com>, an
  56. :extssh: has been added as a synonym of the :ext: access method, as a
  57. kindness to users of old version of Eclipse.
  58. * Misc documentation updates and minor bug fixes.
  59. Changes from 1.11.20 to 1.11.21:
  60. ********************************
  61. BUG FIXES
  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. * Thanks to Rahul Bhargava <rahul@wandisco.com>, heavily loaded systems
  65. suffering from a disk crash or power failure will not lose data they claimed
  66. to have committed.
  67. * CVS server now handles conflict markers in Entry requests as documented.
  68. * CVS now remembers that binary file merge conflicts occurred until the
  69. timestamp of the updated binary file changes.
  70. * CVS client now saves some bandwidth by not sending the contents of files
  71. with conflicts to the server when it isn't needed.
  72. * CVS now does correct locking during import.
  73. * A problem where the server could block indefinitely waiting for an EOF from
  74. the client when compression was enabled has been fixed.
  75. * `cvs diff' no longer splits its arguments on spaces.
  76. * Thanks to an old report and patch from Stewart Brodie <stewart@eh.org>, a
  77. potential crash in response to a corrupt RCS file has been fixed.
  78. * CVS now locks the history and val-tags files before writing to them.
  79. Especially with large repositories, users should no longer see new warnings
  80. about corrupt history records when using the `cvs history' command. Existing
  81. corrupt history records will still need to be removed manually. val-tags
  82. corruption should have had less obvious effects, but removing the
  83. CVSROOT/val-tags file and allowing a 1.11.21 or later version of CVS to
  84. regenerate it may eliminate a few odd behaviors and possibly cause a slight
  85. speed up of read transactions in large repositories over time.
  86. BUILD ISSUES
  87. * The RPM spec file works again with the most modern versions of `rpm'.
  88. DEVELOPER ISSUES
  89. * We've standardized on Automake 1.9.6 to get some at new features that make
  90. our jobs easier. See the HACKING file for more on using the autotools with
  91. CVS.
  92. Changes from 1.11.19 to 1.11.20:
  93. ********************************
  94. SERVER SECURITY FIXES
  95. * Thanks to a report from Alen Zukich <alen.zukich@klocwork.com>, several minor
  96. security issues have been addressed. One was a buffer overflow that is
  97. potentially serious but which may not be exploitable, assigned CAN-2005-0753
  98. by the Common Vulnerabilities and Exposures Project
  99. <http://www.cve.mitre.org>. Other fixes resulting from Alen's report include
  100. repair of an arbitrary free with no known exploit and several plugged memory
  101. leaks and potentially freed NULL pointers which may have been exploitable for
  102. a denial of service attack.
  103. * Thanks to a report from Craig Monson <craig@malachiarts.com>, minor
  104. potential vulnerabilities in the contributed Perl scripts have been fixed.
  105. The confirmed vulnerability could allow the execution of arbitrary code on
  106. the CVS server, but only if a user already had commit access and if one of
  107. the contrib scripts was installed improperly, a condition which should have
  108. been quickly visible to any administrator. The complete description of the
  109. problem is here: <https://ccvs.cvshome.org/issues/show_bug.cgi?id=224>. If
  110. you were making use of any of the contributed trigger scripts on a CVS
  111. server, you should probably still replace them with the new versions, to be
  112. on the safe side.
  113. Unfortunately, our fix is incomplete. Taint-checking has been enabled in all
  114. the contributed Perl scripts intended to be run as trigger scripts, but no
  115. attempt has been made to ensure that they still run in taint mode. You will
  116. most likely have to tweak the scripts in some way to make them run. Please
  117. send any patches you find necessary back to <bug-cvs@nongnu.org> so that we
  118. may again ship fully enabled scripts in the future.
  119. You should also make sure that any home-grown Perl scripts that you might
  120. have installed as CVS triggers also have taint-checking enabled. This can be
  121. done by adding `-T' on the scripts' #! lines. Please try running
  122. `perldoc perlsec' if you would like more information on general Perl security
  123. and taint-checking.
  124. BUG FIXES
  125. * Thanks to a report and a patch from Georg Scwharz <georg.scwarz@freenet.de>
  126. CVS now builds without error on IRIX 5.3
  127. DEVELOPER ISSUES
  128. * We've standardized on Automake 1.9.5 to get some at new features that make
  129. our jobs easier. See the HACKING file for more on using the autotools with
  130. CVS.
  131. Changes from 1.11.18 to 1.11.19:
  132. ********************************
  133. BUG FIXES
  134. * Thanks to a patch from Jim Hyslop <jhyslop@ieee.org>, issuing
  135. 'cvs watch on' or 'cvs watch off' in an empty directory no longer
  136. clears any watchers in that directory.
  137. * An intermittant assertion failure in checkout has been fixed.
  138. * Thanks to a report from Chris Bohn <cbohn@rrinc.com>, all the source files
  139. needed for the Windows "red file" fix are actually included in the
  140. distribution.
  141. * Misc bug and documentation fixes.
  142. Changes from 1.11.17 to 1.11.18:
  143. ********************************
  144. BUG FIXES
  145. * Thanks to a report from Gottfried Ganssauge <gotti@cvshome.org>, CVS no
  146. longer exits when it encounters links pointing to paths containing more
  147. than 128 characters.
  148. * Thanks to a report from Dan Peterson <dbpete@aol.com>, error messages from
  149. GSSAPI servers are no longer truncated.
  150. * Thanks to a report from Dan Peterson <dbpete@aol.com>, attempts to resurrect
  151. a file on the trunk that was added on a branch no longer causes an assertion
  152. failure.
  153. * Thanks to a report from Dan Peterson <dbpete@aol.com>, imports to branches
  154. like "1.1." no longer create corrupt RCS archives.
  155. * Thanks to a report from Chris Bohn <cbohn@rrinc.com>, links from J.C. Hamlin
  156. <jchamlin@ibsys.com>, and code posted by Jonathan Gilligan, we think we have
  157. finally corrected the Windows "red-file" (daylight savings time) bug once and
  158. for all.
  159. * Thanks to a patch from Jeroen Ruigrok/asmodai <asmodai@wxs.nl>, the
  160. log_accum.pl script should no longer elicit warnings from Perl 5.8.5.
  161. * The r* commands (rlog, rls, etc.) can once again handle requests to run
  162. against the entire repository (e.g. `cvs rlog .'). Thanks go to Dan Peterson
  163. <dbpete@aol.com> for the report.
  164. * A problem where the attempted access of files via tags beginning with spaces
  165. could cause the CVS server to hang has been fixed. This was a particular
  166. problem with WinCVS clients because users would sometimes accidentally
  167. include spaces in tags pasted into a dialog box. This fix also altered some
  168. of the error messages generated by the use of invalid tags. Thanks go to Dan
  169. Peterson <dbpete@aol.com> for the report.
  170. * Thanks to James E Wilson <wilson@specifixinc.com> for a bug fix to
  171. modules processing "gcc-core -a !gcc/f gcc" will no longer exclude
  172. gcc/fortran by mistake.
  173. * Thanks to Conrad Pino <conrad@pino.com>, the Windows build works once again.
  174. * Misc updates to the manual.
  175. DEVELOPER ISSUES
  176. * We've standardized on Automake 1.9.3 to get some at new features that make
  177. our jobs easier. See the note below on the Autoconf upgrade for more
  178. details.
  179. * We've standardized on Autoconf version 2.59 to get presumed bug fixes and
  180. features, but nothing specific. Mostly, once we decide to upgrade one of the
  181. autotools we just figure it'll save time later to grab the most current
  182. versions of the others too. See the HACKING file for more on using the
  183. autotools with CVS.
  184. Changes from 1.11.16 to 1.11.17:
  185. ********************************
  186. SERVER SECURITY FIXES
  187. * Thanks to Stefan Esser & Sebastian Krahmer, several potential security
  188. problems have been fixed. The ones which were considered dangerous enough
  189. to catalogue were assigned issue numbers CAN-2004-0416, CAN-2004-0417, &
  190. CAN-2004-0418 by the Common Vulnerabilities and Exposures Project. Please
  191. see <http://www.cve.mitre.org> for more information.
  192. * A potential buffer overflow vulnerability in the server has been fixed.
  193. This addresses the Common Vulnerabilities and Exposures Project's issue
  194. #CAN-2004-0414. Please see <http://www.cve.mitre.org> for more information.
  195. Changes from 1.11.15 to 1.11.16:
  196. ********************************
  197. SERVER SECURITY FIXES
  198. * A potential buffer overflow vulnerability in the server has been fixed.
  199. Prior to this patch, a malicious client could potentially use carefully
  200. crafted server requests to run arbitrary programs on the CVS server machine.
  201. This addresses the Common Vulnerabilities and Exposures Project's issue
  202. #CAN-2004-0396. Please see <http://www.cve.mitre.org> for more information.
  203. BUG FIXES
  204. * The Microsoft Visual C++ workspace and project files have been repaired and
  205. regenerated with MSVC++ 6.0.
  206. * The cvs.1 man page is now generated automatically from a section of the CVS
  207. Manual.
  208. * Thanks to a report from Mark Andrews at the Internet Systems Consortium, the
  209. :ext: connection method no longer relies on a transparent transport that uses
  210. an argument processor that can handle arbitrary ordering of options and other
  211. arguments when using a username other than the caller's.
  212. * Thanks to Ken Raeburn at MIT, directory deletion, whether via `cvs release'
  213. or empty directory pruning, now works on network shares under Windows XP.
  214. Changes from 1.11.14 to 1.11.15:
  215. ********************************
  216. SERVER SECURITY ISSUES
  217. * Piped checkouts of paths above $CVSROOT no longer work. Previously, clients
  218. could have requested the contents of RCS archive files anywhere on a CVS
  219. server. This addresses CVE issue CAN-2004-0405. Please see
  220. <http://www.cve.mitre.org> for more information.
  221. CLIENT SECURITY ISSUES
  222. * Clients now check paths from the server to verify that they are within one of
  223. the sandboxes the user requested be updated. Previously, a trojan server
  224. could have written or overwritten files anywhere the user had access,
  225. presenting a serious security risk. This addresses CVE issue CAN-2004-1080.
  226. Please see <http://www.cve.mitre.org> for more information.
  227. GENERAL USER ISSUES
  228. * Method options (used by WinCVS & CVS 1.12.7+) in CVSROOTs are ignored.
  229. * Configure no longer checks the $TMPDIR, $TMP, & $TEMP variables to set the
  230. default temporary directory.
  231. * CVS on Cygwin correctly handles X:\ style paths.
  232. * Import now uses backslash rather than slash on Windows when checking for
  233. "CVS" directories to ignore in import commands.
  234. * Relative paths containing up-references (`..') should now work in
  235. client/server mode (client fix).
  236. * A race condition between the ordering of messages from CVS and messages from
  237. called scripts in client/server mode has been removed (server fix).
  238. * Resurrected files now get their modes and timestamps set correctly and a
  239. longstanding bug involving resurrection of an uncommitted removal has been
  240. fixed (server fix).
  241. * Some resurrection (cvs add) status messages have changed slightly.
  242. * `cvs release' now works with Kerberos or GSSAPI encryption enabled (server
  243. fix).
  244. * File resurrection from a previously existing revision no longer just reports
  245. that it works (server fix).
  246. * Misc error & status message corrections.
  247. * Diffing of locally added files against arbitrary revisions in an RCS archive
  248. is now allowed when a file of the same name exists or used to exist on some
  249. branch (server fix).
  250. * Misc documentation fixes.
  251. Changes from 1.11.13 to 1.11.14:
  252. ********************************
  253. GENERAL USER ISSUES
  254. * Imports will now always ignore directories and files named `CVS' to avoid
  255. violating assumptions made by other parts of CVS.
  256. * A problem with `cvs release' of subdirs that could corrupt CVS/Entries files
  257. has been fixed (client/server).
  258. * The CVS server's protocol check for unused data from the client is no longer
  259. called automatically at program exit in order to avoid potential recursive
  260. calls to error when the first close is due to memory allocation or similar
  261. problems that cause calls to error() to fail. The check is still made when
  262. the server program exits normally.
  263. * The spec file has been updated to work with more recent versions of RPM.
  264. * Several memory leaks have been plugged (client/server).
  265. DEVELOPER ISSUES
  266. * Misc cosmetic, readability, and commenting fixes.
  267. Changes from 1.11.12 to 1.11.13:
  268. ********************************
  269. GENERAL USER ISSUES
  270. * Several memory leaks have been plugged.
  271. * Thanks to Ville Skyttä the man page has a few less spelling errors and is
  272. slightly more accurate.
  273. * An unlikely potential segfault when using the :fork: connection method has
  274. been fixed.
  275. * The CVS server has had the protocol check for unused data from the client
  276. partially restored.
  277. * A fix has been included that should avoid a very rare race condition that
  278. could cause a CVS server to exit with a "broken pipe" message.
  279. * A minor problem with the nmake build file that was preventing the source from
  280. compiling under Windows has been fixed.
  281. * Tests have been added to the test suite.
  282. DEVELOPER ISSUES
  283. * Misc cosmetic, readability, and commenting fixes.
  284. Changes from 1.11.11 to 1.11.12:
  285. ********************************
  286. GENERAL USER ISSUES
  287. * Infinite alias loops in the modules file are now checked for and avoided.
  288. * Clients on case insensitive systems now preserve the case of directories in
  289. CVS/Entries, in addition to files, for use in communications with the CVS
  290. server.
  291. * Some previously untested behavior is now being tested.
  292. * Server support for case insensitive clients has been removed in favor of the
  293. server relying on the client to preserve the case of checked out files, as
  294. per the CVS client/server protocol spec. This is not as drastic as it may
  295. sound, as all of the current tests still pass without modification when run
  296. from a case insensitive client to a case sensitive server. This change
  297. disables little previous functionality, enables access to more of the
  298. possible namespace to users on systems with case insensitive file systems,
  299. fixes a few bugs, and in the end this should provide a major stability
  300. improvement.
  301. * Thanks to Ville Skyttä the man page is a bit more accurate.
  302. * Thanks to Ville Skyttä some unused variables were removed from the log_accum
  303. Perl script in contrib.
  304. * Thanks to Alexey Mahotkin, a bug that prevented CVS from being compiled with
  305. Kerberos 4 authentication enabled has been fixed.
  306. * A minor bug that caused CVS to fail to report an inifinte alias loop in the
  307. modules file when portions of the alias definition contained trailing slashes
  308. has been fixed.
  309. * A bug in the gzip code that could cause heap corruption and segfaults in CVS
  310. servers talking to clients less than 1.8 and some modern third-party CVS
  311. clients has been fixed.
  312. * mktemp.sh is now included with the source distribution so that the rcs2log
  313. and cvsbug executables may be run on systems which do not contain an
  314. implementation of mktemp.
  315. * Misc documentation fixes.
  316. Changes from 1.11.10 to 1.11.11:
  317. ********************************
  318. SERVER SECURITY ISSUES
  319. * pserver can no longer be configured to run as root via the
  320. $CVSROOT/CVSROOT/passwd file, so if your passwd file is compromised, it no
  321. longer leads directly to a root hack. Attempts to root will also be logged
  322. via the syslog.
  323. Changes from 1.11.9 to 1.11.10:
  324. *******************************
  325. SERVER SECURITY ISSUES
  326. * Malformed module requests could cause the CVS server to attempt to create
  327. directories and possibly files at the root of the filesystem holding the CVS
  328. repository. Filesystem permissions usually prevent the creation of these
  329. misplaced directories, but nevertheless, the CVS server now rejects the
  330. malformed requests.
  331. GENERAL USER ISSUES
  332. * Case insensitive clients using a case sensitive server can now use a
  333. `cvs rm -f file; cvs add FILE' command sequence to add a file with the same
  334. name in a new case.
  335. * CVSROOTs which contain a symlink to a real repository should work.
  336. * The configure script now tests whether it is building CVS on a case
  337. insensitive file system. If it is, CVS assumes that all file systems on this
  338. platform will be case insensitive. This is useful for getting the case
  339. insensitivity flag set correctly when compiling on Mac OS X and under Cygwin
  340. on Windows. Autodetection can be overridden using the
  341. --disable-case-sensitivity and --enable-case-sensitivity arguments to
  342. configure.
  343. * A behavior change in `cvs up -jrev1 -jrev2' for modified files with a base
  344. revision of rev2 (ie, checked-out version matches rev2 and file has been
  345. modified). The operation is no longer ignored and instead is passed to
  346. diff3. This will potentially re-apply the diffs between the two revisions to
  347. a modified local file. Status messages like from a standard merge have also
  348. been added when the file would not or does not change due to this merge
  349. request ("[file] already contains the changes between [revisions]...").
  350. * A bug which could stop `cvs admin -mTAG:message' from recursing has been
  351. fixed.
  352. * Misc documentation cleanup and fixes.
  353. * Some of the contrib scripts, some of the documentation, and sanity.sh were
  354. modified to use and recommend more portable commands rather than using and
  355. recommending commands which were not compatible with the POSIX 1003.1-2001
  356. specification.
  357. DEVELOPER ISSUES
  358. * A new set of tests to test issues specific to case insensitive clients and
  359. servers has also been added.
  360. * Support has been added to the test suite to support testing over a :ext: link
  361. to another machine, subject to some stringent requirements. This support can
  362. be used, for instance, to test the operation of a case insensitive client
  363. against a case sensitive server. Please see the comments in TEST and the
  364. src/sanity.sh test script itself for more.
  365. * We've standardized on Automake 1.7.9 to get a bug fix. See the note below
  366. on the Autoconf upgrade for more details.
  367. * We've standardized on Autoconf version 2.58 to avoid a bug and get at a few
  368. new macros. Again, this should only really affect developers, though it is
  369. possible that CVS will now compile on a few new platforms. Please see the
  370. section of the INSTALL file about using the autotools if you are compiling
  371. CVS yourself.
  372. Changes from 1.11.8 to 1.11.9:
  373. * CVS now knows how to report, as well as record, `P' record types.
  374. * When running the `cvs history' command, clients will now send the
  375. long-accepted `-e' option, for all records, rather than explicitly requesting
  376. `P' record types, a request which servers prior to 1.11.7 will reject with a
  377. fatal error message.
  378. * A problem with locating files requested by case insensitive clients which was
  379. accidentally introduced in 1.11.6 as part of a fix for a data loss problem
  380. involving `cvs add's from case insensitive clients has been fixed. The
  381. relevant error message was `cvs [<command> aborted]: filE,v is ambiguous;
  382. could mean FILE,v or file,v'.
  383. * Attempts to use the global `-l' option, removed from both client and server
  384. as of version 1.11.6, will now elicit a warning rather than a fatal error
  385. from the server.
  386. Changes from 1.11.7 to 1.11.8:
  387. * A problem in the CVS getpass library that could cause passwords to echo on
  388. some systems has been fixed.
  389. Changes from 1.11.6 to 1.11.7:
  390. * A segfault that could occur in very rare cases where the stat of a file
  391. failed during a diff has been fixed.
  392. * Any user with write privleges to the CVSROOT/checkoutlist file could pass
  393. arbitrary format strings directly through to a printf function. This was
  394. probably bad and has been fixed. White space at the beginning of error strings
  395. in checkoutlist is now ignored properly.
  396. * In client/server mode, most messages from CVS now contain the actual
  397. command name rather than the generic "server".
  398. * A long-standing bug that prevented most client/server updates from being
  399. logged in the history file has been fixed.
  400. * Updates done via a patch ("P" status) are now logged in the history file
  401. by default and the corresponding "P" history record type is now documented.
  402. If you're setting the LogHistory option in your CVSROOT/config file, you may
  403. want to add "P" to the list of record types.
  404. * CVS now will always compile and its own getpass() function (originally from
  405. GNULIB) in favor of any system one that may exist. This avoids some problems
  406. with long passwords on some systems and updates us to POSIX.2 compliance, since
  407. getpass() was removed from the POSIX.2 specification.
  408. * A bug that allowed a write lock to be created in a directory despite
  409. there being existing read locks when using LockDir in CVSROOT/config has
  410. been fixed.
  411. * A bug with short patches (`rdiff -s') which caused rdiff to sometimes report
  412. differences that did not exist has been fixed.
  413. * Some minor corrections were made to the diff code to keep diff & rdiff from
  414. printing diff headers with empty change texts when two files have different
  415. revision numbers but the same content.
  416. * The global '-l' option, which suppressed history logging, has been removed
  417. from both client and server.
  418. Changes from 1.11.5 to 1.11.6:
  419. * A warning message is now issued if an administrative file contains
  420. more than one DEFAULT entry.
  421. * An error running a verifymsg script (such as referencing an unset user
  422. variable or the script not existing) now causes the verification to
  423. fail.
  424. * Errors in administrative files commands (like unset user variables)
  425. are no longer reported unless the command is actually executed.
  426. * When a file is initially checked out, its last access time is now set
  427. to the current time rather than being set to the time the file was last
  428. checked in like the modification time is.
  429. * The Checkin.prog and Update.prog functionality has been removed. This
  430. fuctionality previously allowed executables to be specified in the modules file
  431. to be run at update and checkin time, but users could edit these files on a per
  432. workspace basis, creating a security hole.
  433. * contrib/rcs2log and src/cvsbug now use the BSD mktemp program to create
  434. their temp files and directories on systems which provide it.
  435. * Corrected the path in a failed write error message.
  436. * Autoconf and Automake are no longer run automatically unless you run
  437. configure with --enable-maintainer-mode. Accordingly, noautomake.sh is
  438. no longer needed and has been removed.
  439. * We've standardized on Automake version 1.7.5 and Autoconf version 2.57 to get
  440. at a few new macros. Again, this should only really affect developers. See
  441. the section of the INSTALL file about using the autotools if you are compiling
  442. CVS yourself.
  443. Changes from 1.11.4 to 1.11.5:
  444. * Fixed a security hole in the CVS server by which users with read only access
  445. could gain write access. This issue does not affect client builds. The
  446. Common Vulnerabilities and Exposures project (cve.mitre.org) has assigned the
  447. name CAN-2003-0015 to this issue. See
  448. <http://cve.mitre.org/cgi-bin/cvename.cgi?name=CAN-2003-0015> for more
  449. information.
  450. * Fixed some bugs where revision numbers starting with 0 (like 0.3)
  451. weren't correctly handled. (CVS doesn't normally use such revision
  452. numbers, but users may be able to force it to do so and old RCS files
  453. might.)
  454. Changes from 1.11.3 to 1.11.4:
  455. * Some minor changes to allow the code to compile on Windows platforms.
  456. Changes from 1.11.2 to 1.11.3:
  457. * The tag/rtag code has been fixed to once again lock just a single
  458. directory at a time.
  459. * There was a bug where certain error conditions could cause the server
  460. to go into an infinite loop. There was also a bug that caused a
  461. compressed connection from an older client to hang on shutdown. These
  462. bugs have been fixed.
  463. * Fixed a bug that caused the server to reject most watch commands.
  464. * When waiting for another user's lock, the message timestamps are now
  465. in UTC rather than the server's local time.
  466. * The options.h file is no longer used. This fixes a bug that occurred when
  467. 1.11.2 was compiled on Windows platforms.
  468. * We've standardized on Automake version 1.6.3 and Autoconf version 2.53.
  469. They are cleaner, less bug prone, and will hopfully allow me to start updating
  470. sanity.sh to use Autotest and Autoshell. Again, this should only really affect
  471. developers. See the section of the INSTALL file about using the autotools if
  472. you are compiling CVS yourself.
  473. * Fixed a bug in the log/rlog code when a revision range crosses a
  474. branch point.
  475. * Fixed a bug where filenames starting with - would be misinterpreted as
  476. options when using client/server mode.
  477. Changes from 1.11.1p1 to 1.11.2:
  478. * There is a new feature, enabled by RereadLogAfterVerify in CVSROOT/config,
  479. which tells CVS to reread the log message after running the verifymsg
  480. script. This allows the verifymsg script to reformat or otherwise
  481. modify the log message.
  482. * The interpretation of revision ranges using :: in "log" and "rlog"
  483. has changed: a::b now excludes the log message from revision a but
  484. includes the log message from revision b. Also, revision ranges that
  485. cross branch points should now work.
  486. * zlib has been updated to version 1.4. There is a security advisory
  487. out in regards to 1.3. This should fix that problem.
  488. * The "log" and "rlog" commands now have a -S option to suppress the
  489. header information when no revisions are selected.
  490. * A serious error that allowed read-only users to tag files has been
  491. corrected.
  492. * The "annotate" command will no longer annotate binary files unless
  493. you specify the new -F option.
  494. * The "tag" and "rtag" commands will no longer move or delete branch
  495. tags unless you use the new -B option. (This prevents accidental
  496. changes to branch tags that are hard to undo.)
  497. * We've standardized on the 1.5 Automake release for the moment. Again, this
  498. should only really affect developers. See the section of the INSTALL file
  499. about using the autotools if you are compiling CVS yourself.
  500. Changes from 1.11.1 to 1.11.1p1:
  501. * Read only access was broken - now fixed.
  502. Changes from 1.11 to 1.11.1:
  503. * There was a locking bug in the tag/rtag code that could lose changes
  504. made to a file while the tag operation was in progress. This has been
  505. fixed, but all of the directories being tagged are now locked for the
  506. entire duration of the tag operation rather than only one directory at a
  507. time.
  508. * The "cvs diff" command now accepts the -y/--side=by-side and -T/
  509. --initial-tab options. (To use these options with a remote repository,
  510. both the client and the server must support them.)
  511. * The expansion of the loginfo format string has changed slightly.
  512. Previously, the expansion was surrounded by single quotes ('); if a file
  513. name contained a single quote character, the string would not be parsed
  514. as a single entity by the Unix shell (and it would not be possible to
  515. parse it unambiguously). Now the expansion is surrounded by double
  516. quotes (") and any embedded dollar signs ($), backticks (`), backslashes
  517. (\), and double quotes are preceded by a backslash. This is parsed as a
  518. single entity by the shell reguardless of content. This change should
  519. not be noticable unless you're not using a Unix shell or you have
  520. embedded the format string inside a double quoted string.
  521. * There was a bug in the diff code which sometimes caused conflicts to
  522. be flagged which shouldn't have been. This has been fixed.
  523. * New "cvs rlog" and "cvs rannotate" commands have been added to get log
  524. messages and annotations without having to have a checked-out copy.
  525. * Exclusive revision ranges have been added to "cvs log" using ::
  526. (similar to "cvs admin -o").
  527. * The VMS client now accepts wildcards if you're running VMS 7.x.
  528. * ZLIB has been updated to version 1.1.3, the most current version. This
  529. includes mostly some optimizations and minor bug fixes.
  530. * The ~/.cvspass file has a slightly modified format. CVSROOTs are now
  531. stored in a new canonical form - hostnames are now case insensitive and
  532. port numbers are always stored in the new format. Until a new login for
  533. a particular CVSROOT is performed with the new version of CVS, new and
  534. old versions of CVS should interoperate invisibly. After that point, an
  535. extra login using the old version of CVS may be necessary to continue to
  536. allow the new and old versions of CVS to interoperate using the same
  537. ~/.cvspass file and CVSROOT. The exception to this rule occurs when the
  538. CVSROOTs used with the different versions use case insensitively
  539. different hostnames, for example, "empress", and "empress.2-wit.com".
  540. * A password and a port number may now be specified in CVSROOT for
  541. pserver connections. The new format is:
  542. :pserver:[[user][:password]@]host[:[port]]/path
  543. Note that passwords specified in a checkout command will be saved in the
  544. clear in the CVS/Root file in each created directory, so this is not
  545. recommended, except perhaps when accessing anonymous repositories or the
  546. like.
  547. * The distribution has been converted to use Automake. This shouldn't
  548. affect most users except to ease some portability concerns, but if you
  549. are building from the repository and encounter problems with the
  550. makefiles, you might try running ./noautomake.sh after a fresh update
  551. -AC.
  552. Changes from 1.10 to 1.11:
  553. * The "cvs update" command has a new -C option to get clean copies from
  554. the repository, abandoning any local changes.
  555. * The new "cvs version" command gives a short version message. If
  556. the repository is remote, both the client and server versions are
  557. reported.
  558. * "cvs admin -t" now works correctly in client/server mode.
  559. * The "cvs history" command output format has changed -- the date
  560. now includes the year and is given is ISO 8601 format (yyyy-mm-dd).
  561. Also, the new LogHistory option in CVSROOT/config can be used to
  562. control what information gets recorded in the log file and code has
  563. been added to record file removals.
  564. * The buggy PreservePermissions code has been disabled.
  565. * Anonymous read-only access can now be done without requiring a
  566. password. On the server side, simply give that user (presumably
  567. `anonymous') an empty password in the CVSROOT/passwd file, and then
  568. any received password will authenticate successfully.
  569. * There is a new access method :fork: which is similar to :local:
  570. except that it is implemented via the CVS remote protocol, and thus
  571. has a somewhat different set of quirks and bugs.
  572. * The -d command line option no longer updates the CVS/Root file. For
  573. one thing, the CVS 1.9/1.10 behavior never had updated CVS/Root in
  574. subdirectories, and for another, it didn't seem that popular in
  575. general. So this change restores the CVS 1.8 behavior (which is also
  576. the CVS 1.9/1.10 behavior if the environment variable
  577. CVS_IGNORE_REMOTE_ROOT is set; with this change,
  578. CVS_IGNORE_REMOTE_ROOT no longer has any effect).
  579. * It is now possible for a single CVS command to recurse into several
  580. CVS roots. This includes roots which are located on several servers,
  581. or which are both remote and local. CVS will make connections to as
  582. many servers as necessary.
  583. * It is now possible to put the CVS lock files in a directory
  584. set by the new LockDir option in CVSROOT/config. The default
  585. continues to be to put the lock files in the repository itself.
  586. Changes from 1.9 to 1.10:
  587. * A bug was discovered in the -t/-f wrapper support that can cause
  588. serious data loss. Because of this (and also the fact that it doesn't
  589. work at all in client/server mode), the -t/-f wrapper code has been
  590. disabled until it can be fixed.
  591. * There is a new feature, enabled by TopLevelAdmin in CVSROOT/config,
  592. which tells CVS to modify the behavior of the "checkout" command. The
  593. command now creates a CVS directory at the top level of the new
  594. working directory, in addition to CVS directories created within
  595. checked-out directories. See the Cederqvist for details.
  596. * There is an optional set of features, enabled by PreservePermissions
  597. in CVSROOT/config, which allow CVS to store unix-specific file
  598. information such as permissions, file ownership, and links. See the
  599. Cederqvist for details.
  600. * One can now authenticate and encrypt using the GSSAPI network
  601. security interface. For details see the Cederqvist's description of
  602. specifying :gserver: in CVSROOT, and the -a global option.
  603. * All access to RCS files is now implemented internally rather than by
  604. calling RCS programs. The main user-visible consequence of this is
  605. that there is no need to worry about making sure that CVS finds the
  606. correct version of RCS. The -b global option and the RCSBIN setting
  607. in CVSROOT/config are still accepted but don't do anything. The
  608. $RCSBIN internal variable in administrative files is no longer
  609. accepted.
  610. * There is a new syntax, "cvs admin -orev1::rev2", which collapses the
  611. revisions between rev1 and rev2 without deleting rev1 or rev2
  612. themselves.
  613. * There is a new administrative file CVSROOT/config which allows one
  614. to specify miscellaneous aspects of CVS configuration. Currently
  615. supported here:
  616. - SystemAuth, allows you to prevent pserver from checking for system
  617. usernames/passwords.
  618. For more information see the "config" section of cvs.texinfo.
  619. * When setting up the pserver server, one now must specify the
  620. allowable CVSROOT directories in inetd.conf. See the Password
  621. authentication server section of cvs.texinfo for details. Note that
  622. this implies that everyone who is running a pserver server must edit
  623. inetd.conf when upgrading their CVS.
  624. * The client no longer needs an external patch program (assuming both
  625. the client and the server have been updated to the new version).
  626. * "cvs admin [options]" will now recurse. In previous versions of
  627. CVS, it was an error and one needed to specify "cvs admin [options] ."
  628. to recurse. This change brings admin in line with the other CVS
  629. commands.
  630. * New "logout" command to remove the password for a remote cvs
  631. repository from the cvspass file.
  632. * Read-only repository access is implemented for the
  633. password-authenticated server (other access methods are just governed
  634. by Unix file permissions, since they require login access to the
  635. repository machine anyway). See the "Repository" section of
  636. cvs.texinfo for details, including a discussion of security issues.
  637. Note that the requirement that read-only users be able to create locks
  638. and write the history file still applies.
  639. * There is a new administrative file verifymsg which is like editinfo
  640. but merely validates the message, rather than also getting it from the
  641. user. It therefore works with client/server CVS or if one uses the -m
  642. or -F options to commit. See the verifymsg section of cvs.texinfo for
  643. details.
  644. * The %s format formerly accepted in loginfo has been extended to
  645. formats such as %{sVv}, so that loginfo scripts have access to the
  646. version numbers being changed. See the Loginfo section of cvs.texinfo
  647. for details.
  648. * The postscript documentation (doc/cvs.ps) shipped with CVS is now
  649. formatted for US letter size instead of A4. This is not because we
  650. consider this size "better" than A4, but because we believe that the
  651. US letter version will print better on A4 paper than the other way
  652. around.
  653. * The "cvs export" command is now logged in the history file and there
  654. is a "cvs history -x E" command to select history file entries
  655. produced by export.
  656. * CVS no longer uses the CVS_PASSWORD environment variable. Storing
  657. passwords in cleartext in an environment variable is a security risk,
  658. especially since (on BSD variants) any user on the system can display
  659. any process's environment using 'ps'. Users should use the 'cvs
  660. login' command instead.
  661. Changes from 1.8 to 1.9:
  662. * Windows NT client should now work on Windows 95 as well.
  663. * New option "--help-synonyms" prints a list of all recognized command
  664. synonyms.
  665. * The "log" command is now implemented internally rather than via the
  666. RCS "rlog" program. The main user-visible consequence is that
  667. symbolic branch names now work (for example "cvs log -rbranch1").
  668. Also, the date formats accepted by -d have changed. They previously
  669. had been a bewildering variety of poorly-documented date formats. Now
  670. they are the same as the date formats accepted by the -D options to
  671. the other CVS commands, which is also a (different) bewildering
  672. variety of poorly-documented date formats, but at least we are
  673. consistently bewildering :-).
  674. * Encryption is now supported over a Kerberos client/server
  675. connection. The new "-x" global option requests it. You must
  676. configure with the --enable-encryption option in order to enable
  677. encryption.
  678. * The format of the CVS commit message has changed slightly when
  679. committing changes on a branch. The tag on which the commit is
  680. ocurring is now reported correctly in all cases.
  681. * New flag -k in wrappers allows you to specify the keyword expansion
  682. mode for added files based on their name. For example, you can
  683. specify that files whose name matches *.exe are binary by default.
  684. See the Wrappers section of cvs.texinfo for more details.
  685. * Remote CVS with the "-z" option now uses the zlib library (included
  686. with CVS) to compress all communication between the client and the
  687. server, rather than invoking gzip on each file separately. This means
  688. that compression is better and there is no need for an external gzip
  689. program (except to interoperate with older version of CVS).
  690. * The "cvs rlog" command is deprecated and running it will print a
  691. warning; use the synonymous "cvs log" command instead. It is
  692. confusing for rlog to mean the same as log because some other CVS
  693. commands are in pairs consisting of a plain command which operates on
  694. a working directory and an "r" command which does not (diff/rdiff;
  695. tag/rtag).
  696. * "cvs diff" has a bunch of new options, mostly long options. Most of
  697. these work only if rcsdiff and diff support them, and are named the
  698. same as the corresponding options to diff.
  699. * The -q and -Q command options to "cvs diff" were removed (use the
  700. global options instead). This brings "cvs diff" into line with the
  701. rest of the CVS commands.
  702. * The "annotate" command can now be used to annotate a revision other
  703. than the head revision on the trunk (see the -r, -D, and -f options in
  704. the annotate node of cvs.texinfo for details).
  705. * The "tag" command has a new option "-c" which checks that all files
  706. are not locally modified before tagging.
  707. * The -d command line option now overrides the cvsroot setting stored
  708. in the CVS/Root file in each working directory, and specifying -d will
  709. cause CVS/Root to be updated.
  710. * Local (non-client/server) CVS now runs on Windows NT. See
  711. windows-NT/README for details.
  712. * The CVSROOT variable specification has changed to support more
  713. access methods. In addition to "pserver," "server" (internal rsh
  714. client), "ext" (external rsh client), "kserver" (kerberos), and
  715. "local" (local filesystem access) can now be specified. For more
  716. details on each method, see cvs.texinfo (there is an index entry for
  717. :local: and each of the other access methods).
  718. * The "login" command no longer prompts the user for username and
  719. hostname, since one will have to provide that information via the `-d'
  720. flag or by setting CVSROOT.
  721. Changes from 1.7 to 1.8:
  722. * New "cvs annotate" command to display the last modification for each
  723. line of a file, with the revision number, user checking in the
  724. modification, and date of the modification. For more information see
  725. the `annotate' node in cvs.texinfo.
  726. * The cvsinit shell script has been replaced by a cvs init command.
  727. The cvs init command creates some example administrative files which
  728. are similar to the files found in the examples directory (and copied
  729. by cvsinit) in previous releases.
  730. * Added the patterns *.olb *.exe _$* *$ to default ignore list.
  731. * There is now a $USER internal variable for *info files.
  732. * There is no longer a separate `mkmodules' program; the functionality
  733. is now built into `cvs'. If upgrading an old repository, it is OK to
  734. leave in the lines in the modules file which run mkmodules (the
  735. mkmodules actions will get done twice, but that is harmless); you will
  736. probably want to remove them once you are no longer using the old CVS.
  737. * One can now specify user variables in *info files via the
  738. ${=varname} syntax; there is a -s global option to set them. See the
  739. Variables node in cvs.texinfo for details.
  740. Changes from 1.6 to 1.7:
  741. * The default ignore list has changed slightly: *.obj has been added
  742. and CVS* has been changed to CVS CVS.adm.
  743. * CVS now supports password authentication when accessing remote
  744. repositories; this is useful for sites that can't use rsh (because of
  745. a firewall, for example), and also don't have kerberos. See node
  746. "Password authenticated" (in "Remote repositories", in
  747. doc/cvs.texinfo) for more details. Note: This feature requires both
  748. the client and server to be upgraded.
  749. * Using the -kb option to specify binary files now works--most cases
  750. did not work before. See the "Binary files" section of
  751. doc/cvs.texinfo for details.
  752. * New developer communication features. See the "Watches" section of
  753. doc/cvs.texinfo for details.
  754. * RCS keyword "Name" supported for "cvs update -r <tag>" and "cvs
  755. checkout -r <tag>".
  756. * If there is a group whose name matches a compiled in value which
  757. defaults to "cvsadmin", only members of that group can use "cvs
  758. admin". This replaces the CVS_NOADMIN option.
  759. * CVS now sets the modes of files in the repository based on the
  760. CVSUMASK environment variable or a compiled in value defaulting to
  761. 002. This way other developers will be able to access the files in
  762. the repository regardless of the umask of the developer creating them.
  763. * The command names in .cvsrc now match the official name of the
  764. command, not the one (possibly an alias) by which it was invoked. If
  765. you had previously relied on "cvs di" and "cvs diff" using different
  766. options, instead use a shell function or alias (for example "alias
  767. cvsdi='cvs diff -u'"). You also can specify global CVS options (like
  768. "-z") using the command name "cvs".
  769. Changes from 1.5 to 1.6:
  770. * Del updated the man page to include all of the new features
  771. of CVS 1.6.
  772. * "cvs tag" now supports a "-r | -D" option for tagging an already
  773. tagged revision / specific revision of a file.
  774. * There is a "taginfo" file in CVSROOT that supports filtering and
  775. recording of tag operations.
  776. * Long options support added, including --help and --version options.
  777. * "cvs release" no longer cares whether or not the directory being
  778. released has an entry in the `modules' file.
  779. * The modules file now takes a -e option which is used instead of -o
  780. for "cvs export". If your modules file has a -o option which you want
  781. to be used for "cvs export", change it to specify -e as well as -o.
  782. * "cvs export" now takes a -k option to set RCS keyword expansion.
  783. This way you can export binary files. If you want the old behavior,
  784. you need to specify -kv.
  785. * "cvs update", "cvs rdiff", "cvs checkout", "cvs import", "cvs
  786. release", "cvs rtag", and "cvs tag" used to take -q and -Q options
  787. after the command name (e.g. "cvs update -q"). This was confusing
  788. because other commands, such as "cvs ci", did not. So the options
  789. after the command name have been removed and you must now specify, for
  790. example, "cvs -q update", which has been supported since CVS 1.3.
  791. * New "wrappers" feature. This allows you to set a hook which
  792. transforms files on their way in and out of cvs (apparently on the
  793. NeXT there is some particular usefulness in tarring things up in the
  794. repository). It also allows you to declare files as merge-by-copy
  795. which means that instead of trying to merge the file, CVS will merely
  796. copy the new version. There is a CVSROOT/cvswrappers file and an
  797. optionsl ~/.cvswrappers file to support this feature.
  798. * You can set CVSROOT to user@host:dir, not just host:dir, if your
  799. username on the server host is different than on the client host.
  800. * VISUAL is accepted as well as EDITOR.
  801. * $CVSROOT is expanded in *info files.
  802. Changes from 1.4A2 to 1.5:
  803. * Remote implementation. This is very helpful when collaborating on a
  804. project with someone across a wide-area network. This release can
  805. also be used locally, like other CVS versions, if you have no need for
  806. remote access.
  807. Here are some of the features of the remote implementation:
  808. - It uses reliable transport protocols (TCP/IP) for remote repository
  809. access, not NFS. NFS is unusable over long distances (and sometimes
  810. over short distances)
  811. - It transfers only those files that have changed in the repository or
  812. the working directory. To save transmission time, it will transfer
  813. patches when appropriate, and can compress data for transmission.
  814. - The server never holds CVS locks while waiting for a reply from the client;
  815. this makes the system robust when used over flaky networks.
  816. The remote features are documented in doc/cvsclient.texi in the CVS
  817. distribution, but the main doc file, cvs.texinfo, has not yet been
  818. updated to include the remote features.
  819. * Death support. See src/README-rm-add for more information on this.
  820. * Many speedups, especially from jtc@cygnus.com.
  821. * CVS 1.2 compatibility code has been removed as a speedup. If you
  822. have working directories checked out by CVS 1.2, CVS 1.3 or 1.4A2 will
  823. try to convert them, but CVS 1.5 and later will not (if the working
  824. directory is up to date and contains no extraneous files, you can just
  825. remove it, and then check out a new working directory). Likewise if
  826. your repository contains a CVSROOT.adm directory instead of a CVSROOT
  827. directory, you need to rename it.
  828. Fri Oct 21 20:58:54 1994 Brian Berliner <berliner@sun.com>
  829. * Changes between CVS 1.3 and CVS 1.4 Alpha-2
  830. * A new program, "cvsbug", is provided to let you send bug reports
  831. directly to the CVS maintainers. Please use it instead of sending
  832. mail to the info-cvs mailing list. If your build fails, you may
  833. have to invoke "cvsbug" directly from the "src" directory as
  834. "src/cvsbug.sh".
  835. * A new User's Guide and Tutorial, written by Per Cederqvist
  836. <ceder@signum.se> of Signum Support. See the "doc" directory. A
  837. PostScript version is included as "doc/cvs.ps".
  838. * The Frequesntly Asked Questions file, FAQ, has been added to the
  839. release. Unfortunately, its contents are likely out-of-date.
  840. * The "cvsinit" shell script is now installed in the $prefix/bin
  841. directory like the other programs. You can now create new
  842. CVS repositories with great ease.
  843. * Index: lines are now printed on output from 'diff' and 'rdiff',
  844. in order to facilitate application of patches to multiple subdirs.
  845. * Support for a ~/.cvsrc file, which allows you to specify options
  846. that are always supposed to be given to a specific command. This
  847. feature shows the non-orthogonality of the option set, since while
  848. there may be an option to turn something on, the option to turn
  849. that same thing off may not exist.
  850. * You can now list subdirectories that you wish to ignore in a
  851. modules listing, such as:
  852. gcc -a gnu/gcc, !gnu/gcc/testsuites
  853. which will check out everything underneath gnu/gcc, except
  854. everything underneath gnu/gcc/testsuites.
  855. * It is now much harder to accidentally overwrite an existing tag
  856. name, since attempting to move a tag name will result in a error,
  857. unless the -F (force) flag is given to the tag subcommands.
  858. * Better error checking on matching of the repository used to
  859. check code out from against the repository the current cvs
  860. commnands would use. (Thanks to Mark Baushke <mdb@cisco.com>)
  861. * Better support for sites with multiple CVSROOT repositories has
  862. been contributed. The file "CVS/Root" in your working directory
  863. is created to hold the full path to the CVS repository and a
  864. simple check is made against your current CVSROOT setting.
  865. * You can now specify an RCS keyword substitution value when you
  866. import files into the repository.
  867. * Uses a much newer version of Autoconf, and conforms to the GNU
  868. coding standards much more closely. No, it still doesn't have
  869. long option names.
  870. * Code cleanup. Many passes through gcc -Wall helped to identify
  871. a number of questionable constructs. Most arbitrary length limits
  872. were removed.
  873. * Profiling to determine bottlenecks helped to identify the best
  874. places to spend time speeding up the code, which was then done. A
  875. number of performance enhancements in filename matching have sped
  876. up checkouts.
  877. * Many more contributions have been added to the "contrib"
  878. directory. See the README file in that directory for more
  879. information.
  880. * "cvs commit" will try harder to not change the file's
  881. modification time after the commit. If the file does not change
  882. as a result of the commit operation, CVS will preserve the
  883. original modification time, thus speeding up future make-type
  884. builds.
  885. * "cvs commit" now includes any removed files in the (optional)
  886. pre-commit checking program that may be invoked. Previously, only
  887. added and modified files were included.
  888. * It is now possible to commit a file directly onto the trunk at a
  889. specific revision level by doing "cvs commit -r3.0 file.c", where
  890. "3.0" specifies the revision you wish to create. The file must be
  891. up-to-date with the current head of the trunk for this to succeed.
  892. * "cvs commit" will now function with a pre-commit program that
  893. has arguments specified in the "commitinfo" file.
  894. * The "mkmodules" program will now look within the
  895. $CVSROOT/CVSROOT/checkoutlist" file for any additional files that
  896. should be automatically checked out within CVSROOT; mkmodules also
  897. tries harder to preserve any execute bits the files may have
  898. originally had.
  899. * "cvs diff" is much more accurate about its exit status now. It
  900. now returns the maximum exit status of any invoked diff.
  901. * The "-I !" option is now supported for the import and update
  902. commands correctly. It will properly clear the ignore list now.
  903. * Some problems with "cvs import" handling of .cvsignore have been
  904. fixed; as well, some rampant recursion problems with import have
  905. also been fixed.
  906. * "cvs rdiff" (aka "cvs patch") now tries to set the modify time
  907. of any temporary files it uses to match those specified for the
  908. particular revision. This allows a more accurate patch image to
  909. be created.
  910. * "cvs status" has improved revision descriptions. "Working
  911. revision" is used for the revision of the working file that you
  912. edit directly; "Repository revision" is the revision of the file
  913. with the $CVSROOT source repository. Also, the output is clearer
  914. with regard to sticky and branch revisions.
  915. * CVS no longer dumps core when given a mixture of directories and
  916. files in sub-directories (as in "cvs ci file1 dir1/file2").
  917. Instead, arguments are now clumped into their respective directory
  918. and operated on in chunks, together.
  919. * If the CVSEDITOR environment variable is set, that editor is
  920. used for log messages instead of the EDITOR environment variable.
  921. This makes it easy to substitute intelligent programs to make more
  922. elaborate log messages. Contributed by Mark D Baushke
  923. (mdb@cisco.com).
  924. * Command argument changes:
  925. cvs: The "-f" option has been added to ignore
  926. the ~/.cvsrc file.
  927. commit: Renamed the "-f logfile" option to the
  928. "-F logfile" option. Added the "-f"
  929. option to force a commit of the specified
  930. files (this disables recursion).
  931. history: Added "-t timezone" option to force any
  932. date-specific output into the specified
  933. timezone.
  934. import: Added "-d" option to use the file's
  935. modification time as the time of the
  936. import. Added "-k sub" option to set the
  937. default RCS keyword substitution mode for
  938. newly-created files.
  939. remove: Added "-f" option to force the file's
  940. automatic removal if it still exists in
  941. the working directory (use with caution).
  942. rtag: Added "-F" option to move the tag if it
  943. already exists -- new default is to NOT
  944. move tags automatically.
  945. tag: Added "-F" option to move the tag if it
  946. already exists -- new default is to NOT
  947. move tags automatically.
  948. Tue Apr 7 15:55:25 1992 Brian Berliner (berliner at sun.com)
  949. * Changes between CVS 1.3 Beta-3 and official CVS 1.3!
  950. * A new shell script is provided, "./cvsinit", which can be run at
  951. install time to help setup your $CVSROOT area. This can greatly
  952. ease your entry into CVS usage.
  953. * The INSTALL file has been updated to include the machines on
  954. which CVS has compiled successfully. I think CVS 1.3 is finally
  955. portable. Thanks to all the Beta testers!
  956. * Support for the "editinfo" file was contributed. This file
  957. (located in $CVSROOT/CVSROOT) can be used to specify a special
  958. "editor" to run on a per-directory basis within the repository,
  959. instead of the usual user's editor. As such, it can verify that
  960. the log message entered by the user is of the appropriate form
  961. (contains a bugid and test validation, for example).
  962. * The manual pages cvs(1) and cvs(5) have been updated.
  963. * The "mkmodules" command now informs you when your modules file
  964. has duplicate entries.
  965. * The "add" command now preserves any per-directory sticky tag when
  966. you add a new directory to your checked-out sources.
  967. * The "admin" command is now a fully recursive interface to the
  968. "rcs" program which operates on your checked-out sources. It no
  969. longer requires you to specify the full path to the RCS file.
  970. * The per-file sticky tags can now be effectively removed with
  971. "cvs update -A file", even if you had checked out the whole
  972. directory with a per-directory sticky tag. This allows a great
  973. deal of flexibility in managing the revisions that your checked-out
  974. sources are based upon (both per-directory and per-file sticky
  975. tags).
  976. * The "cvs -n commit" command now works, to show which files are
  977. out-of-date and will cause the real commit to fail, or which files
  978. will fail any pre-commit checks. Also, the "cvs -n import ..."
  979. command will now show you what it would've done without actually
  980. doing it.
  981. * Doing "cvs commit modules" to checkin the modules file will no
  982. properly run the "mkmodules" program (assuming you have setup your
  983. $CVSROOT/CVSROOT/modules file to do so).
  984. * The -t option in the modules file (which specifies a program to
  985. run when you do a "cvs rtag" operation on a module) now gets the
  986. symbolic tag as the second argument when invoked.
  987. * When the source repository is locked by another user, that user's
  988. login name will be displayed as the holder of the lock.
  989. * Doing "cvs checkout module/file.c" now works even if
  990. module/file.c is in the Attic (has been removed from main-line
  991. development).
  992. * Doing "cvs commit */Makefile" now works as one would expect.
  993. Rather than trying to commit everything recursively, it will now
  994. commit just the files specified.
  995. * The "cvs remove" command is now fully recursive. To schedule a
  996. file for removal, all you have to do is "rm file" and "cvs rm".
  997. With no arguments, "cvs rm" will schedule all files that have been
  998. physically removed for removal from the source repository at the
  999. next "cvs commit".
  1000. * The "cvs tag" command now prints "T file" for each file that was
  1001. tagged by this invocation and "D file" for each file that had the
  1002. tag removed (as with "cvs tag -d").
  1003. * The -a option has been added to "cvs rtag" to force it to clean
  1004. up any old, matching tags for files that have been removed (in the
  1005. Attic) that may not have been touched by this tag operation. This
  1006. can help keep a consistent view with your tag, even if you re-use
  1007. it frequently.
  1008. Sat Feb 29 16:02:05 1992 Brian Berliner (berliner at sun.com)
  1009. * Changes between CVS 1.3 Beta-2 and CVS 1.3 Beta-3
  1010. * Many portability fixes, thanks to all the Beta testers! With any
  1011. luck, this Beta release will compile correctly on most anything.
  1012. Hey, what are we without our dreams.
  1013. * CVS finally has support for doing isolated development on a
  1014. branch off the current (or previous!) revisions. This is also
  1015. extremely nice for generating patches for previously released
  1016. software while development is progressing on the next release.
  1017. Here's an example of creating a branch to fix a patch with the 2.0
  1018. version of the "foo" module, even though we are already well into
  1019. the 3.0 release. Do:
  1020. % cvs rtag -b -rFOO_2_0 FOO_2_0_Patch foo
  1021. % cvs checkout -rFOO_2_0_Patch foo
  1022. % cd foo
  1023. [[ hack away ]]
  1024. % cvs commit
  1025. A physical branch will be created in the RCS file only when you
  1026. actually commit the change. As such, forking development at some
  1027. random point in time is extremely light-weight -- requiring just a
  1028. symbolic tag in each file until a commit is done. To fork
  1029. development at the currently checked out sources, do:
  1030. % cvs tag -b Personal_Hack
  1031. % cvs update -rPersonal_Hack
  1032. [[ hack away ]]
  1033. % cvs commit
  1034. Now, if you decide you want the changes made in the Personal_Hack
  1035. branch to be merged in with other changes made in the main-line
  1036. development, you could do:
  1037. % cvs commit # to make Personal_Hack complete
  1038. % cvs update -A # to update sources to main-line
  1039. % cvs update -jPersonal_Hack # to merge Personal_Hack
  1040. to update your checked-out sources, or:
  1041. % cvs checkout -jPersonal_Hack module
  1042. to checkout a fresh copy.
  1043. To support this notion of forked development, CVS reserves
  1044. all even-numbered branches for its own use. In addition, CVS
  1045. reserves the ".0" and ".1" branches. So, if you intend to do your
  1046. own branches by hand with RCS, you should use odd-numbered branches
  1047. starting with ".3", as in "1.1.3", "1.1.5", 1.2.9", ....
  1048. * The "cvs commit" command now supports a fully functional -r
  1049. option, allowing you to commit your changes to a specific numeric
  1050. revision or symbolic tag with full consistency checks. Numeric
  1051. tags are useful for bringing your sources all up to some revision
  1052. level:
  1053. % cvs commit -r2.0
  1054. For symbolic tags, you can only commit to a tag that references a
  1055. branch in the RCS file. One created by "cvs rtag -b" or from
  1056. "cvs tag -b" is appropriate (see below).
  1057. * Roland Pesch <pesch@cygnus.com> and K. Richard Pixley
  1058. <rich@cygnus.com> were kind enough to contribute two new manual
  1059. pages for CVS: cvs(1) and cvs(5). Most of the new CVS 1.3 features
  1060. are now documented, with the exception of the new branch support
  1061. added to commit/rtag/tag/checkout/update.
  1062. * The -j options of checkout/update have been added. The "cvs join"
  1063. command has been removed.
  1064. With one -j option, CVS will merge the changes made between the
  1065. resulting revision and the revision that it is based on (e.g., if
  1066. the tag refers to a branch, CVS will merge all changes made in
  1067. that branch into your working file).
  1068. With two -j options, CVS will merge in the changes between the two
  1069. respective revisions. This can be used to "remove" a certain delta
  1070. from your working file. E.g., If the file foo.c is based on
  1071. revision 1.6 and I want to remove the changes made between 1.3 and
  1072. 1.5, I might do:
  1073. % cvs update -j1.5 -j1.3 foo.c # note the order...
  1074. In addition, each -j option can contain on optional date
  1075. specification which, when used with branches, can limit the chosen
  1076. revision to one within a specific date. An optional date is
  1077. specified by adding a colon (:) to the tag, as in:
  1078. -jSymbolic_Tag:Date_Specifier
  1079. An example might be what "cvs import" tells you to do when you have
  1080. just imported sources that have conflicts with local changes:
  1081. % cvs checkout -jTAG:yesterday -jTAG module
  1082. which tells CVS to merge in the changes made to the branch
  1083. specified by TAG in the last 24 hours. If this is not what is
  1084. intended, substitute "yesterday" for whatever format of date that
  1085. is appropriate, like:
  1086. % cvs checkout -jTAG:'1 week ago' -jTAG module
  1087. * "cvs diff" now supports the special tags "BASE" and "HEAD". So,
  1088. the command:
  1089. % cvs diff -u -rBASE -rHEAD
  1090. will effectively show the changes made by others (in unidiff
  1091. format) that will be merged into your working sources with your
  1092. next "cvs update" command. "-rBASE" resolves to the revision that
  1093. your working file is based on. "-rHEAD" resolves to the current
  1094. head of the branch or trunk that you are working on.
  1095. * The -P option of "cvs checkout" now means to Prune empty
  1096. directories, as with "update". The default is to not remove empty
  1097. directories. However, if you do "checkout" with any -r options, -P
  1098. will be implied. I.e., checking out with a tag will cause empty
  1099. directories to be pruned automatically.
  1100. * The new file INSTALL describes how to install CVS, including
  1101. detailed descriptions of interfaces to "configure".
  1102. * The example loginfo file in examples/loginfo has been updated to
  1103. use the perl script included in contrib/log.pl. The nice thing
  1104. about this log program is that it records the revision numbers of
  1105. your change in the log message.
  1106. Example files for commitinfo and rcsinfo are now included in the
  1107. examples directory.
  1108. * All "#if defined(__STDC__) && __STDC__ == 1" lines have been
  1109. changed to be "#if __STDC__" to fix some problems with the former.
  1110. * The lib/regex.[ch] files have been updated to the 1.3 release of
  1111. the GNU regex package.
  1112. * The ndbm emulation routines included with CVS 1.3 Beta-2 in the
  1113. src/ndbm.[ch] files has been moved into the src/myndbm.[ch] files
  1114. to avoid any conflict with the system <ndbm.h> header file. If
  1115. you had a previous CVS 1.3 Beta release, you will want to "cvs
  1116. remove ndbm.[ch]" form your copy of CVS as well.
  1117. * "cvs add" and "cvs remove" are a bit more verbose, telling you
  1118. what to do to add/remove your file permanently.
  1119. * We no longer mess with /dev/tty in "commit" and "add".
  1120. * More things are quiet with the -Q option set.
  1121. * New src/config.h option: If CVS_BADROOT is set, CVS will not
  1122. allow people really logged in as "root" to commit changes.
  1123. * "cvs diff" exits with a status of 0 if there were no diffs, 1 if
  1124. there were diffs, and 2 if there were errors.
  1125. * "cvs -n diff" is now supported so that you can still run diffs
  1126. even while in the middle of committing files.
  1127. * Handling of the CVS/Entries file is now much more robust.
  1128. * The default file ignore list now includes "*.so".
  1129. * "cvs import" did not expand '@' in the log message correctly. It
  1130. does now. Also, import now uses the ignore file facility
  1131. correctly.
  1132. Import will now tell you whether there were conflicts that need to
  1133. be resolved, and how to resolve them.
  1134. * "cvs log" has been changed so that you can "log" things that are
  1135. not a part of the current release (in the Attic).
  1136. * If you don't change the editor message on commit, CVS now prompts
  1137. you with the choice:
  1138. !)reuse this message unchanged for remaining dirs
  1139. which allows you to tell CVS that you have no intention of changing
  1140. the log message for the remainder of the commit.
  1141. * It is no longer necessary to have CVSROOT set if you are using
  1142. the -H option to get Usage information on the commands.
  1143. * Command argument changes:
  1144. checkout: -P handling changed as described above.
  1145. New -j option (up to 2 can be specified)
  1146. for doing rcsmerge kind of things on
  1147. checkout.
  1148. commit: -r option now supports committing to a
  1149. numeric or symbolic tags, with some
  1150. restrictions. Full consistency checks will
  1151. be done.
  1152. Added "-f logfile" option, which tells
  1153. commit to glean the log message from the
  1154. specified file, rather than invoking the
  1155. editor.
  1156. rtag: Added -b option to create a branch tag,
  1157. useful for creating a patch for a previous
  1158. release, or for forking development.
  1159. tag: Added -b option to create a branch tag,
  1160. useful for creating a patch for a previous
  1161. release, or for forking development.
  1162. update: New -j option (up to 2 can be specified)
  1163. for doing rcsmerge kind of things on
  1164. update.
  1165. Thu Jan 9 10:51:35 MST 1992 Jeff Polk (polk at BSDI.COM)
  1166. * Changes between CVS 1.3 Beta-1 and CVS 1.3 Beta-2
  1167. * Thanks to K. Richard Pixley at Cygnus we now have function
  1168. prototypes in all the files
  1169. * Some small changes to configure for portability. There have
  1170. been other portability problems submitted that have not been fixed
  1171. (Brian will be working on those). Additionally all __STDC__
  1172. tests have been modified to check __STDC__ against the constant 1
  1173. (this is what the Second edition of K&R says must be true).
  1174. * Lots of additional error checking for forked processes (run_exec)
  1175. (thanks again to K. Richard Pixley)
  1176. * Lots of miscellaneous bug fixes - including but certainly not
  1177. limited to:
  1178. various commit core dumps
  1179. various update core dumps
  1180. bogus results from status with numeric sticky tags
  1181. commitprog used freed memory
  1182. Entries file corruption caused by No_Difference
  1183. commit to revision broken (now works if branch exists)
  1184. ignore file processing broken for * and !
  1185. ignore processing didn't handle memory reasonably
  1186. miscellaneous bugs in the recursion processor
  1187. file descriptor leak in ParseInfo
  1188. CVSROOT.adm->CVSROOT rename bug
  1189. lots of lint fixes
  1190. * Reformatted all the code in src (with GNU indent) and then
  1191. went back and fixed prototypes, etc since indent gets confused. The
  1192. rationale is that it is better to do it sooner than later and now
  1193. everything is consistent and will hopefully stay that way.
  1194. The basic options to indent were: "-bad -bbb -bap -cdb -d0 -bl -bli0
  1195. -nce -pcs -cs -cli4 -di1 -nbc -psl -lp -i4 -ip4 -c41" and then
  1196. miscellaneous formatting fixes were applied. Note also that the
  1197. "-nfc1" or "-nfca" may be appropriate in files where comments have
  1198. been carefully formatted (e.g, modules.c).
  1199. Sat Dec 14 20:35:22 1991 Brian Berliner (berliner at sun.com)
  1200. * Changes between CVS 1.2 and CVS 1.3 Beta are described here.
  1201. * Lots of portability work. CVS now uses the GNU "configure"
  1202. script to dynamically determine the features provided by your
  1203. system. It probably is not foolproof, but it is better than
  1204. nothing. Please let me know of any portability problems. Some
  1205. file names were changed to fit within 14-characters.
  1206. * CVS has a new RCS parser that is much more flexible and
  1207. extensible. It should read all known RCS ",v" format files.
  1208. * Most of the commands now are fully recursive, rather than just
  1209. operating on the current directory alone. This includes "commit",
  1210. which makes it real easy to do an "atomic" commit of all the
  1211. changes made to a CVS hierarchy of sources. Most of the commands
  1212. also correctly handle file names that are in directories other than
  1213. ".", including absolute path names. Commands now accept the "-R"
  1214. option to force recursion on (though it is always the default now)
  1215. and the "-l" option to force recursion off, doing just "." and not
  1216. any sub-directories.
  1217. * CVS supports many of the features provided with the RCS 5.x
  1218. distribution - including the new "-k" keyword expansion options. I
  1219. recommend using RCS 5.x (5.6 is the current official RCS version)
  1220. and GNU diff 1.15 (or later) distributions with CVS.
  1221. * Checking out files with symbolic tags/dates is now "sticky", in
  1222. that CVS remembers the tag/date used for each file (and directory)
  1223. and will use that tag/date automatically on the next "update" call.
  1224. This stickyness also holds for files checked out with the the new
  1225. RCS 5.x "-k" options.
  1226. * The "cvs diff" command now recognizes all of the rcsdiff 5.x
  1227. options. Unidiff format is available by installing the GNU
  1228. diff 1.15 distribution.
  1229. * The old "CVS.adm" directories created on checkout are now called
  1230. "CVS" directories, to look more like "RCS" and "SCCS". Old CVS.adm
  1231. directories are automagically converted to CVS directories. The
  1232. old "CVSROOT.adm" directory within the source repository is
  1233. automagically changed into a "CVSROOT" directory as well.
  1234. * Symbolic links in the source repository are fully supported ONLY
  1235. if you use RCS 5.6 or later and (of course) your system supports
  1236. symlinks.
  1237. * A history database has been contributed which maintains the
  1238. history of certain CVS operations, as well as providing a wide array
  1239. of querying options.
  1240. * The "cvs" program has a "-n" option which can be used with the
  1241. "update" command to show what would be updated without actually
  1242. doing the update, like: "cvs -n update". All usage statements
  1243. have been cleaned up and made more verbose.
  1244. * The module database parsing has been rewritten. The new format
  1245. is compatible with the old format, but with much more
  1246. functionality. It allows modules to be created that grab pieces or
  1247. whole directories from various different parts of your source
  1248. repository. Module-relative specifications are also correctly
  1249. recognized now, like "cvs checkout module/file.c".
  1250. * A configurable template can be specified such that on a "commit",
  1251. certain directories can supply a template that the user must fill
  1252. before completing the commit operation.
  1253. * A configurable pre-commit checking program can be specified which
  1254. will run to verify that a "commit" can happen. This feature can be
  1255. used to restrict certain users from changing certain pieces of the
  1256. source repository, or denying commits to the entire source
  1257. repository.
  1258. * The new "cvs export" command is much like "checkout", but
  1259. establishes defaults suitable for exporting code to others (expands
  1260. out keywords, forces the use of a symbolic tag, and does not create
  1261. "CVS" directories within the checked out sources.
  1262. * The new "cvs import" command replaces the deprecated "checkin"
  1263. shell script and is used to import sources into CVS control. It is
  1264. also much faster for the first-time import. Some algorithmic
  1265. improvements have also been made to reduce the number of
  1266. conflicting files on next-time imports.
  1267. * The new "cvs admin" command is basically an interface to the
  1268. "rcs" program. (Not yet implemented very well).
  1269. * Signal handling (on systems with BSD or POSIX signals) is much
  1270. improved. Interrupting CVS now works with a single interrupt!
  1271. * CVS now invokes RCS commands by direct fork/exec rather than
  1272. calling system(3). This improves performance by removing a call to
  1273. the shell to parse the arguments.
  1274. * Support for the .cvsignore file has been contributed. CVS will
  1275. now show "unknown" files as "? filename" as the result of an "update"
  1276. command. The .cvsignore file can be used to add files to the
  1277. current list of ignored files so that they won't show up as unknown.
  1278. * Command argument changes:
  1279. cvs: Added -l to turn off history logging.
  1280. Added -n to show what would be done without actually
  1281. doing anything.
  1282. Added -q/-Q for quiet and really quiet settings.
  1283. Added -t to show debugging trace.
  1284. add: Added -k to allow RCS 5.x -k options to be specified.
  1285. admin: New command; an interface to rcs(1).
  1286. checkout: Added -A to reset sticky tags/date/options.
  1287. Added -N to not shorten module paths.
  1288. Added -R option to force recursion.
  1289. Changed -p (prune empty directories) to -P option.
  1290. Changed -f option; forcing tags match is now default.
  1291. Added -p option to checkout module to standard output.
  1292. Added -s option to cat the modules db with status.
  1293. Added -d option to checkout in the specified directory.
  1294. Added -k option to use RCS 5.x -k support.
  1295. commit: Removed -a option; use -l instead.
  1296. Removed -f option.
  1297. Added -l option to disable recursion.
  1298. Added -R option to force recursion.
  1299. If no files specified, commit is recursive.
  1300. diff: Now recognizes all RCS 5.x rcsdiff options.
  1301. Added -l option to disable recursion.
  1302. Added -R option to force recursion.
  1303. history: New command; displays info about CVS usage.
  1304. import: Replaces "checkin" shell script; imports sources
  1305. under CVS control. Ignores files on the ignore
  1306. list (see -I option or .cvsignore description above).
  1307. export: New command; like "checkout", but w/special options
  1308. turned on by default to facilitate exporting sources.
  1309. join: Added -B option to join from base of the branch;
  1310. join now defaults to only joining with the top two
  1311. revisions on the branch.
  1312. Added -k option for RCS 5.x -k support.
  1313. log: Supports all RCS 5.x options.
  1314. Added -l option to disable recursion.
  1315. Added -R option to force recursion.
  1316. patch: Changed -f option; forcing tags match is now default.
  1317. Added -c option to force context-style diffs.
  1318. Added -u option to support unidiff-style diffs.
  1319. Added -V option to support RCS specific-version
  1320. keyword expansion formats.
  1321. Added -R option to force recursion.
  1322. remove: No option changes. It's a bit more verbose.
  1323. rtag: Equivalent to the old "cvs tag" command.
  1324. No option changes. It's a lot faster for re-tag.
  1325. status: New output formats with more information.
  1326. Added -l option to disable recursion.
  1327. Added -R option to force recursion.
  1328. Added -v option to show symbolic tags for files.
  1329. tag: Functionality changed to tag checked out files
  1330. rather than modules; use "rtag" command to get the
  1331. old "cvs tag" behaviour.
  1332. update: Added -A to reset sticky tags/date/options.
  1333. Changed -p (prune empty directories) to -P option.
  1334. Changed -f option; forcing tags match is now default.
  1335. Added -p option to checkout module to standard output.
  1336. Added -I option to add files to the ignore list.
  1337. Added -R option to force recursion.
  1338. Major Contributors:
  1339. * Jeff Polk <polk@bsdi.com> rewrote most of the grody code of CVS
  1340. 1.2. He made just about everything dynamic (by using malloc),
  1341. added a generic hashed list manager, re-wrote the modules database
  1342. parsing in a compatible - but extended way, generalized directory
  1343. hierarchy recursion for virtually all the commands (including
  1344. commit!), generalized the loginfo file to be used for pre-commit
  1345. checks and commit templates, wrote a new and flexible RCS parser,
  1346. fixed an uncountable number of bugs, and helped in the design of
  1347. future CVS features. If there's anything gross left in CVS, it's
  1348. probably my fault!
  1349. * David G. Grubbs <dgg@odi.com> contributed the CVS "history" and
  1350. "release" commands. As well as the ever-so-useful "-n" option of
  1351. CVS which tells CVS to show what it would do, without actually
  1352. doing it. He also contributed support for the .cvsignore file.
  1353. * Paul Sander, HaL Computer Systems, Inc. <paul@hal.com> wrote and
  1354. contributed the code in lib/sighandle.c. I added support for
  1355. POSIX, BSD, and non-POSIX/non-BSD systems.
  1356. * Free Software Foundation contributed the "configure" script and
  1357. other compatibility support in the "lib" directory, which will help
  1358. make CVS much more portable.
  1359. * Many others have contributed bug reports and enhancement requests.
  1360. Some have even submitted actual code which I have not had time yet
  1361. to integrate into CVS. Maybe for the next release.
  1362. * Thanks to you all!
  1363. Wed Feb 6 10:10:58 1991 Brian Berliner (berliner at sun.com)
  1364. * Changes from CVS 1.0 Patchlevel 1 to CVS 1.0 Patchlevel 2; also
  1365. known as "Changes from CVS 1.1 to CVS 1.2".
  1366. * Major new support with this release is the ability to use the
  1367. recently-posted RCS 5.5 distribution with CVS 1.2. See below for
  1368. other assorted bug-fixes that have been thrown in.
  1369. * ChangeLog (new): Added Emacs-style change-log file to CVS 1.2
  1370. release. Chronological description of changes between release.
  1371. * README: Small fixes to installation instructions. My email
  1372. address is now "berliner@sun.com".
  1373. * src/Makefile: Removed "rcstime.h". Removed "depend" rule.
  1374. * src/partime.c: Updated to RCS 5.5 version with hooks for CVS.
  1375. * src/maketime.c: Updated to RCS 5.5 version with hooks for CVS.
  1376. * src/rcstime.h: Removed from the CVS 1.2 distribution.
  1377. Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
  1378. * src/checkin.csh: Support for RCS 5.5 parsing.
  1379. Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1380. * src/collect_sets.c (Collect_Sets): Be quieter if "-f" option is
  1381. specified. When checking out files on-top-of other files that CVS
  1382. doesn't know about, run a diff in the hopes that they are really
  1383. the same file before aborting.
  1384. * src/commit.c (branch_number): Fix for RCS 5.5 parsing.
  1385. Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1386. * src/commit.c (do_editor): Bug fix - fprintf missing argument
  1387. which sometimes caused core dumps.
  1388. * src/modules.c (process_module): Properly NULL-terminate
  1389. update_dir[] in all cases.
  1390. * src/no_difference.c (No_Difference): The wrong RCS revision was
  1391. being registered in certain (strange) cases.
  1392. * src/patch.c (get_rcsdate): New algorithm. No need to call
  1393. maketime() any longer.
  1394. Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1395. * src/patchlevel.h: Increased patch level to "2".
  1396. * src/subr.c (isdir, islink): Changed to compare stat mode bits
  1397. correctly.
  1398. * src/tag.c (tag_file): Added support for following symbolic links
  1399. that are in the master source repository when tagging. Made tag
  1400. somewhat quieter in certain cases.
  1401. * src/update.c (update_process_lists): Unlink the user's file if it
  1402. was put on the Wlist, meaning that the user's file is not modified
  1403. and its RCS file has been removed by someone else.
  1404. * src/update.c (update): Support for "cvs update dir" to correctly
  1405. just update the argument directory "dir".
  1406. * src/cvs.h: Fixes for RCS 5.5 parsing.
  1407. * src/version_number.c (Version_Number): Fixes for parsing RCS 5.5
  1408. and older RCS-format files.
  1409. Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
  1410. * src/version_number.c (Version_Number): Bug fixes for "-f" option.
  1411. Bug fixes for parsing with certain branch numbers. RCS
  1412. revision/symbol parsing is much more solid now.
  1413. Wed Feb 14 10:01:33 1990 Brian Berliner (berliner at sun.com)
  1414. * Changes from CVS 1.0 Patchlevel 0 to CVS 1.0 Patchlevel 1; also
  1415. known as "Changes from CVS 1.0 to CVS 1.1".
  1416. * src/patch.c (get_rcsdate): Portability fix. Replaced call to
  1417. timelocal() with call to maketime().
  1418. Mon Nov 19 23:15:11 1990 Brian Berliner (berliner at prisma.com)
  1419. * Sent CVS 1.0 release to comp.sources.unix moderator and FSF.
  1420. * Special thanks to Dick Grune <dick@cs.vu.nl> for his work on the
  1421. 1986 version of CVS and making it available to the world. Dick's
  1422. version is available on uunet.uu.net in the
  1423. comp.sources.unix/volume6/cvs directory.