pkgsrc/devel/scmcvs/patches/patch-ae
adam 75d78ea164 Changes 1.12.13:
SECURITY FIXES

* CVS now uses version 1.2.3 of the ZLib compression libraries in order to
  avoid two recently announced security vulnerabilities in them.  Both may be
  used for denial of service attacks and one may reportedly allow execution of
  arbitrary code, though this is not confirmed.

NEW FEATURES

* Thanks to Conrad Pino <conrad@pino.com>, a hang in the Windows client, which
  had pretty much rendered the client useless, has been fixed.

* A minor problem preventing build of the Kerberos4 client has been fixed.

* The path to the config file may be set as an argument to the CVS server
  commands.

* Sections of directives specific to one or more repositories and not others
  may now be specified in the config file.

* %{sV} format strings are now available to the verifymsg trigger, similar to
  the %{stVv} available to loginfo.

* `cvs watch add' on an empty directory no longer clears watchers, and
  specifying a directory for `cvs watch add' now (correctly) sets default
  attributes.

* Missing CVSROOT/history files will now cause CVS to attempt to create one.
  To suppress history logging, set LogHistory equal to the empty string in
  CVSROOT/config.

* There are several new options available in CVSROOT/config.  These are
  TmpDir, HistoryLogPath, HistorySearchPath, MinCompressionLevel, &
  MaxCompressionLevel.  Please see the manual for more.

* CVS on Solaris 10 was refusing to parse command options.  This has been
  fixed.

* The Windows client now creates locks compatible with older versions of CVS by
  default.  This should only be relevant if your client is accessing a local
  repository concurrently with another, older client.  If you would like to
  disable compatibility mode (because it is slightly faster), edit the
  LOCK_COMPATIBILITY flag in windows-NT/config.h and recompile.

* Misc efficiency and portability improvements.

BUG FIXES

* Thanks to Serguei E. Leontiev <lse@CryptoPro.ru>, CVS with Kerberos 5 GSSAPI
  should automatically link on FreeBSD 5.x.

* Thanks to Rahul Bhargava <rahul@wandisco.com>, heavily loaded systems
  suffering from a disk crash or power failure will not lose data they claimed
  to have committed.

* CVS server now handles conflict markers in Entry requests as documented.

* CVS now remembers that binary file merge conflicts occurred until the
  timestamp of the updated binary file changes.

* CVS client now saves some bandwidth by not sending the contents of files
  with conflicts to the server when it isn't needed.

* CVS now does correct locking during import.

* A problem where the server could block indefinitely waiting for an EOF from
  the client when compression was enabled has been fixed.

* `cvs diff' no longer splits its arguments on spaces.

* Thanks to an old report and patch from Stewart Brodie <stewart@eh.org>, a
  potential crash in response to a corrupt RCS file has been fixed.

* CVS now locks the history and val-tags files before writing to them.
  Especially with large repositories, users should no longer see new warnings
  about corrupt history records when using the `cvs history' command.  Existing
  corrupt history records will still need to be removed manually.  val-tags
  corruption should have had less obvious effects, but removing the
  CVSROOT/val-tags file and allowing a 1.11.21 or later version of CVS to
  regenerate it may eliminate a few odd behaviors and possibly cause a slight
  speed up of read transactions in large repositories over time.

BUILD ISSUES

* The RPM spec file works again with the most modern versions of `rpm'.  It
  also finds the correct version of install-sh when building the CVS with
  GSSAPI.

DEVELOPER ISSUES

* We've standardized on Automake 1.9.6 to get some at new features that make
  our jobs easier.  See the HACKING file for more on using the autotools with
  CVS.
2013-10-14 06:51:02 +00:00

34 lines
1.1 KiB
Text

$NetBSD: patch-ae,v 1.4 2013/10/14 06:51:02 adam Exp $
--- src/rcs.c.orig 2005-09-28 15:25:59.000000000 +0000
+++ src/rcs.c
@@ -3641,7 +3641,7 @@ expand_keywords (RCSNode *rcs, RCSVers *
char *locker;
char *srch, *srch_next;
size_t srch_len;
- const struct rcs_keyword *keywords;
+ struct rcs_keyword *keywords;
if (!config /* For `cvs init', config may not be set. */
||expand == KFLAG_O || expand == KFLAG_B)
@@ -3654,6 +3654,11 @@ expand_keywords (RCSNode *rcs, RCSVers *
if (!config->keywords) config->keywords = new_keywords ();
keywords = config->keywords;
+ if (RCS_citag != NULL) {
+ keywords[KEYWORD_LOCALID].string = RCS_citag;
+ keywords[KEYWORD_LOCALID].len = strlen(RCS_citag);
+ }
+
/* If we are using -kkvl, dig out the locker information if any. */
locker = NULL;
if (expand == KFLAG_KVL)
@@ -4434,7 +4439,7 @@ RCS_checkout (RCSNode *rcs, const char *
if (info != NULL)
{
/* If the size of `devtype' changes, fix the sscanf call also */
- char devtype[16];
+ char devtype[16+1];
if (sscanf (info->data, "%15s %lu",
devtype, &devnum_long) < 2)