home *** CD-ROM | disk | FTP | other *** search
/ Magazyn Exec 5 / CD_Magazyn_EXEC_nr_5.iso / Programy / Programowanie / cvs-1.11.lha / cvs-1.11 / NEWS < prev    next >
Encoding:
Text File  |  2000-08-30  |  47.0 KB  |  1,116 lines

  1. Changes since 1.10:
  2.  
  3. * The new "cvs version" command gives a short version message.  If
  4. the repository is remote, both the client and server versions are
  5. reported.
  6.  
  7. * "cvs admin -t" now works correctly in client/server mode.
  8.  
  9. * The "cvs history" command output format has changed -- the date
  10. now includes the year and is given is ISO 8601 format (yyyy-mm-dd).
  11. Also, the new LogHistory option in CVSROOT/config can be used to
  12. control what information gets recorded in the log file and code has
  13. been added to record file removals.
  14.  
  15. * The buggy PreservePermissions code has been disabled.
  16.  
  17. * Anonymous read-only access can now be done without requiring a
  18. password.  On the server side, simply give that user (presumably
  19. `anonymous') an empty password in the CVSROOT/passwd file, and then
  20. any received password will authenticate successfully.
  21.  
  22. * There is a new access method :fork: which is similar to :local:
  23. except that it is implemented via the CVS remote protocol, and thus
  24. has a somewhat different set of quirks and bugs.
  25.  
  26. * The -d command line option no longer updates the CVS/Root file.  For
  27. one thing, the CVS 1.9/1.10 behavior never had updated CVS/Root in
  28. subdirectories, and for another, it didn't seem that popular in
  29. general.  So this change restores the CVS 1.8 behavior (which is also
  30. the CVS 1.9/1.10 behavior if the environment variable
  31. CVS_IGNORE_REMOTE_ROOT is set; with this change,
  32. CVS_IGNORE_REMOTE_ROOT no longer has any effect).
  33.  
  34. * It is now possible for a single CVS command to recurse into several
  35. CVS roots.  This includes roots which are located on several servers,
  36. or which are both remote and local.  CVS will make connections to as
  37. many servers as necessary.
  38.  
  39. * It is now possible to put the CVS lock files in a directory
  40. set by the new LockDir option in CVSROOT/config.  The default
  41. continues to be to put the lock files in the repository itself.
  42.  
  43. Changes from 1.9 to 1.10:
  44.  
  45. * There is a new feature, enabled by TopLevelAdmin in CVSROOT/config,
  46. which tells CVS to modify the behavior of the "checkout" command.  The
  47. command now creates a CVS directory at the top level of the new
  48. working directory, in addition to CVS directories created within
  49. checked-out directories.  See the Cederqvist for details.
  50.  
  51. * There is an optional set of features, enabled by PreservePermissions
  52. in CVSROOT/config, which allow CVS to store unix-specific file
  53. information such as permissions, file ownership, and links.  See the
  54. Cederqvist for details.
  55.  
  56. * One can now authenticate and encrypt using the GSSAPI network
  57. security interface.  For details see the Cederqvist's description of
  58. specifying :gserver: in CVSROOT, and the -a global option.
  59.  
  60. * All access to RCS files is now implemented internally rather than by
  61. calling RCS programs.  The main user-visible consequence of this is
  62. that there is no need to worry about making sure that CVS finds the
  63. correct version of RCS.  The -b global option and the RCSBIN setting
  64. in CVSROOT/config are still accepted but don't do anything.  The
  65. $RCSBIN internal variable in administrative files is no longer
  66. accepted.
  67.  
  68. * There is a new syntax, "cvs admin -orev1::rev2", which collapses the
  69. revisions between rev1 and rev2 without deleting rev1 or rev2
  70. themselves.
  71.  
  72. * There is a new administrative file CVSROOT/config which allows one
  73. to specify miscellaneous aspects of CVS configuration.  Currently
  74. supported here:
  75.  
  76.   - SystemAuth, allows you to prevent pserver from checking for system
  77.   usernames/passwords.
  78.  
  79. For more information see the "config" section of cvs.texinfo.
  80.  
  81. * When setting up the pserver server, one now must specify the
  82. allowable CVSROOT directories in inetd.conf.  See the Password
  83. authentication server section of cvs.texinfo for details.  Note that
  84. this implies that everyone who is running a pserver server must edit
  85. inetd.conf when upgrading their CVS.
  86.  
  87. * The client no longer needs an external patch program (assuming both
  88. the client and the server have been updated to the new version).
  89.  
  90. * "cvs admin [options]" will now recurse.  In previous versions of
  91. CVS, it was an error and one needed to specify "cvs admin [options] ."
  92. to recurse.  This change brings admin in line with the other CVS
  93. commands.
  94.  
  95. * New "logout" command to remove the password for a remote cvs
  96. repository from the cvspass file.
  97.  
  98. * Read-only repository access is implemented for the
  99. password-authenticated server (other access methods are just governed
  100. by Unix file permissions, since they require login access to the
  101. repository machine anyway).  See the "Repository" section of
  102. cvs.texinfo for details, including a discussion of security issues.
  103. Note that the requirement that read-only users be able to create locks
  104. and write the history file still applies.
  105.  
  106. * There is a new administrative file verifymsg which is like editinfo
  107. but merely validates the message, rather than also getting it from the
  108. user.  It therefore works with client/server CVS or if one uses the -m
  109. or -F options to commit.  See the verifymsg section of cvs.texinfo for
  110. details.
  111.  
  112. * The %s format formerly accepted in loginfo has been extended to
  113. formats such as %{sVv}, so that loginfo scripts have access to the
  114. version numbers being changed.  See the Loginfo section of cvs.texinfo
  115. for details.
  116.  
  117. * The postscript documentation (doc/cvs.ps) shipped with CVS is now
  118. formatted for US letter size instead of A4.  This is not because we
  119. consider this size "better" than A4, but because we believe that the
  120. US letter version will print better on A4 paper than the other way
  121. around.
  122.  
  123. * The "cvs export" command is now logged in the history file and there
  124. is a "cvs history -x E" command to select history file entries
  125. produced by export.
  126.  
  127. * CVS no longer uses the CVS_PASSWORD environment variable.  Storing
  128. passwords in cleartext in an environment variable is a security risk,
  129. especially since (on BSD variants) any user on the system can display
  130. any process's environment using 'ps'.  Users should use the 'cvs
  131. login' command instead.
  132.  
  133.  
  134. Changes from 1.8 to 1.9:
  135.  
  136. * Windows NT client should now work on Windows 95 as well.
  137.  
  138. * New option "--help-synonyms" prints a list of all recognized command
  139. synonyms.
  140.  
  141. * The "log" command is now implemented internally rather than via the
  142. RCS "rlog" program.  The main user-visible consequence is that
  143. symbolic branch names now work (for example "cvs log -rbranch1").
  144. Also, the date formats accepted by -d have changed.  They previously
  145. had been a bewildering variety of poorly-documented date formats.  Now
  146. they are the same as the date formats accepted by the -D options to
  147. the other CVS commands, which is also a (different) bewildering
  148. variety of poorly-documented date formats, but at least we are
  149. consistently bewildering :-).
  150.  
  151. * Encryption is now supported over a Kerberos client/server
  152. connection.  The new "-x" global option requests it.  You must
  153. configure with the --enable-encryption option in order to enable
  154. encryption.
  155.  
  156. * The format of the CVS commit message has changed slightly when
  157. committing changes on a branch.  The tag on which the commit is
  158. ocurring is now reported correctly in all cases.
  159.  
  160. * New flag -k in wrappers allows you to specify the keyword expansion
  161. mode for added files based on their name.  For example, you can
  162. specify that files whose name matches *.exe are binary by default.
  163. See the Wrappers section of cvs.texinfo for more details.
  164.  
  165. * Remote CVS with the "-z" option now uses the zlib library (included
  166. with CVS) to compress all communication between the client and the
  167. server, rather than invoking gzip on each file separately.  This means
  168. that compression is better and there is no need for an external gzip
  169. program (except to interoperate with older version of CVS).
  170.  
  171. * The "cvs rlog" command is deprecated and running it will print a
  172. warning; use the synonymous "cvs log" command instead.  It is
  173. confusing for rlog to mean the same as log because some other CVS
  174. commands are in pairs consisting of a plain command which operates on
  175. a working directory and an "r" command which does not (diff/rdiff;
  176. tag/rtag).
  177.  
  178. * "cvs diff" has a bunch of new options, mostly long options.  Most of
  179. these work only if rcsdiff and diff support them, and are named the
  180. same as the corresponding options to diff.
  181.  
  182. * The -q and -Q command options to "cvs diff" were removed (use the
  183. global options instead).  This brings "cvs diff" into line with the
  184. rest of the CVS commands.
  185.  
  186. * The "annotate" command can now be used to annotate a revision other
  187. than the head revision on the trunk (see the -r, -D, and -f options in
  188. the annotate node of cvs.texinfo for details).
  189.  
  190. * The "tag" command has a new option "-c" which checks that all files
  191.   are not locally modified before tagging.
  192.  
  193. * The -d command line option now overrides the cvsroot setting stored
  194. in the CVS/Root file in each working directory, and specifying -d will
  195. cause CVS/Root to be updated.
  196.  
  197. * Local (non-client/server) CVS now runs on Windows NT.  See
  198. windows-NT/README for details.
  199.  
  200. * The CVSROOT variable specification has changed to support more
  201. access methods.  In addition to "pserver," "server" (internal rsh
  202. client), "ext" (external rsh client), "kserver" (kerberos), and
  203. "local" (local filesystem access) can now be specified.  For more
  204. details on each method, see cvs.texinfo (there is an index entry for
  205. :local: and each of the other access methods).
  206.  
  207. * The "login" command no longer prompts the user for username and
  208. hostname, since one will have to provide that information via the `-d'
  209. flag or by setting CVSROOT.
  210.  
  211. Changes from 1.7 to 1.8:
  212.  
  213. * New "cvs annotate" command to display the last modification for each
  214. line of a file, with the revision number, user checking in the
  215. modification, and date of the modification.  For more information see
  216. the `annotate' node in cvs.texinfo.
  217.  
  218. * The cvsinit shell script has been replaced by a cvs init command.
  219. The cvs init command creates some example administrative files which
  220. are similar to the files found in the examples directory (and copied
  221. by cvsinit) in previous releases.
  222.  
  223. * Added the patterns *.olb *.exe _$* *$ to default ignore list.
  224.  
  225. * There is now a $USER internal variable for *info files.
  226.  
  227. * There is no longer a separate `mkmodules' program; the functionality
  228. is now built into `cvs'.  If upgrading an old repository, it is OK to
  229. leave in the lines in the modules file which run mkmodules (the
  230. mkmodules actions will get done twice, but that is harmless); you will
  231. probably want to remove them once you are no longer using the old CVS.
  232.  
  233. * One can now specify user variables in *info files via the
  234. ${=varname} syntax; there is a -s global option to set them.  See the
  235. Variables node in cvs.texinfo for details.
  236.  
  237. Changes from 1.6 to 1.7:
  238.  
  239. * The default ignore list has changed slightly: *.obj has been added
  240. and CVS* has been changed to CVS CVS.adm.
  241.  
  242. * CVS now supports password authentication when accessing remote
  243. repositories; this is useful for sites that can't use rsh (because of
  244. a firewall, for example), and also don't have kerberos.  See node
  245. "Password authenticated" (in "Remote repositories", in
  246. doc/cvs.texinfo) for more details.  Note: This feature requires both
  247. the client and server to be upgraded.
  248.  
  249. * Using the -kb option to specify binary files now works--most cases
  250. did not work before.  See the "Binary files" section of
  251. doc/cvs.texinfo for details.
  252.  
  253. * New developer communication features.  See the "Watches" section of
  254. doc/cvs.texinfo for details.
  255.  
  256. * RCS keyword "Name" supported for "cvs update -r <tag>" and "cvs
  257. checkout -r <tag>".
  258.  
  259. * If there is a group whose name matches a compiled in value which
  260. defaults to "cvsadmin", only members of that group can use "cvs
  261. admin".  This replaces the CVS_NOADMIN option.
  262.  
  263. * CVS now sets the modes of files in the repository based on the
  264. CVSUMASK environment variable or a compiled in value defaulting to
  265. 002.  This way other developers will be able to access the files in
  266. the repository regardless of the umask of the developer creating them.
  267.  
  268. * The command names in .cvsrc now match the official name of the
  269. command, not the one (possibly an alias) by which it was invoked.  If
  270. you had previously relied on "cvs di" and "cvs diff" using different
  271. options, instead use a shell function or alias (for example "alias
  272. cvsdi='cvs diff -u'").  You also can specify global CVS options (like
  273. "-z") using the command name "cvs".
  274.  
  275. Changes from 1.5 to 1.6:
  276.  
  277. * Del updated the man page to include all of the new features
  278. of CVS 1.6.
  279.  
  280. * "cvs tag" now supports a "-r | -D" option for tagging an already
  281. tagged revision / specific revision of a file.
  282.  
  283. * There is a "taginfo" file in CVSROOT that supports filtering and
  284. recording of tag operations.
  285.  
  286. * Long options support added, including --help and --version options.
  287.  
  288. * "cvs release" no longer cares whether or not the directory being
  289. released has an entry in the `modules' file.
  290.  
  291. * The modules file now takes a -e option which is used instead of -o
  292. for "cvs export".  If your modules file has a -o option which you want
  293. to be used for "cvs export", change it to specify -e as well as -o.
  294.  
  295. * "cvs export" now takes a -k option to set RCS keyword expansion.
  296. This way you can export binary files.  If you want the old behavior,
  297. you need to specify -kv.
  298.  
  299. * "cvs update", "cvs rdiff", "cvs checkout", "cvs import", "cvs
  300. release", "cvs rtag", and "cvs tag" used to take -q and -Q options
  301. after the command name (e.g. "cvs update -q").  This was confusing
  302. because other commands, such as "cvs ci", did not.  So the options
  303. after the command name have been removed and you must now specify, for
  304. example, "cvs -q update", which has been supported since CVS 1.3.
  305.  
  306. * New "wrappers" feature.  This allows you to set a hook which
  307. transforms files on their way in and out of cvs (apparently on the
  308. NeXT there is some particular usefulness in tarring things up in the
  309. repository).  It also allows you to declare files as merge-by-copy
  310. which means that instead of trying to merge the file, CVS will merely
  311. copy the new version.  There is a CVSROOT/cvswrappers file and an
  312. optionsl ~/.cvswrappers file to support this feature.
  313.  
  314. * You can set CVSROOT to user@host:dir, not just host:dir, if your
  315. username on the server host is different than on the client host.
  316.  
  317. * VISUAL is accepted as well as EDITOR.
  318.  
  319. * $CVSROOT is expanded in *info files.
  320.  
  321. Changes from 1.4A2 to 1.5:
  322.  
  323. * Remote implementation.  This is very helpful when collaborating on a
  324. project with someone across a wide-area network.  This release can
  325. also be used locally, like other CVS versions, if you have no need for
  326. remote access.
  327.  
  328. Here are some of the features of the remote implementation:
  329. - It uses reliable transport protocols (TCP/IP) for remote repository
  330.   access, not NFS.  NFS is unusable over long distances (and sometimes
  331.   over short distances)
  332. - It transfers only those files that have changed in the repository or
  333.   the working directory.  To save transmission time, it will transfer
  334.   patches when appropriate, and can compress data for transmission.
  335. - The server never holds CVS locks while waiting for a reply from the client;
  336.   this makes the system robust when used over flaky networks.
  337.  
  338. The remote features are documented in doc/cvsclient.texi in the CVS
  339. distribution, but the main doc file, cvs.texinfo, has not yet been
  340. updated to include the remote features.
  341.  
  342. * Death support.  See src/README-rm-add for more information on this.
  343.  
  344. * Many speedups, especially from jtc@cygnus.com.
  345.  
  346. * CVS 1.2 compatibility code has been removed as a speedup.  If you
  347. have working directories checked out by CVS 1.2, CVS 1.3 or 1.4A2 will
  348. try to convert them, but CVS 1.5 and later will not (if the working
  349. directory is up to date and contains no extraneous files, you can just
  350. remove it, and then check out a new working directory).  Likewise if
  351. your repository contains a CVSROOT.adm directory instead of a CVSROOT
  352. directory, you need to rename it.
  353.  
  354. Fri Oct 21 20:58:54 1994  Brian Berliner  <berliner@sun.com>
  355.  
  356.     * Changes between CVS 1.3 and CVS 1.4 Alpha-2
  357.  
  358.     * A new program, "cvsbug", is provided to let you send bug reports
  359.     directly to the CVS maintainers.  Please use it instead of sending
  360.     mail to the info-cvs mailing list.  If your build fails, you may
  361.     have to invoke "cvsbug" directly from the "src" directory as
  362.     "src/cvsbug.sh".
  363.  
  364.     * A new User's Guide and Tutorial, written by Per Cederqvist
  365.     <ceder@signum.se> of Signum Support.  See the "doc" directory.  A
  366.     PostScript version is included as "doc/cvs.ps".
  367.  
  368.     * The Frequesntly Asked Questions file, FAQ, has been added to the
  369.     release.  Unfortunately, its contents are likely out-of-date.
  370.  
  371.     * The "cvsinit" shell script is now installed in the $prefix/bin
  372.     directory like the other programs.  You can now create new
  373.     CVS repositories with great ease.
  374.  
  375.     * Index: lines are now printed on output from 'diff' and 'rdiff',
  376.     in order to facilitate application of patches to multiple subdirs.
  377.  
  378.     * Support for a ~/.cvsrc file, which allows you to specify options
  379.     that are always supposed to be given to a specific command.  This
  380.     feature shows the non-orthogonality of the option set, since while
  381.     there may be an option to turn something on, the option to turn
  382.     that same thing off may not exist.
  383.  
  384.     * You can now list subdirectories that you wish to ignore in a
  385.     modules listing, such as:
  386.  
  387.         gcc  -a gnu/gcc, !gnu/gcc/testsuites
  388.  
  389.     which will check out everything underneath gnu/gcc, except
  390.     everything underneath gnu/gcc/testsuites.
  391.  
  392.     * It is now much harder to accidentally overwrite an existing tag
  393.     name, since attempting to move a tag name will result in a error,
  394.     unless the -F (force) flag is given to the tag subcommands.
  395.  
  396.     * Better error checking on matching of the repository used to
  397.     check code out from against the repository the current cvs
  398.     commnands would use. (Thanks to Mark Baushke <mdb@cisco.com>)
  399.  
  400.     * Better support for sites with multiple CVSROOT repositories has
  401.     been contributed.  The file "CVS/Root" in your working directory
  402.     is created to hold the full path to the CVS repository and a
  403.     simple check is made against your current CVSROOT setting.
  404.  
  405.     * You can now specify an RCS keyword substitution value when you
  406.     import files into the repository.
  407.  
  408.     * Uses a much newer version of Autoconf, and conforms to the GNU
  409.     coding standards much more closely.  No, it still doesn't have
  410.     long option names.
  411.  
  412.     * Code cleanup.  Many passes through gcc -Wall helped to identify
  413.     a number of questionable constructs.  Most arbitrary length limits
  414.     were removed.
  415.  
  416.     * Profiling to determine bottlenecks helped to identify the best
  417.     places to spend time speeding up the code, which was then done.  A
  418.     number of performance enhancements in filename matching have sped
  419.     up checkouts.
  420.  
  421.     * Many more contributions have been added to the "contrib"
  422.     directory.  See the README file in that directory for more
  423.     information.
  424.  
  425.     * "cvs commit" will try harder to not change the file's
  426.     modification time after the commit.  If the file does not change
  427.     as a result of the commit operation, CVS will preserve the
  428.     original modification time, thus speeding up future make-type
  429.     builds.
  430.  
  431.     * "cvs commit" now includes any removed files in the (optional)
  432.     pre-commit checking program that may be invoked.  Previously, only
  433.     added and modified files were included.
  434.  
  435.     * It is now possible to commit a file directly onto the trunk at a
  436.     specific revision level by doing "cvs commit -r3.0 file.c", where
  437.     "3.0" specifies the revision you wish to create.  The file must be
  438.     up-to-date with the current head of the trunk for this to succeed.
  439.  
  440.     * "cvs commit" will now function with a pre-commit program that
  441.     has arguments specified in the "commitinfo" file.
  442.  
  443.     * The "mkmodules" program will now look within the
  444.     $CVSROOT/CVSROOT/checkoutlist" file for any additional files that
  445.     should be automatically checked out within CVSROOT; mkmodules also
  446.     tries harder to preserve any execute bits the files may have
  447.     originally had.
  448.  
  449.     * "cvs diff" is much more accurate about its exit status now.  It
  450.     now returns the maximum exit status of any invoked diff.
  451.  
  452.     * The "-I !" option is now supported for the import and update
  453.     commands correctly.  It will properly clear the ignore list now.
  454.  
  455.     * Some problems with "cvs import" handling of .cvsignore have been
  456.     fixed; as well, some rampant recursion problems with import have
  457.     also been fixed.
  458.  
  459.     * "cvs rdiff" (aka "cvs patch") now tries to set the modify time
  460.     of any temporary files it uses to match those specified for the
  461.     particular revision.  This allows a more accurate patch image to
  462.     be created.
  463.  
  464.     * "cvs status" has improved revision descriptions.  "Working
  465.     revision" is used for the revision of the working file that you
  466.     edit directly; "Repository revision" is the revision of the file
  467.     with the $CVSROOT source repository.  Also, the output is clearer
  468.     with regard to sticky and branch revisions.
  469.  
  470.     * CVS no longer dumps core when given a mixture of directories and
  471.     files in sub-directories (as in "cvs ci file1 dir1/file2").
  472.     Instead, arguments are now clumped into their respective directory
  473.     and operated on in chunks, together.
  474.  
  475.     * If the CVSEDITOR environment variable is set, that editor is
  476.     used for log messages instead of the EDITOR environment variable.
  477.     This makes it easy to substitute intelligent programs to make more
  478.     elaborate log messages.  Contributed by Mark D Baushke
  479.     (mdb@cisco.com).
  480.  
  481.     * Command argument changes:
  482.     cvs:            The "-f" option has been added to ignore
  483.                 the ~/.cvsrc file.
  484.     commit:            Renamed the "-f logfile" option to the
  485.                 "-F logfile" option.  Added the "-f"
  486.                 option to force a commit of the specified
  487.                 files (this disables recursion).
  488.     history:        Added "-t timezone" option to force any
  489.                 date-specific output into the specified
  490.                 timezone.
  491.     import:            Added "-d" option to use the file's
  492.                 modification time as the time of the
  493.                 import. Added "-k sub" option to set the
  494.                 default RCS keyword substitution mode for
  495.                 newly-created files.
  496.     remove:            Added "-f" option to force the file's
  497.                 automatic removal if it still exists in
  498.                 the working directory (use with caution).
  499.     rtag:            Added "-F" option to move the tag if it
  500.                 already exists -- new default is to NOT
  501.                 move tags automatically.
  502.     tag:            Added "-F" option to move the tag if it
  503.                 already exists -- new default is to NOT
  504.                 move tags automatically.
  505.  
  506. Tue Apr  7 15:55:25 1992  Brian Berliner  (berliner at sun.com)
  507.  
  508.     * Changes between CVS 1.3 Beta-3 and official CVS 1.3!
  509.  
  510.     * A new shell script is provided, "./cvsinit", which can be run at
  511.     install time to help setup your $CVSROOT area.  This can greatly
  512.     ease your entry into CVS usage.
  513.  
  514.     * The INSTALL file has been updated to include the machines on
  515.     which CVS has compiled successfully.  I think CVS 1.3 is finally
  516.     portable.  Thanks to all the Beta testers!
  517.  
  518.     * Support for the "editinfo" file was contributed.  This file
  519.     (located in $CVSROOT/CVSROOT) can be used to specify a special
  520.     "editor" to run on a per-directory basis within the repository,
  521.     instead of the usual user's editor.  As such, it can verify that
  522.     the log message entered by the user is of the appropriate form
  523.     (contains a bugid and test validation, for example).
  524.  
  525.     * The manual pages cvs(1) and cvs(5) have been updated.
  526.  
  527.     * The "mkmodules" command now informs you when your modules file
  528.     has duplicate entries.
  529.  
  530.     * The "add" command now preserves any per-directory sticky tag when
  531.     you add a new directory to your checked-out sources.
  532.  
  533.     * The "admin" command is now a fully recursive interface to the
  534.     "rcs" program which operates on your checked-out sources.  It no
  535.     longer requires you to specify the full path to the RCS file.
  536.  
  537.     * The per-file sticky tags can now be effectively removed with
  538.     "cvs update -A file", even if you had checked out the whole
  539.     directory with a per-directory sticky tag.  This allows a great
  540.     deal of flexibility in managing the revisions that your checked-out
  541.     sources are based upon (both per-directory and per-file sticky
  542.     tags).
  543.  
  544.     * The "cvs -n commit" command now works, to show which files are
  545.     out-of-date and will cause the real commit to fail, or which files
  546.     will fail any pre-commit checks.  Also, the "cvs -n import ..."
  547.     command will now show you what it would've done without actually
  548.     doing it.
  549.  
  550.     * Doing "cvs commit modules" to checkin the modules file will no
  551.     properly run the "mkmodules" program (assuming you have setup your
  552.     $CVSROOT/CVSROOT/modules file to do so).
  553.  
  554.     * The -t option in the modules file (which specifies a program to
  555.     run when you do a "cvs rtag" operation on a module) now gets the
  556.     symbolic tag as the second argument when invoked.
  557.  
  558.     * When the source repository is locked by another user, that user's
  559.     login name will be displayed as the holder of the lock.
  560.  
  561.     * Doing "cvs checkout module/file.c" now works even if
  562.     module/file.c is in the Attic (has been removed from main-line
  563.     development).
  564.  
  565.     * Doing "cvs commit */Makefile" now works as one would expect.
  566.     Rather than trying to commit everything recursively, it will now
  567.     commit just the files specified.
  568.  
  569.     * The "cvs remove" command is now fully recursive.  To schedule a
  570.     file for removal, all you have to do is "rm file" and "cvs rm".
  571.     With no arguments, "cvs rm" will schedule all files that have been
  572.     physically removed for removal from the source repository at the
  573.     next "cvs commit".
  574.  
  575.     * The "cvs tag" command now prints "T file" for each file that was
  576.     tagged by this invocation and "D file" for each file that had the
  577.     tag removed (as with "cvs tag -d").
  578.  
  579.     * The -a option has been added to "cvs rtag" to force it to clean
  580.     up any old, matching tags for files that have been removed (in the
  581.     Attic) that may not have been touched by this tag operation.  This
  582.     can help keep a consistent view with your tag, even if you re-use
  583.     it frequently.
  584.  
  585. Sat Feb 29 16:02:05 1992  Brian Berliner  (berliner at sun.com)
  586.  
  587.     * Changes between CVS 1.3 Beta-2 and CVS 1.3 Beta-3
  588.  
  589.     * Many portability fixes, thanks to all the Beta testers!  With any
  590.     luck, this Beta release will compile correctly on most anything.
  591.     Hey, what are we without our dreams.
  592.  
  593.     * CVS finally has support for doing isolated development on a
  594.     branch off the current (or previous!) revisions.  This is also
  595.     extremely nice for generating patches for previously released
  596.     software while development is progressing on the next release.
  597.     Here's an example of creating a branch to fix a patch with the 2.0
  598.     version of the "foo" module, even though we are already well into
  599.     the 3.0 release.  Do:
  600.  
  601.         % cvs rtag -b -rFOO_2_0 FOO_2_0_Patch foo
  602.         % cvs checkout -rFOO_2_0_Patch foo
  603.         % cd foo
  604.         [[ hack away ]]
  605.         % cvs commit
  606.  
  607.     A physical branch will be created in the RCS file only when you
  608.     actually commit the change.  As such, forking development at some
  609.     random point in time is extremely light-weight -- requiring just a
  610.     symbolic tag in each file until a commit is done.  To fork
  611.     development at the currently checked out sources, do:
  612.  
  613.         % cvs tag -b Personal_Hack
  614.         % cvs update -rPersonal_Hack
  615.         [[ hack away ]]
  616.         % cvs commit
  617.  
  618.     Now, if you decide you want the changes made in the Personal_Hack
  619.     branch to be merged in with other changes made in the main-line
  620.     development, you could do:
  621.  
  622.         % cvs commit             # to make Personal_Hack complete
  623.         % cvs update -A             # to update sources to main-line
  624.         % cvs update -jPersonal_Hack # to merge Personal_Hack
  625.  
  626.     to update your checked-out sources, or:
  627.  
  628.         % cvs checkout -jPersonal_Hack module
  629.  
  630.     to checkout a fresh copy.
  631.  
  632.     To support this notion of forked development, CVS reserves
  633.     all even-numbered branches for its own use.  In addition, CVS
  634.     reserves the ".0" and ".1" branches.  So, if you intend to do your
  635.     own branches by hand with RCS, you should use odd-numbered branches
  636.     starting with ".3", as in "1.1.3", "1.1.5", 1.2.9", ....
  637.  
  638.     * The "cvs commit" command now supports a fully functional -r
  639.     option, allowing you to commit your changes to a specific numeric
  640.     revision or symbolic tag with full consistency checks.  Numeric
  641.     tags are useful for bringing your sources all up to some revision
  642.     level:
  643.  
  644.         % cvs commit -r2.0
  645.  
  646.     For symbolic tags, you can only commit to a tag that references a
  647.     branch in the RCS file.  One created by "cvs rtag -b" or from
  648.     "cvs tag -b" is appropriate (see below).
  649.  
  650.     * Roland Pesch <pesch@cygnus.com> and K. Richard Pixley
  651.     <rich@cygnus.com> were kind enough to contribute two new manual
  652.     pages for CVS: cvs(1) and cvs(5).  Most of the new CVS 1.3 features
  653.     are now documented, with the exception of the new branch support
  654.     added to commit/rtag/tag/checkout/update.
  655.  
  656.     * The -j options of checkout/update have been added.  The "cvs join"
  657.     command has been removed.
  658.  
  659.     With one -j option, CVS will merge the changes made between the
  660.     resulting revision and the revision that it is based on (e.g., if
  661.     the tag refers to a branch, CVS will merge all changes made in
  662.     that branch into your working file).
  663.  
  664.     With two -j options, CVS will merge in the changes between the two
  665.     respective revisions.  This can be used to "remove" a certain delta
  666.     from your working file.  E.g., If the file foo.c is based on
  667.     revision 1.6 and I want to remove the changes made between 1.3 and
  668.     1.5, I might do:
  669.  
  670.         % cvs update -j1.5 -j1.3 foo.c        # note the order...
  671.  
  672.     In addition, each -j option can contain on optional date
  673.     specification which, when used with branches, can limit the chosen
  674.     revision to one within a specific date.  An optional date is
  675.     specified by adding a colon (:) to the tag, as in:
  676.  
  677.         -jSymbolic_Tag:Date_Specifier
  678.  
  679.     An example might be what "cvs import" tells you to do when you have
  680.     just imported sources that have conflicts with local changes:
  681.  
  682.         % cvs checkout -jTAG:yesterday -jTAG module
  683.  
  684.     which tells CVS to merge in the changes made to the branch
  685.     specified by TAG in the last 24 hours.  If this is not what is
  686.     intended, substitute "yesterday" for whatever format of date that
  687.     is appropriate, like:
  688.  
  689.         % cvs checkout -jTAG:'1 week ago' -jTAG module
  690.  
  691.     * "cvs diff" now supports the special tags "BASE" and "HEAD".  So,
  692.     the command:
  693.  
  694.         % cvs diff -u -rBASE -rHEAD
  695.  
  696.     will effectively show the changes made by others (in unidiff
  697.     format) that will be merged into your working sources with your
  698.     next "cvs update" command.  "-rBASE" resolves to the revision that
  699.     your working file is based on.  "-rHEAD" resolves to the current
  700.     head of the branch or trunk that you are working on.
  701.  
  702.     * The -P option of "cvs checkout" now means to Prune empty
  703.     directories, as with "update".  The default is to not remove empty
  704.     directories.  However, if you do "checkout" with any -r options, -P
  705.     will be implied.  I.e., checking out with a tag will cause empty
  706.     directories to be pruned automatically.
  707.  
  708.     * The new file INSTALL describes how to install CVS, including
  709.     detailed descriptions of interfaces to "configure".
  710.  
  711.     * The example loginfo file in examples/loginfo has been updated to
  712.     use the perl script included in contrib/log.pl.  The nice thing
  713.     about this log program is that it records the revision numbers of
  714.     your change in the log message.
  715.  
  716.     Example files for commitinfo and rcsinfo are now included in the
  717.     examples directory.
  718.  
  719.     * All "#if defined(__STDC__) && __STDC__ == 1" lines have been
  720.     changed to be "#if __STDC__" to fix some problems with the former.
  721.  
  722.     * The lib/regex.[ch] files have been updated to the 1.3 release of
  723.     the GNU regex package.
  724.  
  725.     * The ndbm emulation routines included with CVS 1.3 Beta-2 in the
  726.     src/ndbm.[ch] files has been moved into the src/myndbm.[ch] files
  727.     to avoid any conflict with the system <ndbm.h> header file.  If
  728.     you had a previous CVS 1.3 Beta release, you will want to "cvs
  729.     remove ndbm.[ch]" form your copy of CVS as well.
  730.  
  731.     * "cvs add" and "cvs remove" are a bit more verbose, telling you
  732.     what to do to add/remove your file permanently.
  733.  
  734.     * We no longer mess with /dev/tty in "commit" and "add".
  735.  
  736.     * More things are quiet with the -Q option set.
  737.  
  738.     * New src/config.h option:  If CVS_BADROOT is set, CVS will not
  739.     allow people really logged in as "root" to commit changes.
  740.  
  741.     * "cvs diff" exits with a status of 0 if there were no diffs, 1 if
  742.     there were diffs, and 2 if there were errors.
  743.  
  744.     * "cvs -n diff" is now supported so that you can still run diffs
  745.     even while in the middle of committing files.
  746.  
  747.     * Handling of the CVS/Entries file is now much more robust.
  748.  
  749.     * The default file ignore list now includes "*.so".
  750.  
  751.     * "cvs import" did not expand '@' in the log message correctly.  It
  752.     does now.  Also, import now uses the ignore file facility
  753.     correctly.
  754.  
  755.     Import will now tell you whether there were conflicts that need to
  756.     be resolved, and how to resolve them.
  757.  
  758.     * "cvs log" has been changed so that you can "log" things that are
  759.     not a part of the current release (in the Attic).
  760.  
  761.     * If you don't change the editor message on commit, CVS now prompts
  762.     you with the choice:
  763.  
  764.         !)reuse this message unchanged for remaining dirs
  765.  
  766.     which allows you to tell CVS that you have no intention of changing
  767.     the log message for the remainder of the commit.
  768.  
  769.     * It is no longer necessary to have CVSROOT set if you are using
  770.     the -H option to get Usage information on the commands.
  771.  
  772.     * Command argument changes:
  773.     checkout:        -P handling changed as described above.
  774.                 New -j option (up to 2 can be specified)
  775.                 for doing rcsmerge kind of things on
  776.                 checkout.
  777.     commit:            -r option now supports committing to a
  778.                 numeric or symbolic tags, with some
  779.                 restrictions.  Full consistency checks will
  780.                 be done.
  781.                 Added "-f logfile" option, which tells
  782.                 commit to glean the log message from the
  783.                 specified file, rather than invoking the
  784.                 editor.
  785.     rtag:            Added -b option to create a branch tag,
  786.                 useful for creating a patch for a previous
  787.                 release, or for forking development.
  788.     tag:            Added -b option to create a branch tag,
  789.                 useful for creating a patch for a previous
  790.                 release, or for forking development.
  791.     update:            New -j option (up to 2 can be specified)
  792.                 for doing rcsmerge kind of things on
  793.                 update.
  794.  
  795. Thu Jan  9 10:51:35 MST 1992 Jeff Polk (polk at BSDI.COM)
  796.  
  797.     * Changes between CVS 1.3 Beta-1 and CVS 1.3 Beta-2
  798.  
  799.     * Thanks to K. Richard Pixley at Cygnus we now have function
  800.     prototypes in all the files
  801.  
  802.     * Some small changes to configure for portability.  There have
  803.     been other portability problems submitted that have not been fixed
  804.     (Brian will be working on those).  Additionally all __STDC__
  805.     tests have been modified to check __STDC__ against the constant 1 
  806.     (this is what the Second edition of K&R says must be true).
  807.  
  808.     * Lots of additional error checking for forked processes (run_exec)
  809.     (thanks again to K. Richard Pixley)
  810.  
  811.     * Lots of miscellaneous bug fixes - including but certainly not 
  812.     limited to:
  813.         various commit core dumps
  814.         various update core dumps
  815.         bogus results from status with numeric sticky tags
  816.         commitprog used freed memory
  817.         Entries file corruption caused by No_Difference
  818.         commit to revision broken (now works if branch exists)
  819.         ignore file processing broken for * and !
  820.         ignore processing didn't handle memory reasonably
  821.         miscellaneous bugs in the recursion processor
  822.         file descriptor leak in ParseInfo
  823.         CVSROOT.adm->CVSROOT rename bug
  824.         lots of lint fixes
  825.  
  826.     * Reformatted all the code in src (with GNU indent) and then 
  827.     went back and fixed prototypes, etc since indent gets confused.  The
  828.     rationale is that it is better to do it sooner than later and now
  829.     everything is consistent and will hopefully stay that way.
  830.     The basic options to indent were: "-bad -bbb -bap -cdb -d0 -bl -bli0 
  831.     -nce -pcs -cs -cli4 -di1 -nbc -psl -lp -i4 -ip4 -c41"  and then
  832.     miscellaneous formatting fixes were applied.  Note also that the 
  833.     "-nfc1" or "-nfca" may be appropriate in files where comments have
  834.     been carefully formatted (e.g, modules.c).
  835.  
  836. Sat Dec 14 20:35:22 1991  Brian Berliner  (berliner at sun.com)
  837.  
  838.     * Changes between CVS 1.2 and CVS 1.3 Beta are described here.
  839.  
  840.     * Lots of portability work.  CVS now uses the GNU "configure"
  841.     script to dynamically determine the features provided by your
  842.     system.  It probably is not foolproof, but it is better than
  843.     nothing.  Please let me know of any portability problems.  Some
  844.     file names were changed to fit within 14-characters.
  845.  
  846.     * CVS has a new RCS parser that is much more flexible and
  847.     extensible.  It should read all known RCS ",v" format files.
  848.  
  849.     * Most of the commands now are fully recursive, rather than just
  850.     operating on the current directory alone.  This includes "commit",
  851.     which makes it real easy to do an "atomic" commit of all the
  852.     changes made to a CVS hierarchy of sources.  Most of the commands
  853.     also correctly handle file names that are in directories other than
  854.     ".", including absolute path names.  Commands now accept the "-R"
  855.     option to force recursion on (though it is always the default now)
  856.     and the "-l" option to force recursion off, doing just "." and not
  857.     any sub-directories.
  858.  
  859.     * CVS supports many of the features provided with the RCS 5.x
  860.     distribution - including the new "-k" keyword expansion options.  I
  861.     recommend using RCS 5.x (5.6 is the current official RCS version)
  862.     and GNU diff 1.15 (or later) distributions with CVS.
  863.  
  864.     * Checking out files with symbolic tags/dates is now "sticky", in
  865.     that CVS remembers the tag/date used for each file (and directory)
  866.     and will use that tag/date automatically on the next "update" call.
  867.     This stickyness also holds for files checked out with the the new
  868.     RCS 5.x "-k" options.
  869.  
  870.     * The "cvs diff" command now recognizes all of the rcsdiff 5.x
  871.     options.  Unidiff format is available by installing the GNU
  872.     diff 1.15 distribution.
  873.  
  874.     * The old "CVS.adm" directories created on checkout are now called
  875.     "CVS" directories, to look more like "RCS" and "SCCS".  Old CVS.adm
  876.     directories are automagically converted to CVS directories.  The
  877.     old "CVSROOT.adm" directory within the source repository is
  878.     automagically changed into a "CVSROOT" directory as well.
  879.  
  880.     * Symbolic links in the source repository are fully supported ONLY
  881.     if you use RCS 5.6 or later and (of course) your system supports
  882.     symlinks.
  883.  
  884.     * A history database has been contributed which maintains the
  885.     history of certain CVS operations, as well as providing a wide array
  886.     of querying options.
  887.  
  888.     * The "cvs" program has a "-n" option which can be used with the
  889.     "update" command to show what would be updated without actually
  890.     doing the update, like:  "cvs -n update".  All usage statements
  891.     have been cleaned up and made more verbose.
  892.  
  893.     * The module database parsing has been rewritten.  The new format
  894.     is compatible with the old format, but with much more
  895.     functionality.  It allows modules to be created that grab pieces or
  896.     whole directories from various different parts of your source
  897.     repository.  Module-relative specifications are also correctly
  898.     recognized now, like "cvs checkout module/file.c".
  899.  
  900.     * A configurable template can be specified such that on a "commit", 
  901.     certain directories can supply a template that the user must fill
  902.     before completing the commit operation.
  903.  
  904.     * A configurable pre-commit checking program can be specified which
  905.     will run to verify that a "commit" can happen.  This feature can be
  906.     used to restrict certain users from changing certain pieces of the
  907.     source repository, or denying commits to the entire source
  908.     repository.
  909.  
  910.     * The new "cvs export" command is much like "checkout", but
  911.     establishes defaults suitable for exporting code to others (expands
  912.     out keywords, forces the use of a symbolic tag, and does not create
  913.     "CVS" directories within the checked out sources.
  914.  
  915.     * The new "cvs import" command replaces the deprecated "checkin"
  916.     shell script and is used to import sources into CVS control.  It is
  917.     also much faster for the first-time import.  Some algorithmic
  918.     improvements have also been made to reduce the number of
  919.     conflicting files on next-time imports.
  920.  
  921.     * The new "cvs admin" command is basically an interface to the
  922.     "rcs" program.  (Not yet implemented very well).
  923.  
  924.     * Signal handling (on systems with BSD or POSIX signals) is much
  925.     improved.  Interrupting CVS now works with a single interrupt!
  926.  
  927.     * CVS now invokes RCS commands by direct fork/exec rather than
  928.     calling system(3).  This improves performance by removing a call to
  929.     the shell to parse the arguments.
  930.  
  931.     * Support for the .cvsignore file has been contributed.  CVS will
  932.     now show "unknown" files as "? filename" as the result of an "update"
  933.     command.  The .cvsignore file can be used to add files to the
  934.     current list of ignored files so that they won't show up as unknown.
  935.  
  936.     * Command argument changes:
  937.     cvs:        Added -l to turn off history logging.
  938.             Added -n to show what would be done without actually
  939.             doing anything.
  940.             Added -q/-Q for quiet and really quiet settings.
  941.             Added -t to show debugging trace.
  942.     add:        Added -k to allow RCS 5.x -k options to be specified.
  943.     admin:        New command; an interface to rcs(1).
  944.     checkout:    Added -A to reset sticky tags/date/options.
  945.             Added -N to not shorten module paths.
  946.             Added -R option to force recursion.
  947.             Changed -p (prune empty directories) to -P option.
  948.             Changed -f option; forcing tags match is now default.
  949.             Added -p option to checkout module to standard output.
  950.             Added -s option to cat the modules db with status.
  951.             Added -d option to checkout in the specified directory.
  952.             Added -k option to use RCS 5.x -k support.
  953.     commit:        Removed -a option; use -l instead.
  954.             Removed -f option.
  955.             Added -l option to disable recursion.
  956.             Added -R option to force recursion.
  957.             If no files specified, commit is recursive.
  958.     diff:        Now recognizes all RCS 5.x rcsdiff options.
  959.             Added -l option to disable recursion.
  960.             Added -R option to force recursion.
  961.     history:    New command; displays info about CVS usage.
  962.     import:        Replaces "checkin" shell script; imports sources
  963.             under CVS control.  Ignores files on the ignore
  964.             list (see -I option or .cvsignore description above).
  965.     export:        New command; like "checkout", but w/special options
  966.             turned on by default to facilitate exporting sources.
  967.     join:        Added -B option to join from base of the branch;
  968.             join now defaults to only joining with the top two
  969.             revisions on the branch.
  970.             Added -k option for RCS 5.x -k support.
  971.     log:        Supports all RCS 5.x options.
  972.             Added -l option to disable recursion.
  973.             Added -R option to force recursion.
  974.     patch:        Changed -f option; forcing tags match is now default.
  975.             Added -c option to force context-style diffs.
  976.             Added -u option to support unidiff-style diffs.
  977.             Added -V option to support RCS specific-version
  978.             keyword expansion formats.
  979.             Added -R option to force recursion.
  980.     remove:        No option changes.  It's a bit more verbose.
  981.     rtag:        Equivalent to the old "cvs tag" command.
  982.             No option changes.  It's a lot faster for re-tag.
  983.     status:        New output formats with more information.
  984.             Added -l option to disable recursion.
  985.             Added -R option to force recursion.
  986.             Added -v option to show symbolic tags for files.
  987.     tag:        Functionality changed to tag checked out files
  988.             rather than modules; use "rtag" command to get the
  989.             old "cvs tag" behaviour.
  990.     update:        Added -A to reset sticky tags/date/options.
  991.             Changed -p (prune empty directories) to -P option.
  992.             Changed -f option; forcing tags match is now default.
  993.             Added -p option to checkout module to standard output.
  994.             Added -I option to add files to the ignore list.
  995.             Added -R option to force recursion.
  996.  
  997.     Major Contributors:
  998.  
  999.     * Jeff Polk <polk@bsdi.com> rewrote most of the grody code of CVS
  1000.     1.2.  He made just about everything dynamic (by using malloc),
  1001.     added a generic hashed list manager, re-wrote the modules database
  1002.     parsing in a compatible - but extended way, generalized directory
  1003.     hierarchy recursion for virtually all the commands (including
  1004.     commit!), generalized the loginfo file to be used for pre-commit
  1005.     checks and commit templates, wrote a new and flexible RCS parser,
  1006.     fixed an uncountable number of bugs, and helped in the design of
  1007.     future CVS features.  If there's anything gross left in CVS, it's
  1008.     probably my fault!
  1009.  
  1010.     * David G. Grubbs <dgg@odi.com> contributed the CVS "history" and
  1011.     "release" commands.  As well as the ever-so-useful "-n" option of
  1012.     CVS which tells CVS to show what it would do, without actually
  1013.     doing it.  He also contributed support for the .cvsignore file.
  1014.  
  1015.     * Paul Sander, HaL Computer Systems, Inc. <paul@hal.com> wrote and
  1016.     contributed the code in lib/sighandle.c.  I added support for
  1017.     POSIX, BSD, and non-POSIX/non-BSD systems.
  1018.  
  1019.     * Free Software Foundation contributed the "configure" script and
  1020.     other compatibility support in the "lib" directory, which will help
  1021.     make CVS much more portable.
  1022.  
  1023.     * Many others have contributed bug reports and enhancement requests.
  1024.     Some have even submitted actual code which I have not had time yet
  1025.     to integrate into CVS.  Maybe for the next release.
  1026.  
  1027.     * Thanks to you all!
  1028.  
  1029. Wed Feb  6 10:10:58 1991  Brian Berliner  (berliner at sun.com)
  1030.  
  1031.     * Changes from CVS 1.0 Patchlevel 1 to CVS 1.0 Patchlevel 2; also
  1032.     known as "Changes from CVS 1.1 to CVS 1.2".
  1033.  
  1034.     * Major new support with this release is the ability to use the
  1035.     recently-posted RCS 5.5 distribution with CVS 1.2.  See below for
  1036.     other assorted bug-fixes that have been thrown in.
  1037.  
  1038.     * ChangeLog (new): Added Emacs-style change-log file to CVS 1.2
  1039.     release.  Chronological description of changes between release.
  1040.  
  1041.     * README: Small fixes to installation instructions.  My email
  1042.     address is now "berliner@sun.com".
  1043.  
  1044.     * src/Makefile: Removed "rcstime.h".  Removed "depend" rule.
  1045.  
  1046.     * src/partime.c:  Updated to RCS 5.5 version with hooks for CVS.
  1047.     * src/maketime.c: Updated to RCS 5.5 version with hooks for CVS.
  1048.     * src/rcstime.h:  Removed from the CVS 1.2 distribution.
  1049.     Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
  1050.  
  1051.     * src/checkin.csh: Support for RCS 5.5 parsing.
  1052.     Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1053.  
  1054.     * src/collect_sets.c (Collect_Sets): Be quieter if "-f" option is
  1055.     specified.  When checking out files on-top-of other files that CVS
  1056.     doesn't know about, run a diff in the hopes that they are really
  1057.     the same file before aborting.
  1058.  
  1059.     * src/commit.c (branch_number): Fix for RCS 5.5 parsing.
  1060.     Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1061.  
  1062.     * src/commit.c (do_editor): Bug fix - fprintf missing argument
  1063.     which sometimes caused core dumps.
  1064.  
  1065.     * src/modules.c (process_module): Properly NULL-terminate
  1066.     update_dir[] in all cases.
  1067.  
  1068.     * src/no_difference.c (No_Difference): The wrong RCS revision was
  1069.     being registered in certain (strange) cases.
  1070.  
  1071.     * src/patch.c (get_rcsdate): New algorithm.  No need to call
  1072.     maketime() any longer.
  1073.     Thanks to Paul Eggert <eggert@twinsun.com> for this change.
  1074.  
  1075.     * src/patchlevel.h: Increased patch level to "2".
  1076.  
  1077.     * src/subr.c (isdir, islink): Changed to compare stat mode bits
  1078.     correctly.
  1079.  
  1080.     * src/tag.c (tag_file): Added support for following symbolic links
  1081.     that are in the master source repository when tagging.  Made tag
  1082.     somewhat quieter in certain cases.
  1083.  
  1084.     * src/update.c (update_process_lists): Unlink the user's file if it
  1085.     was put on the Wlist, meaning that the user's file is not modified
  1086.     and its RCS file has been removed by someone else.
  1087.  
  1088.     * src/update.c (update): Support for "cvs update dir" to correctly
  1089.     just update the argument directory "dir".
  1090.  
  1091.     * src/cvs.h: Fixes for RCS 5.5 parsing.
  1092.     * src/version_number.c (Version_Number): Fixes for parsing RCS 5.5
  1093.     and older RCS-format files.
  1094.     Thanks to Paul Eggert <eggert@twinsun.com> for these changes.
  1095.  
  1096.     * src/version_number.c (Version_Number): Bug fixes for "-f" option.
  1097.     Bug fixes for parsing with certain branch numbers.  RCS
  1098.     revision/symbol parsing is much more solid now.
  1099.  
  1100. Wed Feb 14 10:01:33 1990  Brian Berliner  (berliner at sun.com)
  1101.  
  1102.     * Changes from CVS 1.0 Patchlevel 0 to CVS 1.0 Patchlevel 1; also
  1103.     known as "Changes from CVS 1.0 to CVS 1.1".
  1104.  
  1105.     * src/patch.c (get_rcsdate): Portability fix.  Replaced call to
  1106.     timelocal() with call to maketime().
  1107.  
  1108. Mon Nov 19 23:15:11 1990  Brian Berliner  (berliner at prisma.com)
  1109.  
  1110.     * Sent CVS 1.0 release to comp.sources.unix moderator and FSF.
  1111.  
  1112.     * Special thanks to Dick Grune <dick@cs.vu.nl> for his work on the
  1113.     1986 version of CVS and making it available to the world.  Dick's
  1114.     version is available on uunet.uu.net in the
  1115.     comp.sources.unix/volume6/cvs directory.
  1116.