diff options
Diffstat (limited to 'devel/cvs-devel')
37 files changed, 1639 insertions, 4201 deletions
diff --git a/devel/cvs-devel/Makefile b/devel/cvs-devel/Makefile index 3fea9c752c9a..3ea01445dcbb 100644 --- a/devel/cvs-devel/Makefile +++ b/devel/cvs-devel/Makefile @@ -1,30 +1,25 @@ -# New ports collection makefile for: cvs+ipv6 -# Date created: Tue Jul 23 11:24:24 JST 2002 -# Whom: sumikawa +# New ports collection makefile for: cvs-devel +# Date created: Wed, 14 Nov 2007 00:21:45 +0530 +# Whom: Balwinder S Dheeman <bdheeman@gmail.com> # # $FreeBSD$ # PORTNAME= cvs -PORTVERSION= 1.11.17 -PORTREVISION= 1 +PORTVERSION= 1.12.13 +PORTREVISION= 8 CATEGORIES= devel ipv6 MASTER_SITES= ${MASTER_SITE_GNU} -MASTER_SITE_SUBDIR= non-gnu/${PORTNAME}/source/stable/${PORTVERSION} -PKGNAMESUFFIX= +ipv6 +MASTER_SITE_SUBDIR= non-gnu/${PORTNAME}/source/feature/${PORTVERSION} +PKGNAMESUFFIX= -devel -PATCH_SITES= ftp://ftp.kame.net/pub/kame/misc/ -PATCHFILES= ${DISTNAME}-v6-20040610.diff.gz -PATCH_DIST_STRIP= -p1 - -MAINTAINER= sumikawa@FreeBSD.org +MAINTAINER= bdheeman@gmail.com COMMENT= IPv6 enabled cvs. You can use IPv6 connection when using pserver -CONFLICTS= cvsnt-[12]* +CONFLICTS= cvsnt-[12]* cvs+ipv6-[12]* GNU_CONFIGURE= yes USE_BZIP2= yes -#USE_GMAKE= yes CONFIGURE_ARGS= --enable-ipv6 --without-gssapi \ --with-editor="vi" \ --with-tmpdir="/tmp" @@ -35,16 +30,17 @@ MAN8= cvsbug.8 INFO= cvs cvsclient CVS_SITE?= :pserver:anoncvs@anoncvs.jp.FreeBSD.org:/home/ncvs -CVS_VER?= v${PORTVERSION:S/./_/g} +CVS_VER?= v${PORTVERSION:S//_/g} post-patch: - ${REINPLACE_CMD} 's/${PORTVERSION:S/./\./g}/&+IPv6/g' ${WRKSRC}/configure + ${REINPLACE_CMD} 's/${PORTVERSION:S/./\./g}/&-devel/g' \ + ${WRKSRC}/configure @${CP} ${FILESDIR}/missing ${WRKSRC} -replace: +post-install: .for f in cvs cvsbug - ${MV} /usr/bin/${f} /usr/bin/${f}.orig - ${CP} -p ${PREFIX}/bin/${f} /usr/bin/ + -${MV} ${PREFIX:S/\/local//}/bin/${f} ${PREFIX:S/\/local//}/bin/${f}.orig + -${CP} -p ${PREFIX}/bin/${f} ${PREFIX:S/\/local//}/bin .endfor generate-patch: diff --git a/devel/cvs-devel/distinfo b/devel/cvs-devel/distinfo index a26948f129f8..9ed329875137 100644 --- a/devel/cvs-devel/distinfo +++ b/devel/cvs-devel/distinfo @@ -1,6 +1,3 @@ -MD5 (cvs-1.11.17.tar.bz2) = 17cd48888d5571d215a44a7e8d46759c -SHA256 (cvs-1.11.17.tar.bz2) = a5486a3224140e7bd94ba77c5f690da8142fa9ee241e1a75612d6228c459e97e -SIZE (cvs-1.11.17.tar.bz2) = 2343366 -MD5 (cvs-1.11.17-v6-20040610.diff.gz) = 29b341c7b619c7c86751a7ee2e8eca02 -SHA256 (cvs-1.11.17-v6-20040610.diff.gz) = 16aa61329485fbd94c3a2c117e49ee99612f5f0281e9a85c13c22349e39eed11 -SIZE (cvs-1.11.17-v6-20040610.diff.gz) = 12807 +MD5 (cvs-1.12.13.tar.bz2) = 956ab476ce276c2d19d583e227dbdbea +SHA256 (cvs-1.12.13.tar.bz2) = 78853613b9a6873a30e1cc2417f738c330e75f887afdaf7b3d0800cb19ca515e +SIZE (cvs-1.12.13.tar.bz2) = 3911104 diff --git a/devel/cvs-devel/files/patch-64bit_crashfix b/devel/cvs-devel/files/patch-64bit_crashfix new file mode 100644 index 000000000000..15ec55410c57 --- /dev/null +++ b/devel/cvs-devel/files/patch-64bit_crashfix @@ -0,0 +1,15 @@ +# Fix a 64-bit crash in the entries_time() function and another bug in +# the diff code. Thanks to Gabor Gombas for the patch. Closes: +# #329127. +diff -Nur diff/util.c diff/util.c +--- diff/util.c 2003-02-03 03:52:38.000000000 +0800 ++++ diff/util.c 2006-02-26 21:32:22.000000000 +0800 +@@ -235,7 +235,7 @@ + close (pipes[0]); + } + +- execl (PR_PROGRAM, PR_PROGRAM, "-f", "-h", name, 0); ++ execl (PR_PROGRAM, PR_PROGRAM, "-f", "-h", name, NULL); + pfatal_with_name (PR_PROGRAM); + } + else diff --git a/devel/cvs-devel/files/patch-DSA_external_passwd_file b/devel/cvs-devel/files/patch-DSA_external_passwd_file new file mode 100644 index 000000000000..f7d21bfb65ef --- /dev/null +++ b/devel/cvs-devel/files/patch-DSA_external_passwd_file @@ -0,0 +1,388 @@ +# Add support for overriding lookups in CVSROOT/passwd +# Specify --password-file <file> on the pserver command line to use it +# Initial patch from the Debian DSA team, adapted by Steve McIntyre. +# See README.Debian for more details. +diff -Nur src/cvs.h src/cvs.h +--- src/cvs.h 2005-10-02 16:17:20.000000000 +0100 ++++ src/cvs.h 2006-08-19 01:20:33.000000000 +0100 +@@ -371,6 +371,7 @@ + extern int use_editor; + extern int cvswrite; + extern mode_t cvsumask; ++extern char *PasswordFileName; + + /* Temp dir abstraction. */ + /* From main.c. */ +diff -Nur src/main.c src/main.c +--- src/main.c 2006-08-17 00:25:16.000000000 +0100 ++++ src/main.c 2006-08-19 01:20:03.000000000 +0100 +@@ -43,8 +43,7 @@ + int noexec = 0; + int readonlyfs = 0; + int logoff = 0; +- +- ++char *PasswordFileName = NULL; + + /*** + *** +@@ -519,6 +518,7 @@ + {"help-commands", 0, NULL, 1}, + {"help-synonyms", 0, NULL, 2}, + {"help-options", 0, NULL, 4}, ++ {"password-file", required_argument, NULL, 5}, + #ifdef SERVER_SUPPORT + {"allow-root", required_argument, NULL, 3}, + #endif /* SERVER_SUPPORT */ +@@ -646,6 +646,10 @@ + root_allow_add (optarg, gConfigPath); + break; + #endif /* SERVER_SUPPORT */ ++ case 5: ++ /* --password-file */ ++ PasswordFileName = xstrdup(optarg); ++ break; + case 'Q': + really_quiet = 1; + /* FALL THROUGH */ +diff -Nur src/Makefile.in src/Makefile.in +--- src/Makefile.in 2005-10-03 14:37:18.000000000 +0100 ++++ src/Makefile.in 2006-08-17 00:28:35.000000000 +0100 +@@ -146,7 +146,7 @@ + ls.$(OBJEXT) main.$(OBJEXT) mkmodules.$(OBJEXT) \ + modules.$(OBJEXT) ms-buffer.$(OBJEXT) myndbm.$(OBJEXT) \ + no_diff.$(OBJEXT) parseinfo.$(OBJEXT) patch.$(OBJEXT) \ +- rcs.$(OBJEXT) rcscmds.$(OBJEXT) recurse.$(OBJEXT) \ ++ rcs.$(OBJEXT) rcscmds.$(OBJEXT) readpw.$(OBJEXT) recurse.$(OBJEXT) \ + release.$(OBJEXT) remove.$(OBJEXT) repos.$(OBJEXT) \ + root.$(OBJEXT) rsh-client.$(OBJEXT) run.$(OBJEXT) \ + scramble.$(OBJEXT) server.$(OBJEXT) stack.$(OBJEXT) \ +@@ -349,6 +349,7 @@ + patch.c \ + rcs.c \ + rcscmds.c \ ++ readpw.c \ + recurse.c \ + release.c \ + remove.c \ +@@ -543,6 +544,7 @@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/patch.Po@am__quote@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rcs.Po@am__quote@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rcscmds.Po@am__quote@ ++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/readpw.Po@am__quote@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/recurse.Po@am__quote@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/release.Po@am__quote@ + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/remove.Po@am__quote@ +diff -Nur src/parseinfo.h src/parseinfo.h +--- src/parseinfo.h 2006-08-17 00:25:16.000000000 +0100 ++++ src/parseinfo.h 2006-08-17 00:58:25.000000000 +0100 +@@ -21,6 +21,7 @@ + char *HistoryLogPath; + char *HistorySearchPath; + char *TmpDir; ++ char *PasswordFileName; + + /* Should the logmsg be re-read during the do_verify phase? + * RereadLogAfterVerify=no|stat|yes +diff -Nur src/readpw.c src/readpw.c +--- src/readpw.c 1970-01-01 01:00:00.000000000 +0100 ++++ src/readpw.c 2006-08-19 01:45:26.000000000 +0100 +@@ -0,0 +1,158 @@ ++/* ++ readpw.c - read the CVS password from an external file ++ Copyright (c) 2006 Martin Schulze <joey@infodrom.org> ++ ++ This program is free software; you can redistribute it and/or modify ++ it under the terms of the GNU General Public License as published by ++ the Free Software Foundation; either version 2 of the License, or ++ (at your option) any later version. ++ ++ This program is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ GNU General Public License for more details. ++ ++ You should have received a copy of the GNU General Public License ++ along with this program; if not, write to the Free Software ++ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++*/ ++ ++#include <string.h> ++#include <stdio.h> ++#include <errno.h> ++#include <syslog.h> ++ ++#define PWFILE "/tmp/work/cvs/cvs.passwd" ++ ++/* ++ * Source: control_nextline() in dtaus.c from dtaus ++ */ ++size_t readline (FILE *f, char **buf, unsigned int len) ++{ ++ char line[100]; ++ char tmp[100]; ++ char *cp; ++ int i; ++ ++ memset (line, 0, sizeof(line)); ++ memset (*buf, 0, len); ++ ++ cp = line; ++ ++ while (!strlen(line) && (cp = fgets(line, 100, f))) { ++ if (strlen(line)) { ++ if (line[0] != '#') { ++ if (line[strlen(line)-1] != '\n') { ++ strcpy(tmp, line); ++ while (tmp[strlen(tmp)-1] != '\n' && (cp = fgets(tmp, 100, f))); ++ } else ++ line[strlen(line)-1] = '\0'; ++ if (line[strlen(line)-1] == '\r') ++ line[strlen(line)-1] = '\0'; ++ for (i=strlen(line);(line[i-1] == ' '||line[i-1] == '\t')&&i>0; i--) ++ line[i-1] = '\0'; ++ } else ++ line[0] = '\0'; ++ } ++ } ++ for (cp=line; *cp==' '; cp++); ++ ++ if (strlen(cp)) { ++ memcpy(*buf, cp, strlen(cp) >= len ? len-1 : strlen(cp)); ++ return (strlen (cp)); ++ } else ++ return 0; ++} ++ ++#define MAXLINE 100 ++#define PWLEN 20 ++ ++char *getpwline (const char *fname, const char *repository, const char *logname) ++{ ++ FILE *f; ++ char buf[MAXLINE], *bp = buf; ++ static char line[MAXLINE]; ++ int inrepo = 0; ++ char *cp; ++ ++ memset (line, 0, sizeof (line)); ++ ++ if ((f = fopen (fname, "r")) == NULL) { ++ perror ("fopen"); ++ return line; ++ } ++ ++ while (readline (f, &bp, 50)) { ++ if (buf[0] == '/') { ++ syslog(LOG_ERR, "Looking for repo %s in %s\n", repository, buf); ++ if (!inrepo && !strcmp (buf, repository)) ++ { ++ syslog(LOG_ERR, "matched repository %s\n", repository); ++ inrepo = 1; ++ } ++ else if (inrepo) ++ inrepo = 0; ++ } else { ++ if (inrepo) { ++ if ((cp = strchr (buf, ':')) != NULL) { ++ if ( (cp - buf) == strlen (logname) ++ && !strncmp (buf, logname, strlen (logname))) { ++ memcpy (line, buf, strlen(buf) >= MAXLINE ? MAXLINE-1 : strlen(buf)); ++ } ++ } ++ } ++ } ++ } ++ ++ if (ferror (f)) ++ perror ("ferror"); ++ if (fclose (f) < 0) ++ perror ("fclose"); ++ ++ return line; ++} ++ ++/* ++***************************************************************** ++ */ ++#ifdef TEST_READPW ++ ++void getpasswd (const char *fname, const char *repository, const char *logname, char **pw, char **user) ++{ ++ char *line; ++ char *cp, *xp; ++ ++ memset (*pw, 0, PWLEN); ++ memset (*user, 0, PWLEN); ++ ++ line = getpwline(fname, repository, logname); ++ ++ if (line[0] == '\0') ++ return; ++ ++ cp = strchr (line, ':'); ++ cp++; ++ ++ if ((xp = strchr (cp, ':')) != NULL) { ++ memcpy (*pw, cp, xp-cp >= PWLEN ? PWLEN-1 : xp-cp); ++ ++ xp++; ++ ++ if (strlen (xp)) ++ memcpy (*user, xp, strlen(xp) >= PWLEN ? PWLEN-1 : strlen(xp)); ++ } ++} ++ ++int main () ++{ ++ char pw[PWLEN], *ppw = pw; ++ char cvsuser[PWLEN], *pcu = cvsuser; ++ ++ getpasswd (PWFILE, "/cvs/debian-doc", "jseidel", &ppw, &pcu); ++ ++ printf ("%s<:>%s\n", pw, cvsuser); ++ printf ("XXXXXXXXXXXXX\n"); ++ ++ return 0; ++} ++#endif /*TEST_READPW */ +diff -Nur src/server.c src/server.c +--- src/server.c 2006-08-17 00:25:16.000000000 +0100 ++++ src/server.c 2006-08-20 00:31:22.000000000 +0100 +@@ -22,6 +22,8 @@ + + int server_active = 0; + ++char *getpwline (const char *fname, const char *repository, const char *logname); ++ + #if defined (SERVER_SUPPORT) || defined (CLIENT_SUPPORT) + + # include "log-buffer.h" +@@ -6689,51 +6691,71 @@ + { + int retval = 0; + FILE *fp; +- char *filename; ++ char *filename = NULL; ++ char *cp; + char *linebuf = NULL; + size_t linebuf_len; + int found_it = 0; + int namelen; + +- /* We don't use current_parsed_root->directory because it hasn't been +- * set yet -- our `repository' argument came from the authentication +- * protocol, not the regular CVS protocol. +- */ +- +- filename = xmalloc (strlen (repository) +- + 1 +- + strlen (CVSROOTADM) +- + 1 +- + strlen (CVSROOTADM_PASSWD) +- + 1); ++ if (!PasswordFileName) ++ { ++ /* We don't use current_parsed_root->directory because it hasn't been ++ * set yet -- our `repository' argument came from the authentication ++ * protocol, not the regular CVS protocol. ++ */ ++ ++ filename = xmalloc (strlen (repository) ++ + 1 ++ + strlen (CVSROOTADM) ++ + 1 ++ + strlen (CVSROOTADM_PASSWD) ++ + 1); + +- (void) sprintf (filename, "%s/%s/%s", repository, +- CVSROOTADM, CVSROOTADM_PASSWD); ++ (void) sprintf (filename, "%s/%s/%s", repository, ++ CVSROOTADM, CVSROOTADM_PASSWD); + +- fp = CVS_FOPEN (filename, "r"); +- if (fp == NULL) +- { +- if (!existence_error (errno)) +- error (0, errno, "cannot open %s", filename); +- free (filename); +- return 0; +- } ++ fp = CVS_FOPEN (filename, "r"); ++ if (fp == NULL) ++ { ++ if (!existence_error (errno)) ++ error (0, errno, "cannot open %s", filename); ++ free (filename); ++ return 0; ++ } + +- /* Look for a relevant line -- one with this user's name. */ +- namelen = strlen (username); +- while (getline (&linebuf, &linebuf_len, fp) >= 0) +- { +- if ((strncmp (linebuf, username, namelen) == 0) +- && (linebuf[namelen] == ':')) +- { +- found_it = 1; +- break; +- } ++ /* Look for a relevant line -- one with this user's name. */ ++ namelen = strlen (username); ++ while (getline (&linebuf, &linebuf_len, fp) >= 0) ++ { ++ if ((strncmp (linebuf, username, namelen) == 0) ++ && (linebuf[namelen] == ':')) ++ { ++ found_it = 1; ++ break; ++ } ++ } ++ if (ferror (fp)) ++ error (0, errno, "cannot read %s", filename); ++ if (fclose (fp) < 0) ++ error (0, errno, "cannot close %s", filename); ++ } ++ else /* DSA_VERSION */ ++ { ++ namelen = strlen (username); ++ ++ cp = getpwline (PasswordFileName, repository, username); ++ /* syslog (LOG_NOTICE, "cp=%s", cp); */ ++ if (strlen (cp)) { ++ linebuf = xmalloc (strlen (cp) + 1); ++ memcpy (linebuf, cp, strlen(cp)+1); ++ /* syslog (LOG_NOTICE, "line=%s", linebuf); */ ++ found_it = 1; ++ } else ++ found_it = 0; ++ ++ /* syslog (LOG_NOTICE, "username=%s, password=%s, repository=%s", username, password, repository); */ + } +- if (ferror (fp)) +- error (0, errno, "cannot read %s", filename); +- if (fclose (fp) < 0) +- error (0, errno, "cannot close %s", filename); + + /* If found_it, then linebuf contains the information we need. */ + if (found_it) +@@ -6823,6 +6845,7 @@ + retval = 0; + } + ++ if (filename) + free (filename); + if (linebuf) + free (linebuf); +@@ -7043,7 +7066,10 @@ + letting you in if it won't say why, and I am not convinced + that the potential information disclosure to an attacker + outweighs this. */ +- printf ("error 0 no such user %s in CVSROOT/passwd\n", username); ++ if (PasswordFileName) ++ printf ("error 0 no such user %s in %s\n", username, PasswordFileName); ++ else ++ printf ("error 0 no such user %s in CVSROOT/passwd\n", username); + + exit (EXIT_FAILURE); + } diff --git a/devel/cvs-devel/files/patch-PAM_support b/devel/cvs-devel/files/patch-PAM_support new file mode 100644 index 000000000000..4b37c20fc7b0 --- /dev/null +++ b/devel/cvs-devel/files/patch-PAM_support @@ -0,0 +1,144 @@ +# +# Add in extra PAM options compared to upstream's own PAM code: +# * Add an extra option PamAuth to control use of PAM separately from +# SystemAuth +# * Add support for DefaultPamUser - try that if the specified +# user does not exist +# +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur doc/cvs.texinfo doc/cvs.texinfo +--- doc/cvs.texinfo 2005-09-23 03:02:53.000000000 +0100 ++++ doc/cvs.texinfo 2006-05-19 23:50:10.000000000 +0100 +@@ -2662,8 +2662,18 @@ + system has PAM (Pluggable Authentication Modules) + and your @sc{cvs} server executable was configured to + use it at compile time (using @code{./configure --enable-pam} - see the +-INSTALL file for more). In this case, PAM will be consulted instead. +-This means that @sc{cvs} can be configured to use any password ++INSTALL file for more). In this case, PAM may be ++consulted first (or instead). The ++"fallback" behaviour can be controlled using the two ++variables @code{PamAuth} and @code{SystemAuth}. On a ++Debian system, @code{PamAuth} defaults to @code{yes} ++and @code{SystemAuth} to @code{no} - after all, PAM can ++supports passwd file lookups itself. Changing these is ++possible by setting @code{PamAuth=no} and ++@code{SystemAuth=yes} in the @sc{cvs} @file{config} ++file, @pxref{config}). ++ ++Use of PAM means that @sc{cvs} can be configured to use any password + authentication source PAM can be configured to use (possibilities + include a simple UNIX password, NIS, LDAP, and others) in its + global configuration file (usually @file{/etc/pam.conf} +@@ -2691,7 +2701,7 @@ + cvs session required pam_unix.so + @end example + +-The the equivalent @file{/etc/pam.d/cvs} would contain ++The equivalent @file{/etc/pam.d/cvs} would contain + + @example + auth required pam_unix.so +@@ -2715,6 +2725,13 @@ + feature should not be used if you may not have control of the name + @sc{cvs} will be invoked as. + ++If you wish to use PAM for authentication, and details ++of your users are not available using getpwnam(), you ++may set a default name for the account on the server ++that will be used after authentication. To do this, ++either set @code{DefaultPamUser=user} in the @sc{cvs} ++@file{config} file, @pxref{config}. ++ + Be aware, also, that falling back to system + authentication might be a security risk: @sc{cvs} + operations would then be authenticated with that user's +diff -Nur src/parseinfo.c src/parseinfo.c +--- src/parseinfo.c 2005-09-06 05:40:37.000000000 +0100 ++++ src/parseinfo.c 2006-05-19 22:46:00.000000000 +0100 +@@ -303,8 +303,12 @@ + */ + #endif /* PROXY_SUPPORT */ + #ifdef AUTH_SERVER_SUPPORT +- new->system_auth = true; ++ new->system_auth = false; + #endif /* AUTH_SERVER_SUPPORT */ ++#ifdef HAVE_PAM ++ new->PamAuth = true; ++ new->DefaultPamUser = NULL; ++#endif + + return new; + } +@@ -696,6 +700,13 @@ + readSizeT (infopath, "MaxCompressionLevel", p, + &retval->MaxCompressionLevel); + #endif /* SERVER_SUPPORT */ ++#ifdef HAVE_PAM ++ else if (!strcmp (line, "DefaultPamUser")) ++ retval->DefaultPamUser = xstrdup(p); ++ else if (!strcmp (line, "PamAuth")) ++ readBool (infopath, "PamAuth", p, ++ &retval->PamAuth); ++#endif + else + /* We may be dealing with a keyword which was added in a + subsequent version of CVS. In that case it is a good idea +diff -Nur src/parseinfo.h src/parseinfo.h +--- src/parseinfo.h 2005-09-05 04:03:38.000000000 +0100 ++++ src/parseinfo.h 2006-05-19 22:40:31.000000000 +0100 +@@ -59,6 +59,10 @@ + #ifdef PRESERVE_PERMISSIONS_SUPPORT + bool preserve_perms; + #endif /* PRESERVE_PERMISSIONS_SUPPORT */ ++#ifdef HAVE_PAM ++ char *DefaultPamUser; ++ bool PamAuth; ++#endif + }; + + bool parse_error (const char *, unsigned int); +diff -Nur src/server.c src/server.c +--- src/server.c 2005-09-28 16:25:59.000000000 +0100 ++++ src/server.c 2006-05-20 00:45:14.000000000 +0100 +@@ -6919,6 +6919,15 @@ + { + pam_stage = "get pam user"; + retval = pam_get_item (pamh, PAM_USER, (const void **)username); ++ if ((retval != PAM_SUCCESS) && (NULL != config->DefaultPamUser)) ++ { ++ /* An issue with using pam is that the host may well not have ++ a local user entry to match the authenticated user. If this ++ has failed, optionally fall back to a specified local ++ username */ ++ *username = xstrdup(config->DefaultPamUser); ++ retval = PAM_SUCCESS; ++ } + } + + if (retval != PAM_SUCCESS) +@@ -7022,7 +7031,11 @@ + + assert (rc == 0); + ++#ifdef HAVE_PAM ++ if (!config->system_auth && !config->PamAuth) ++#else + if (!config->system_auth) ++#endif + { + /* Note that the message _does_ distinguish between the case in + which we check for a system password and the case in which +@@ -7037,9 +7050,10 @@ + + /* No cvs password found, so try /etc/passwd. */ + #ifdef HAVE_PAM +- if (check_pam_password (&username, password)) ++ if ( (config->PamAuth && check_pam_password (&username, password)) || ++ (config->system_auth && check_system_password (username, password))) + #else /* !HAVE_PAM */ +- if (check_system_password (username, password)) ++ if (config->system_auth && check_system_password (username, password)) + #endif /* HAVE_PAM */ + host_user = xstrdup (username); + else diff --git a/devel/cvs-devel/files/patch-PATH_MAX_check b/devel/cvs-devel/files/patch-PATH_MAX_check new file mode 100644 index 000000000000..0af532bd4bc6 --- /dev/null +++ b/devel/cvs-devel/files/patch-PATH_MAX_check @@ -0,0 +1,27 @@ +# Fix FTBFS in hurd-i386 regarding bad check of PATH_MAX. +# Closes: #378966 +# Thanks to Cyril Brulebois <cyril.brulebois@enst-bretagne.fr> +diff -Nur lib/chdir-long.c lib/chdir-long.c +--- lib/chdir-long.c 2005-09-19 21:12:18.000000000 +0000 ++++ lib/chdir-long.c 2006-07-20 02:47:32.000000000 +0000 +@@ -39,9 +39,7 @@ + # define O_DIRECTORY 0 + #endif + +-#ifndef PATH_MAX +-# error "compile this file only if your system defines PATH_MAX" +-#endif ++#ifdef PATH_MAX + + struct cd_buf + { +@@ -269,6 +267,8 @@ + } + #endif + ++#endif /* PATH_MAX */ ++ + /* + Local Variables: + compile-command: "gcc -DTEST_CHDIR=1 -DHAVE_CONFIG_H -I.. -g -O -W -Wall chdir-long.c libcoreutils.a" + diff --git a/devel/cvs-devel/files/patch-check_method_crash b/devel/cvs-devel/files/patch-check_method_crash new file mode 100644 index 000000000000..a7524301928f --- /dev/null +++ b/devel/cvs-devel/files/patch-check_method_crash @@ -0,0 +1,21 @@ +# +# Do a basic sanity check on the method in the CVSROOT - don't crash +# if one is not specified! Bug#274020 +# +# Patch from Steve McIntyre <steve@einval.com> +diff -Nur src/root.c src/root.c +--- src/root.c 2005-09-25 08:38:29.000000000 +0800 ++++ src/root.c 2006-02-26 17:48:32.000000000 +0800 +@@ -535,6 +535,12 @@ + method = ""; + #endif /* defined (CLIENT_SUPPORT) || defined (SERVER_SUPPORT) */ + ++ if (NULL == method) ++ { ++ error (0, 0, "Missing method in CVSROOT."); ++ goto error_exit; ++ } ++ + /* Now we have an access method -- see if it's valid. */ + + if (!strcasecmp (method, "local")) diff --git a/devel/cvs-devel/files/patch-contrib-Makefile.in b/devel/cvs-devel/files/patch-contrib-Makefile.in deleted file mode 100644 index be06c83dfcdf..000000000000 --- a/devel/cvs-devel/files/patch-contrib-Makefile.in +++ /dev/null @@ -1,10 +0,0 @@ ---- contrib/Makefile.in.orig Fri Apr 19 00:55:53 2002 -+++ contrib/Makefile.in Sun Aug 25 06:03:37 2002 -@@ -126,6 +126,7 @@ - - - contrib_DATA = \ -+ ${contrib_MANS} \ - README \ - intro.doc - diff --git a/devel/cvs-devel/files/patch-copyright b/devel/cvs-devel/files/patch-copyright new file mode 100644 index 000000000000..81747b2516d1 --- /dev/null +++ b/devel/cvs-devel/files/patch-copyright @@ -0,0 +1,44 @@ +# Change references from GNU Public License to GNU General Public +# License, where that is meant (closes: #102142) +# +# Patch by Tollef Fog Heen <tfheen@debian.org> +diff -Nur DEVEL-CVS DEVEL-CVS +--- DEVEL-CVS 2005-09-01 20:46:54.000000000 +0800 ++++ DEVEL-CVS 2006-02-26 22:40:36.000000000 +0800 +@@ -7,7 +7,8 @@ + Policies regarding the CVS source repository: + + By checking items into the repository, developers agree to permit +-distribution of such items under the terms of the GNU Public License. ++distribution of such items under the terms of the GNU General Public ++License. + + ---------------------------------------------------------------------- + Procedure for dealing with people who want to be developers: +diff -Nur doc/cvsclient.texi doc/cvsclient.texi +--- doc/cvsclient.texi 2006-02-26 22:40:35.000000000 +0800 ++++ doc/cvsclient.texi 2006-02-26 22:40:37.000000000 +0800 +@@ -54,7 +54,7 @@ + user documentation, @file{cvs.texinfo}, for that information. The + protocol is non-proprietary (anyone who wants to is encouraged to + implement it) and an implementation, known as CVS, is available under +-the GNU Public License. The CVS distribution, containing this ++the GNU General Public License. The CVS distribution, containing this + implementation, @file{cvs.texinfo}, and a copy (possibly more or less up + to date than what you are reading now) of this document, + @file{cvsclient.texi}, can be found at the usual GNU FTP sites, with a +diff -Nur HACKING HACKING +--- HACKING 2005-09-25 08:36:08.000000000 +0800 ++++ HACKING 2006-02-26 22:42:15.000000000 +0800 +@@ -403,8 +403,9 @@ + for each issue. Use context diffs or unidiffs for patches. + + Include words like "I grant permission to distribute this patch under +-the terms of the GNU Public License" with your patch. By sending a +-patch to bug-cvs@nongnu.org, you implicitly grant this permission. ++the terms of the GNU General Public License" with your patch. By ++sending a patch to bug-cvs@nongnu.org, you implicitly grant this ++permission. + + Submitting a patch to bug-cvs is the way to reach the people who have + signed up to receive such submissions (including CVS developers), but diff --git a/devel/cvs-devel/files/patch-cvs-repouid-0.1 b/devel/cvs-devel/files/patch-cvs-repouid-0.1 new file mode 100644 index 000000000000..d31e0467482d --- /dev/null +++ b/devel/cvs-devel/files/patch-cvs-repouid-0.1 @@ -0,0 +1,111 @@ +# +# cvs-repouid patch for controlling pserver access. See +# README.Debian for details. +# +# Original patch by Wichert Akkerman <wakkerma@debian.org>, fixes by +# Steve McIntyre <steve@einval.com> with help from Alberto Garcia +# <agarcia@igalia.com> +diff -Nur src/cvs.h src/cvs.h +--- src/cvs.h 2005-10-02 23:17:20.000000000 +0800 ++++ src/cvs.h 2006-02-26 22:08:16.000000000 +0800 +@@ -145,6 +145,13 @@ + #define CVSADM_TEMPLATE "CVS/Template" + #endif /* USE_VMS_FILENAMES */ + ++/* Global configuration file mapping repositories to uids. This can be ++ used instead of getting the unix user. This is prevents a security ++ problem where anyone with commit access can basically become any ++ user on the machine. Combined with the insecure pserver that is a ++ problem waiting to happen. */ ++#define CVS_REPOUIDFILE "/etc/cvs-repouids" ++ + /* This is the special directory which we use to store various extra + per-directory information in the repository. It must be the same as + CVSADM to avoid creating a new reserved directory name which users cannot +diff -Nur src/server.c src/server.c +--- src/server.c 2005-09-28 23:25:59.000000000 +0800 ++++ src/server.c 2006-02-26 22:08:16.000000000 +0800 +@@ -6570,6 +6570,12 @@ + exit (EXIT_FAILURE); + } + ++ if (pw->pw_uid == 0) ++ { ++ printf("error 0: root not allowed\n"); ++ exit (EXIT_FAILURE); ++ } ++ + #if HAVE_INITGROUPS + if (initgroups (pw->pw_name, pw->pw_gid) < 0 + # ifdef EPERM +@@ -6667,6 +6673,51 @@ + } + #endif + ++static char* ++global_repo_uid(const char* repository) ++{ ++ FILE *fp; ++ char *linebuf = NULL; ++ size_t linebuf_len; ++ int found_it = 0; ++ size_t repolen = strlen (repository); ++ char *user; ++ ++ fp = fopen (CVS_REPOUIDFILE, "r"); ++ if (fp == NULL) ++ { ++ if (!existence_error (errno)) ++ error (0, errno, "cannot open %s", CVS_REPOUIDFILE); ++ return NULL; ++ } ++ ++ while (getline (&linebuf, &linebuf_len, fp) >= 0) ++ { ++ if ((strncmp (linebuf, repository, repolen) == 0) ++ && (linebuf[repolen] == ':')) ++ { ++ found_it = 1; ++ break; ++ } ++ } ++ ++ if (ferror (fp)) ++ error (0, errno, "cannot read %s", CVS_REPOUIDFILE); ++ if (fclose (fp) < 0) ++ error (0, errno, "cannot close %s", CVS_REPOUIDFILE); ++ ++ if (!found_it) { ++ free (linebuf); ++ return NULL; ++ } ++ ++ strtok (linebuf + repolen, "\n"); ++ user = xstrdup (linebuf + repolen + 1); ++ free (linebuf); ++ ++ return user; ++} ++ + #ifdef AUTH_SERVER_SUPPORT + + extern char *crypt (const char *, const char *); +@@ -6738,7 +6789,7 @@ + /* If found_it, then linebuf contains the information we need. */ + if (found_it) + { +- char *found_password, *host_user_tmp; ++ char *found_password, *host_user_tmp, *user_override; + char *non_cvsuser_portion; + + /* We need to make sure lines such as +@@ -6805,6 +6856,9 @@ + /* Give host_user_ptr permanent storage. */ + *host_user_ptr = xstrdup (host_user_tmp); + retval = 1; ++ user_override = global_repo_uid (repository); ++ if (user_override) ++ *host_user_ptr = user_override; + } + else + { diff --git a/devel/cvs-devel/files/patch-cvs.info.typo b/devel/cvs-devel/files/patch-cvs.info.typo new file mode 100644 index 000000000000..82103e91603d --- /dev/null +++ b/devel/cvs-devel/files/patch-cvs.info.typo @@ -0,0 +1,58 @@ +# Minor documentation changes +# +# Patch by Steve McIntyre <steve@einval.com> and Britton Leo Kerin <fsblk@aurora.uaf.edu> +diff -Nur doc/cvsclient.texi doc/cvsclient.texi +--- doc/cvsclient.texi 2005-07-20 18:39:59.000000000 +0800 ++++ doc/cvsclient.texi 2006-02-26 22:39:20.000000000 +0800 +@@ -3,9 +3,10 @@ + @setfilename cvsclient.info + @include version-client.texi + +-@dircategory Programming ++@dircategory Development + @direntry +-* cvsclient: (cvsclient). The CVS client/server protocol. ++* CVS client/server: (cvsclient). Describes the client/server protocol ++ used by CVS. + @end direntry + + @node Top +diff -Nur doc/cvs.texinfo doc/cvs.texinfo +--- doc/cvs.texinfo 2006-02-26 22:39:19.000000000 +0800 ++++ doc/cvs.texinfo 2006-02-26 22:39:20.000000000 +0800 +@@ -97,7 +97,7 @@ + @end macro + @end ifhtml + +-@dircategory GNU Packages ++@dircategory Development + @direntry + * CVS: (cvs). Concurrent Versions System + @end direntry +@@ -2385,13 +2385,16 @@ + There are two access methods that you use in @code{CVSROOT} + for rsh. @code{:server:} specifies an internal rsh + client, which is supported only by some @sc{cvs} ports. ++This is not supported on most Unix-style systems, ++including Debian. + @code{:ext:} specifies an external rsh program. By + default this is @code{rsh} (unless otherwise specified + by the @file{--with-rsh} flag to configure) but you may set the + @code{CVS_RSH} environment variable to invoke another + program which can access the remote server (for + example, @code{remsh} on HP-UX 9 because @code{rsh} is +-something different). It must be a program which can ++something different, or @code{ssh} to allow the use of ++secure and/or compressed connections). It must be a program which can + transmit data to and from the server without modifying + it; for example the Windows NT @code{rsh} is not + suitable since it by default translates between CRLF +@@ -12711,7 +12714,7 @@ + @item @var{mname} [ options ] @var{dir} [ @var{files}@dots{} ] + In the simplest case, this form of module definition + reduces to @samp{@var{mname} @var{dir}}. This defines +-all the files in directory @var{dir} as module mname. ++all the files in directory @var{dir} as module @var{mname}. + @var{dir} is a relative path (from @code{$CVSROOT}) to a + directory of source in the source repository. In this + case, on checkout, a single directory called diff --git a/devel/cvs-devel/files/patch-cvsbug_tmpfix b/devel/cvs-devel/files/patch-cvsbug_tmpfix new file mode 100644 index 000000000000..f5d15ae94403 --- /dev/null +++ b/devel/cvs-devel/files/patch-cvsbug_tmpfix @@ -0,0 +1,22 @@ +# Patch for a tmp race in cvsbug (in the source package; we don't ship +# the script as part of the package). Closes: #325106 +diff -Nur src/cvsbug.in src/cvsbug.in +--- src/cvsbug.in 2003-02-26 05:31:33.000000000 +0800 ++++ src/cvsbug.in 2006-02-26 22:07:08.000000000 +0800 +@@ -109,14 +109,14 @@ + /usr/bin/ypcat passwd 2>/dev/null | cat - /etc/passwd | grep "^$LOGNAME:" | + cut -f5 -d':' | sed -e 's/,.*//' > $TEMP + ORIGINATOR="`cat $TEMP`" +- rm -f $TEMP ++ > $TEMP + fi + fi + + if [ "$ORIGINATOR" = "" ]; then + grep "^$LOGNAME:" /etc/passwd | cut -f5 -d':' | sed -e 's/,.*//' > $TEMP + ORIGINATOR="`cat $TEMP`" +- rm -f $TEMP ++ > $TEMP + fi + + if [ -n "$ORGANIZATION" ]; then diff --git a/devel/cvs-devel/files/patch-cvsrc_whitespace b/devel/cvs-devel/files/patch-cvsrc_whitespace new file mode 100644 index 000000000000..ca3c68f597ea --- /dev/null +++ b/devel/cvs-devel/files/patch-cvsrc_whitespace @@ -0,0 +1,37 @@ +# Ignore leading whitespace in .cvsrc files. Closes: #212415. Thanks +# to James R. Van Zandt for the patch. +diff -Nur src/cvsrc.c src/cvsrc.c +--- src/cvsrc.c 2005-03-16 23:52:14.000000000 +0800 ++++ src/cvsrc.c 2006-02-26 18:25:18.000000000 +0800 +@@ -41,6 +41,7 @@ + size_t line_chars_allocated; + + char *optstart; ++ int white_len; + + int command_len; + int found = 0; +@@ -96,9 +97,12 @@ + if (line[0] == '#') + continue; + ++ for (white_len=0; isspace(line[white_len]); white_len++) ++ ; ++ + /* stop if we match the current command */ +- if (!strncmp (line, cmdname, command_len) +- && isspace ((unsigned char) *(line + command_len))) ++ if (!strncmp (line + white_len, cmdname, command_len) ++ && isspace ((unsigned char) *(line + white_len + command_len))) + { + found = 1; + break; +@@ -120,7 +124,7 @@ + if (found) + { + /* skip over command in the options line */ +- for (optstart = strtok (line + command_len, "\t \n"); ++ for (optstart = strtok (line + white_len + command_len, "\t \n"); + optstart; + optstart = strtok (NULL, "\t \n")) + { diff --git a/devel/cvs-devel/files/patch-date_format_option b/devel/cvs-devel/files/patch-date_format_option new file mode 100644 index 000000000000..d78f5988328f --- /dev/null +++ b/devel/cvs-devel/files/patch-date_format_option @@ -0,0 +1,151 @@ +# +# Add an extra option to set the DateFormat used in log output. +# +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur doc/cvs.texinfo doc/cvs.texinfo +--- doc/cvs.texinfo 2005-09-23 10:02:53.000000000 +0800 ++++ doc/cvs.texinfo 2006-02-26 23:03:05.000000000 +0800 +@@ -14840,9 +14840,17 @@ + group to using @code{cvs admin} to change the default keyword + substitution mode, lock revisions, unlock revisions, and + replace the log message, use @samp{UserAdminOptions=klum}. +-@end table +- + ++@cindex DateFormat, in CVSROOT/config ++@item DateFormat=@var{value} ++Control the output format of dates from cvs. cvs version 1.12.x ++changed the default format to use ``iso8601'' dates, which are ++better for many reasons. However, old scripts/programs written to ++parse the output of various cvs commands (especially cvs log) may ++not cope with the change in date format (e.g. gcvs). The default ++value of DateFormat will be ``iso8601'', but if you need temporary ++backwards-compatibility set DateFormat=old. ++@end table + + @c --------------------------------------------------------------------- + @node Environment variables +diff -Nur src/log.c src/log.c +--- src/log.c 2005-03-22 21:19:57.000000000 +0800 ++++ src/log.c 2006-02-26 23:03:05.000000000 +0800 +@@ -1607,8 +1607,12 @@ + &sec); + if (year < 1900) + year += 1900; +- sprintf (buf, "%04d-%02d-%02d %02d:%02d:%02d +0000", year, mon, mday, +- hour, min, sec); ++ if ('-' == datesep) ++ sprintf (buf, "%04d%c%02d%c%02d %02d:%02d:%02d +0000", year, datesep, ++ mon, datesep, mday, hour, min, sec); ++ else ++ sprintf (buf, "%04d%c%02d%c%02d %02d:%02d:%02d", year, datesep, ++ mon, datesep, mday, hour, min, sec); + cvs_output_tagged ("date", buf); + + cvs_output_tagged ("text", "; author: "); +diff -Nur src/main.c src/main.c +--- src/main.c 2006-02-26 23:03:04.000000000 +0800 ++++ src/main.c 2006-02-26 23:10:12.000000000 +0800 +@@ -1371,9 +1371,19 @@ + static char buf[sizeof ("yyyy-mm-dd HH:MM:SS -HHMM")]; + /* Convert to a time in the local time zone. */ + struct tm ltm = *(localtime (&unixtime)); +- +- if (!my_strftime (buf, sizeof (buf), "%Y-%m-%d %H:%M:%S %z", <m, 0, 0)) +- return NULL; ++ char *format = NULL; ++ ++ switch (datesep) ++ { ++ case '/': ++ format = "%Y/%m/%d %H:%M:%S"; ++ break; ++ default: ++ format = "%Y-%m-%d %H:%M:%S %z"; ++ break; ++ } ++ if (my_strftime (buf, sizeof (buf), format, <m, 0, 0) == 0) ++ return NULL; + + return xstrdup (buf); + } +@@ -1388,9 +1398,19 @@ + static char buf[sizeof ("yyyy-mm-dd HH:MM:SS -HHMM")]; + /* Convert to a time in the local time zone. */ + struct tm ltm = *(gmtime (&unixtime)); +- +- if (!my_strftime (buf, sizeof (buf), "%Y-%m-%d %H:%M:%S %z", <m, 0, 0)) +- return NULL; ++ char *format = NULL; ++ ++ switch (datesep) ++ { ++ case '/': ++ format = "%Y/%m/%d %H:%M:%S"; ++ break; ++ default: ++ format = "%Y-%m-%d %H:%M:%S %z"; ++ break; ++ } ++ if (my_strftime (buf, sizeof (buf), format, <m, 0, 0) == 0) ++ return NULL; + + return xstrdup (buf); + } +diff -Nur src/parseinfo.c src/parseinfo.c +--- src/parseinfo.c 2005-09-06 12:40:37.000000000 +0800 ++++ src/parseinfo.c 2006-02-26 23:03:05.000000000 +0800 +@@ -626,6 +626,19 @@ + retval->logHistory = xstrdup (p); + } + } ++ /* grab FreeBSD date format idea */ ++ else if (strcmp (line, "DateFormat") == 0) ++ { ++ if (strcmp (p, "old") == 0) ++ { ++ datesep = '/'; ++ } ++ else if (strcmp (p, "iso8601") == 0) ++ { ++ datesep = '-'; ++ } ++ } ++ /* end grabbing */ + else if (strcmp (line, "RereadLogAfterVerify") == 0) + { + if (!strcasecmp (p, "never")) +diff -Nur src/rcs.c src/rcs.c +--- src/rcs.c 2006-02-26 23:03:04.000000000 +0800 ++++ src/rcs.c 2006-02-26 23:03:05.000000000 +0800 +@@ -33,6 +33,8 @@ + # endif + #endif + ++int datesep = '-'; ++ + /* The RCS -k options, and a set of enums that must match the array. + These come first so that we can use enum kflag in function + prototypes. */ +@@ -3537,8 +3539,8 @@ + &sec); + if (year < 1900) + year += 1900; +- sprintf (buf, "%04d/%02d/%02d %02d:%02d:%02d", year, mon, mday, +- hour, min, sec); ++ sprintf (buf, "%04d%c%02d%c%02d %02d:%02d:%02d", year, datesep, mon, ++ datesep, mday, hour, min, sec); + return xstrdup (buf); + } + +diff -Nur src/rcs.h src/rcs.h +--- src/rcs.h 2005-03-18 06:36:24.000000000 +0800 ++++ src/rcs.h 2006-02-26 23:03:05.000000000 +0800 +@@ -254,6 +254,7 @@ + void RCS_setlocalid (const char *, unsigned int, void **, const char *arg); + char *make_file_label (const char *, const char *, RCSNode *); + ++extern int datesep; + extern bool preserve_perms; + + /* From import.c. */ diff --git a/devel/cvs-devel/files/patch-ext_expansion b/devel/cvs-devel/files/patch-ext_expansion new file mode 100644 index 000000000000..b3d69dd12bda --- /dev/null +++ b/devel/cvs-devel/files/patch-ext_expansion @@ -0,0 +1,29 @@ +# +# Make the "ext" method more intelligent; allow specification of the +# "rsh" command using ext=<command>. Extended to recognise "extssh" the +# same way as "ext=ssh" +# +# Original patch by Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com>, +# extension by Steve McIntyre <steve@einval.com>. Bugs #165432 and #276328 +diff -Nur src/root.c.orig src/root.c +--- src/root.c.orig 2006-05-05 23:35:40.000000000 +0800 ++++ src/root.c 2006-05-05 23:34:12.000000000 +0800 +@@ -553,6 +547,18 @@ + newroot->method = gserver_method; + else if (!strcasecmp (method, "server")) + newroot->method = server_method; ++ else if (strncmp (method, "ext=", 4) == 0) ++ { ++ const char *rsh = method + 4; ++ setenv ("CVS_RSH", rsh, 1); /* This is a hack, but simplifies */ ++ newroot->method = ext_method; ++ } ++ else if (strncmp (method, "extssh", 6) == 0) ++ { ++ const char *rsh = method + 3; ++ setenv ("CVS_RSH", rsh, 1); /* This is a hack, but simplifies */ ++ newroot->method = ext_method; ++ } + else if (!strcasecmp (method, "ext")) + newroot->method = ext_method; + else if (!strcasecmp (method, "fork")) diff --git a/devel/cvs-devel/files/patch-extra_tags b/devel/cvs-devel/files/patch-extra_tags new file mode 100644 index 000000000000..2d37e2ec305b --- /dev/null +++ b/devel/cvs-devel/files/patch-extra_tags @@ -0,0 +1,29 @@ +# +# Add extra tag keyword expansion options +# +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur src/logmsg.c src/logmsg.c +--- src/logmsg.c 2006-02-26 22:54:52.000000000 +0800 ++++ src/logmsg.c 2006-02-26 22:56:36.000000000 +0800 +@@ -642,7 +642,11 @@ + break; + case 'T': + li = p->data; +- arg = li->tag ? li->tag : ""; ++ arg = li->tag ? li->tag : "TRUNK"; ++ break; ++ case 'S': ++ arg = xmalloc(strlen(p->key) + 5); ++ sprintf(arg, "\\\"%s\\\"", p->key); + break; + case 'V': + li = p->data; +@@ -814,7 +818,7 @@ + #endif /* SERVER_SUPPORT */ + "p", "s", srepos, + "r", "s", current_parsed_root->directory, +- "sVv", ",", changes, ++ "SsTVv", ",", changes, + logmsg_list_to_args_proc, (void *) NULL, + (char *) NULL); + if (!cmdline || !strlen (cmdline)) diff --git a/devel/cvs-devel/files/patch-fix_-l b/devel/cvs-devel/files/patch-fix_-l new file mode 100644 index 000000000000..c384369c6ac9 --- /dev/null +++ b/devel/cvs-devel/files/patch-fix_-l @@ -0,0 +1,26 @@ +# Re-added -l option to the client. Does nothing, but stops +# warnings/errors. Will really fix #219950 and #224737, and also a +# differently-described bug (220379). Closes: #219950, #220379 +# +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur src/main.c src/main.c +--- src/main.c 2006-02-26 22:09:42.000000000 +0800 ++++ src/main.c 2006-02-26 22:09:43.000000000 +0800 +@@ -511,7 +511,7 @@ + int help = 0; /* Has the user asked for help? This + lets us support the `cvs -H cmd' + convention to give help for cmd. */ +- static const char short_options[] = "+QqrwtnRvb:T:e:d:Hfz:s:xa"; ++ static const char short_options[] = "+QqrwtnRvb:T:e:d:Hfz:s:xal"; + static struct option long_options[] = + { + {"help", 0, NULL, 'H'}, +@@ -669,6 +669,8 @@ + noexec = 1; + logoff = 1; + break; ++ case 'l': /* no-op to simply ignore the old -l option */ ++ break; + case 'v': + (void) fputs ("\n", stdout); + version (0, NULL); diff --git a/devel/cvs-devel/files/patch-fix_sparc_sigbus b/devel/cvs-devel/files/patch-fix_sparc_sigbus new file mode 100644 index 000000000000..bc2abaf2c393 --- /dev/null +++ b/devel/cvs-devel/files/patch-fix_sparc_sigbus @@ -0,0 +1,30 @@ +diff -Nur src/update.c src/update.c +--- src/update.c 2005-09-22 20:49:17.000000000 +0200 ++++ src/update.c 2006-12-15 01:35:54.000000000 +0100 +@@ -58,7 +58,7 @@ + static int patch_file (struct file_info *finfo, + Vers_TS *vers_ts, + int *docheckout, struct stat *file_info, +- unsigned char *checksum); ++ md5_uint32 *checksum); + static void patch_file_write (void *, const char *, size_t); + #endif + static int merge_file (struct file_info *finfo, Vers_TS *vers); +@@ -723,7 +723,7 @@ + { + int docheckout; + struct stat file_info; +- unsigned char checksum[16]; ++ md5_uint32 checksum[4]; + + retval = patch_file (finfo, + vers, &docheckout, +@@ -1511,7 +1511,7 @@ + */ + static int + patch_file (struct file_info *finfo, Vers_TS *vers_ts, int *docheckout, +- struct stat *file_info, unsigned char *checksum) ++ struct stat *file_info, md5_uint32 *checksum) + { + char *backup; + char *file1; diff --git a/devel/cvs-devel/files/patch-flag_conflicted_copies b/devel/cvs-devel/files/patch-flag_conflicted_copies new file mode 100644 index 000000000000..0657e6c6977f --- /dev/null +++ b/devel/cvs-devel/files/patch-flag_conflicted_copies @@ -0,0 +1,21 @@ +# Undo not flagging conflicted copies anymore, as reported by +# Henrique de Moraes Holschuh <hmh@debian.org> +# Closes: #368681 +# Fix as described in message to the CVS mailing list at +# http://lists.gnu.org/archive/html/info-cvs/2006-06/msg00050.html +--- src/client.c~ 2005-10-02 16:17:20.000000000 +0100 ++++ src/client.c 2006-06-09 20:12:06.000000000 +0100 +@@ -4533,10 +4533,9 @@ + /* File no longer exists. Don't do anything, missing files + just happen. */ + } +- else if (!vers->ts_rcs || args->force +- || strcmp (vers->ts_conflict +- ? vers->ts_conflict : vers->ts_rcs, vers->ts_user) +- || (vers->ts_conflict && !strcmp (cvs_cmd_name, "diff"))) ++ else if (vers->ts_rcs == NULL ++ || args->force ++ || strcmp (vers->ts_user, vers->ts_rcs) != 0) + { + if (args->no_contents + && supported_request ("Is-modified")) diff --git a/devel/cvs-devel/files/patch-freebsdlocal b/devel/cvs-devel/files/patch-freebsdlocal deleted file mode 100644 index 5c9336d26a51..000000000000 --- a/devel/cvs-devel/files/patch-freebsdlocal +++ /dev/null @@ -1,4062 +0,0 @@ -Index: FREEBSD-Xlist -diff -u /dev/null src/contrib/cvs/FREEBSD-Xlist:1.1 ---- /dev/null Fri Oct 20 15:17:33 2006 -+++ FREEBSD-Xlist Thu Jun 10 05:14:53 2004 -@@ -0,0 +1,21 @@ -+FreeBSD: src/contrib/cvs/FREEBSD-Xlist,v 1.1 2004/06/09 20:14:53 des Exp $ -+ -+*/*.com -+*/*.dep -+*/*.dsp -+*/*.mak -+*/.cvsignore -+.cvsignore -+README.VMS -+build.com -+cvs.spec* -+cvsnt.* -+doc/*.info* -+doc/*.ps -+doc/texinfo.tex -+emx -+lib/getdate.c -+os2 -+vms -+windows-NT -+zlib -Index: FREEBSD-upgrade -diff -u /dev/null src/contrib/cvs/FREEBSD-upgrade:1.11 ---- /dev/null Fri Oct 20 15:17:33 2006 -+++ FREEBSD-upgrade Thu Jun 10 05:51:26 2004 -@@ -0,0 +1,38 @@ -+FreeBSD: src/contrib/cvs/FREEBSD-upgrade,v 1.11 2004/06/09 20:51:26 des Exp $ -+ -+MAINTAINER= peter@FreeBSD.org -+ -+This directory contains the virgin CVS source on the vendor branch. Do -+not under any circumstances commit new versions onto the mainline, new -+versions or official-patch versions must be imported. -+ -+To prepare a new cvs dist for import, extract it into a fresh directory; -+then delete the files and directories listed in FREEBSD-Xlist. -+ -+CVS is imported from its top level directory something like this: -+ cvs -n import src/contrib/cvs CVSHOME v<version> -+ -+The -n option is "don't do anything" so you can see what is about to happen -+first. Remove it when it looks ok. -+ -+The initial import was done with: -+ cvs import src/contrib/cvs CVSHOME v1_8_1 -+ -+When new versions are imported, cvs will give instructions on how to merge -+the local and vendor changes when/if conflicts arise. -+ -+The developers can be reached at: <devel-cvs@cyclic.com>. Local changes -+that are suitable for public consumption should be submitted for inclusion -+in future releases. -+ -+peter@freebsd.org - 20 Aug 1996 -+ -+Current local changes: -+ - CVS_LOCAL_BRANCH_NUM environment variable support for choosing the -+ magic branch number. (for CVSup local-commit support) -+ - CVSREADONLYFS environment variable and global option -R to enable -+ no-locking readonly mode (eg: cvs repo is a cdrom or mirror) -+ - the verify message script can edit the submitted log message. -+ - CVSROOT/options file -+ - Variable keyword expansion controls including custom keywords. -+ - $ CVSHeader$ keyword - like Header, but with $CVSROOT stripped off. -Index: contrib/sccs2rcs.in -diff -u src/contrib/cvs/contrib/sccs2rcs.in:1.1.1.3 src/contrib/cvs/contrib/sccs2rcs.in:1.5 ---- src/contrib/cvs/contrib/sccs2rcs.in:1.1.1.3 Thu Apr 15 10:01:55 2004 -+++ contrib/sccs2rcs.in Thu Apr 15 10:17:25 2004 -@@ -48,6 +48,7 @@ - # -Allan G. Schrum schrum@ofsoptics.com agschrum@mindspring.com - # Fri Sep 26 10:40:40 EDT 2003 - # -+# FreeBSD: src/contrib/cvs/contrib/sccs2rcs.in,v 1.5 2004/04/15 01:17:25 peter Exp $ - - - #we'll assume the user set up the path correctly -Index: diff/diagmeet.note -diff -u src/contrib/cvs/diff/diagmeet.note:1.1.1.1 src/contrib/cvs/diff/diagmeet.note:removed ---- src/contrib/cvs/diff/diagmeet.note:1.1.1.1 Mon Jan 26 12:09:49 1998 -+++ diff/diagmeet.note Fri Oct 20 15:17:34 2006 -@@ -1,71 +0,0 @@ --Here is a comparison matrix which shows a case in which --it is possible for the forward and backward scan in `diag' --to meet along a nonzero length of diagonal simultaneous --(so that bdiag[d] and fdiag[d] are not equal) --even though there is no snake on that diagonal at the meeting point. -- -- -- 85 1 1 1 159 1 1 17 -- 1 2 3 4 --60 -- 1 2 --1 -- 2 2 3 4 --71 -- 3 3 4 5 --85 -- 4 3 4 5 --17 -- 5 4 5 --1 -- 6 4 5 6 --183 -- 7 5 6 7 --10 -- 8 6 7 --1 -- 9 6 7 8 --12 -- 7 8 9 10 --13 -- 10 8 9 10 --14 -- 10 9 10 --17 -- 10 10 --1 -- 10 9 10 --1 -- 8 10 10 10 --183 -- 8 7 9 9 9 --10 -- 7 6 8 9 8 8 --1 -- 6 5 7 7 --1 -- 5 6 6 --1 -- 5 5 5 --50 -- 5 4 4 4 --1 -- 4 3 3 --85 -- 5 4 3 2 2 --1 -- 2 1 --17 -- 5 4 3 2 1 1 --1 -- 1 0 -- 85 1 1 1 159 1 1 17 -- -- -- -- -- -- -- -- -- -Index: diff/diff3.c -diff -u src/contrib/cvs/diff/diff3.c:1.1.1.7 src/contrib/cvs/diff/diff3.c:1.6 ---- src/contrib/cvs/diff/diff3.c:1.1.1.7 Thu Apr 15 10:01:56 2004 -+++ diff/diff3.c Thu Apr 15 10:17:26 2004 -@@ -12,6 +12,9 @@ - GNU General Public License for more details. - - */ -+/* -+ * FreeBSD: src/contrib/cvs/diff/diff3.c,v 1.6 2004/04/15 01:17:26 peter Exp $ -+ */ - - /* Written by Randy Smith */ - /* Librarification by Tim Pierce */ -Index: lib/md5.h -diff -u src/contrib/cvs/lib/md5.h:1.1.1.3 src/contrib/cvs/lib/md5.h:1.2 ---- src/contrib/cvs/lib/md5.h:1.1.1.3 Sat Dec 11 21:22:56 1999 -+++ lib/md5.h Sun Dec 12 00:10:02 1999 -@@ -1,8 +1,21 @@ - /* See md5.c for explanation and copyright information. */ - -+/* -+ * FreeBSD: src/contrib/cvs/lib/md5.h,v 1.2 1999/12/11 15:10:02 peter Exp $ -+ */ -+ - #ifndef MD5_H - #define MD5_H - -+#ifdef __FreeBSD__ -+#define cvs_MD5Context MD5Context -+#define cvs_MD5Init MD5Init -+#define cvs_MD5Update MD5Update -+#define cvs_MD5Final MD5Final -+#define cvs_MD5Transform MD5Transform -+#include <sys/md5.h> -+#else -+ - /* Unlike previous versions of this code, uint32 need not be exactly - 32 bits, merely 32 bits or more. Choosing a data type which is 32 - bits instead of 64 is not important; speed is considerably more -@@ -23,4 +36,6 @@ - struct cvs_MD5Context *context)); - void cvs_MD5Transform PROTO ((cvs_uint32 buf[4], const unsigned char in[64])); - -+#endif -+ - #endif /* !MD5_H */ -Index: man/cvs.1 -diff -u /dev/null src/contrib/cvs/man/cvs.1:1.22 ---- /dev/null Fri Oct 20 15:17:35 2006 -+++ man/cvs.1 Thu Jul 28 22:53:45 2005 -@@ -0,0 +1,2203 @@ -+.\" FreeBSD: src/contrib/cvs/man/cvs.1,v 1.22 2005/07/28 13:53:45 keramida Exp $ -+.de Id -+.ds Rv \\$3 -+.ds Dt \\$4 -+.. -+.TH CVS 1 "\*(Dt" -+.\" Full space in nroff; half space in troff -+.de SP -+.if n .sp -+.if t .sp .5 -+.. -+.\" quoted command -+.de ` -+.RB ` "\|\\$1\|" '\\$2 -+.. -+.SH "NAME" -+cvs \- Concurrent Versions System -+.SH "SYNOPSIS" -+.TP -+\fBcvs\fP [ \fIcvs_options\fP ] -+.I cvs_command -+[ -+.I command_options -+] [ -+.I command_args -+] -+.SH "NOTE" -+This manpage is a summary of some of the features of -+.B cvs -+but it may no longer be kept up-to-date. -+For more current and in-depth documentation, please consult the -+Cederqvist manual (via the -+.B info cvs -+command or otherwise, -+as described in the SEE ALSO section of this manpage). -+.SH "DESCRIPTION" -+.IX "revision control system" "\fLcvs\fR" -+.IX cvs "" "\fLcvs\fP \- concurrent versions system" -+.IX "concurrent versions system \- \fLcvs\fP" -+.IX "release control system" "cvs command" "" "\fLcvs\fP \- concurrent versions system" -+.IX "source control system" "cvs command" "" "\fLcvs\fP \- concurrent versions system" -+.IX revisions "cvs command" "" "\fLcvs\fP \- source control" -+CVS is a version control system, which allows you to keep old versions -+of files (usually source code), keep a log of who, when, and why -+changes occurred, etc., like RCS or SCCS. Unlike the simpler systems, -+CVS does not just operate on one file at a time or one directory at a -+time, but operates on hierarchical collections of directories -+consisting of version controlled files. CVS helps to manage releases -+and to control the concurrent editing of source files among multiple -+authors. CVS allows triggers to enable/log/control various -+operations and works well over a wide area network. -+.SP -+.B cvs -+keeps a single copy of the master sources. -+This copy is called the source ``repository''; it contains all the -+information to permit extracting previous software releases at any -+time based on either a symbolic revision tag, or a date in the past. -+.SH "ESSENTIAL COMMANDS" -+.B cvs -+provides a rich variety of commands (\fIcvs_command\fP in the -+Synopsis), each of which often has a wealth of options, to satisfy the -+many needs of source management in distributed environments. However, -+you don't have to master every detail to do useful work with -+.BR cvs ; -+in fact, five commands are sufficient to use (and contribute to) -+the source repository. -+.TP -+\fBcvs checkout\fP \fImodules\fP\|.\|.\|. -+A necessary preliminary for most \fBcvs\fP work: creates your private -+copy of the source for \fImodules\fP (named collections of source; you -+can also use a path relative to the source repository here). You can -+work with this copy without interfering with others' work. At least -+one subdirectory level is always created. -+.TP -+.B cvs update -+Execute this command from \fIwithin\fP your private source -+directory when you wish to update your copies of source files from -+changes that other developers have made to the source in the -+repository. -+.TP -+\fBcvs add\fP \fIfile\fP\|.\|.\|. -+Use this command to enroll new files in \fBcvs\fP records of your -+working directory. The files will be added to the repository the next -+time you run -+.` "cvs commit". -+Note: -+You should use the -+.` "cvs import" -+command to bootstrap new sources into the source repository. -+.` "cvs add" -+is only used for new files to an already checked-out module. -+.TP -+\fBcvs remove\fP \fIfile\fP\|.\|.\|. -+Use this command (after erasing any files listed) to declare that you -+wish to eliminate files from the repository. The removal does not -+affect others until you run -+.` "cvs commit". -+.TP -+\fBcvs commit\fP \fIfile\fP\|.\|.\|. -+Use this command when you wish to ``publish'' your changes to other -+developers, by incorporating them in the source repository. -+.SH "OPTIONS" -+The -+.B cvs -+command line can include -+.IR cvs_options , -+which apply to the overall -+.B cvs -+program; a -+.IR cvs_command , -+which specifies a particular action on the source repository; and -+.I command_options -+and -+.I command_arguments -+to fully specify what the -+.I cvs_command -+will do. -+.SP -+.I Warning: -+you must be careful of precisely where you place options relative to the -+.IR cvs_command . -+The same option can mean different things depending on whether it -+is in the -+.I cvs_options -+position (to the left of a -+.B cvs -+command) or in the -+.I command_options -+position (to the right of a -+.B cvs -+command). -+.SP -+There are only two situations where you may omit -+.IR cvs_command : -+.` "cvs \-H" -+or -+.` "cvs --help" -+elicits a list of available commands, and -+.` "cvs \-v" -+or -+.` "cvs --version" -+displays version information on \fBcvs\fP itself. -+.SP -+.SH "CVS OPTIONS" -+As of release 1.6, -+.B cvs -+supports -+.SM GNU -+style long options as well as short options. Only -+a few long options are currently supported, these are listed in -+brackets after the short options whose functions they duplicate. -+.SP -+Use these options to control the overall -+.B cvs -+program: -+.TP -+.B \-H [ --help ] -+Display usage information about the specified -+.I cvs_command -+(but do not actually execute the command). If you don't specify a -+command name, -+.` "cvs \-H" -+displays a summary of all the commands available. -+.TP -+.B \-Q -+Causes the command to be -+.I really -+quiet; the command will generate output only for serious problems. -+.TP -+.B \-q -+Causes the command to be somewhat quiet; informational messages, such -+as reports of recursion through subdirectories, are suppressed. -+.TP -+\fB\-b\fP \fIbindir\fP -+Use -+.I bindir -+as the directory where -+.SM RCS -+programs are located (CVS 1.9 and older). -+Overrides the setting of the -+.SM RCSBIN -+environment variable. -+This value should be specified as an absolute pathname. -+.TP -+\fB\-d\fP \fICVS_root_directory\fP -+Use -+.I CVS_root_directory -+as the root directory pathname of the master -+source repository. -+Overrides the setting of the -+.SM CVSROOT -+environment variable. -+This value should be specified as an absolute pathname. -+.TP -+\fB\-e\fP \fIeditor\fP -+Use -+.I editor -+to enter revision log information. -+Overrides the setting of the -+.SM CVSEDITOR\c -+, -+.SM VISUAL\c -+, and -+.SM EDITOR -+environment variables. -+.TP -+.B \-f -+Do not read the -+.B cvs -+startup file (\fI~/.cvsrc\fP). -+.TP -+.B \-n -+Do not change any files. Attempt to execute the -+.IR cvs_command , -+but only to issue reports; do not remove, update, or merge any -+existing files, or create any new files. -+.TP -+.B \-t -+Trace program execution; display messages showing the steps of -+.B cvs -+activity. Particularly useful with -+.B \-n -+to explore the potential impact of an unfamiliar command. -+.TP -+.B \-r -+Makes new working files read-only. -+Same effect as if the -+.SM CVSREAD -+environment variable is set. -+.TP -+.B \-R -+Turns on read-only repository mode. This allows one to check out from a -+read-only repository, such as within an anoncvs server, or from a CDROM -+repository. -+Same effect as if the -+.SM CVSREADONLYFS -+environment variable is set. Using -+.B \-R -+can also considerably speed up checkout's over NFS. -+.TP -+.B \-v [ --version ] -+Displays version and copyright information for -+.BR cvs . -+.TP -+.B \-w -+Makes new working files read-write (default). -+Overrides the setting of the -+.SM CVSREAD -+environment variable. -+.TP -+.B \-g -+Forces group-write perms on working files. This option is typically -+used when you have multiple users sharing a single checked out source -+tree, allowing them to operate their shells with a less dangerous umask. -+To use this feature, create a directory to hold the checked-out source -+tree, set it to a private group, and set up the directory such that -+files created under it inherit the group id of the directory. This occurs -+automatically with FreeBSD. With SysV you must typically set the SGID bit -+on the directory. The users who are to share the checked out tree must -+be placed in that group. Note that the sharing of a single checked-out -+source tree is very different from giving several users access to a common -+CVS repository. Access to a common CVS repository already maintains shared -+group-write perms and does not require this option. -+ -+To use the option transparently, simply place the line 'cvs -g' in your -+~/.cvsrc file. Doing this is not recommended unless you firewall all your -+source checkouts within a private group or within a private mode 0700 -+directory. -+.TP -+.B \-x -+Encrypt all communication between the client and the server. As of -+this writing, this is only implemented when using a Kerberos -+connection. -+.TP -+\fB\-z\fP \fIcompression\-level\fP -+When transferring files across the network use -+.B gzip -+with compression level \fIcompression\-level\fP to compress and -+de-compress data as it is transferred. Requires the presence of -+the -+.SM GNU -+.B gzip -+program in the current search path at both ends of the link. -+.SH "USAGE" -+Except when requesting general help with -+.` "cvs \-H", -+you must specify a -+.I cvs_command -+to -+.B cvs -+to select a specific release control function to perform. -+Each -+.B cvs -+command accepts its own collection of options and arguments. -+However, many options are available across several commands. -+You can display a usage summary for each command by specifying the -+.B \-H -+option with the command. -+.SH "CVS STARTUP FILE" -+Normally, when CVS starts up, it reads the -+.I .cvsrc -+file from the home directory of the user reading it. This startup -+procedure can be turned off with the -+.B \-f -+flag. -+.SP -+The -+.I .cvsrc -+file lists CVS commands with a list of arguments, one command per -+line. For example, the following line in \fI.cvsrc\fP: -+.SP -+diff \-c -+.SP -+will mean that the -+.` "cvs diff" -+command will always be passed the \-c option in addition to any -+other options that are specified in the command line (in this case -+it will have the effect of producing context sensitive diffs for -+all executions of -+.` "cvs diff" -+). -+.SP -+Global options are specified using the \fBcvs\fP keyword. For example, -+the following: -+.SP -+cvs \-q -+.SP -+will mean that all -+.` "cvs" -+commands will behave as thought he \-q global option had been supplied. -+.SH "CVS COMMAND SUMMARY" -+Here are brief descriptions of all the -+.B cvs -+commands: -+.TP -+.B add -+Add a new file or directory to the repository, pending a -+.` "cvs commit" -+on the same file. -+Can only be done from within sources created by a previous -+.` "cvs checkout" -+invocation. -+Use -+.` "cvs import" -+to place whole new hierarchies of sources under -+.B cvs -+control. -+(Does not directly affect repository; changes -+working directory.) -+.TP -+.B admin -+Execute -+control functions on the source repository. (Changes -+repository directly; uses working directory without changing it.) -+.TP -+.B checkout -+Make a working directory of source files for editing. (Creates or changes -+working directory.) -+.TP -+.B commit -+Apply to the source repository changes, additions, and deletions from your -+working directory. (Changes repository.) -+.TP -+.B diff -+Show differences between files in working directory and source -+repository, or between two revisions in source repository. -+(Does not change either repository or working directory.) -+.TP -+.B export -+Prepare copies of a set of source files for shipment off site. -+Differs from -+.` "cvs checkout" -+in that no -+.B cvs -+administrative directories are created (and therefore -+.` "cvs commit" -+cannot be executed from a directory prepared with -+.` "cvs export"), -+and a symbolic tag must be specified. -+(Does not change repository; creates directory similar to working -+directories). -+.TP -+.B history -+Show reports on -+.B cvs -+commands that you or others have executed on a particular file or -+directory in the source repository. (Does not change repository or -+working directory.) History logs are kept only if enabled by creation -+of the -+.` "$CVSROOT/CVSROOT/history" -+file; see -+.BR cvs ( 5 ). -+.TP -+.B import -+Incorporate a set of updates from off-site into the source repository, -+as a ``vendor branch''. (Changes repository.) -+.TP -+.B init -+Initialize a repository by adding the CVSROOT subdirectory and some default -+control files. You must use this command or initialize the repository in -+some other way before you can use it. -+.TP -+.B log -+Display -+log information. -+(Does not change repository or working directory.) -+.TP -+.B rdiff -+Prepare a collection of diffs as a patch file between two releases in -+the repository. (Does not change repository or working directory.) -+.TP -+.B release -+Cancel a -+.` "cvs checkout", -+abandoning any changes. -+(Can delete working directory; no effect on repository.) -+.TP -+.B remove -+Remove files from the source repository, pending a -+.` "cvs commit" -+on the same files. (Does not directly affect repository; -+changes working directory.) -+.TP -+.B rtag -+Explicitly specify a symbolic tag for particular revisions of files in the -+source repository. See also -+.` "cvs tag". -+(Changes repository directly; does not require or affect -+working directory.) -+.TP -+.B status -+Show current status of files: latest version, version in working -+directory, whether working version has been edited and, optionally, -+symbolic tags in the -+.SM RCS -+file. (Does not change -+repository or working directory.) -+.TP -+.B tag -+Specify a symbolic tag for files in the repository. By default, tags -+the revisions -+that were last synchronized with your working directory. (Changes -+repository directly; uses working directory without changing it.) -+.TP -+.B update -+Bring your working directory up to date with changes from the -+repository. Merges are performed automatically when possible; a -+warning is issued if manual resolution is required for conflicting -+changes. (Changes working directory; does not change repository.) -+.SH "COMMON COMMAND OPTIONS" -+This section describes the -+.I command_options -+that are available across several -+.B cvs -+commands. Not all commands support all of these options; each option -+is only supported for commands where it makes sense. However, when -+a command has one of these options you can count on the same meaning -+for the option as in other commands. (Other command -+options, which are listed with the individual commands, may have -+different meanings from one -+.B cvs -+command to another.) -+.I "Warning:" -+the -+.B history -+command is an exception; -+it supports many options that conflict -+even with these standard options. -+.TP -+\fB\-D\fP \fIdate_spec\fP -+Use the most recent revision no later than \fIdate_spec\fP (a single -+argument, date description specifying a date in the -+past). A wide variety of date formats are supported, in particular -+ISO ("1972-09-24 20:05") or Internet ("24 Sep 1972 20:05"). -+The \fIdate_spec\fP is interpreted as being in the local timezone, unless a -+specific timezone is specified. -+The specification is ``sticky'' when you use it to make a -+private copy of a source file; that is, when you get a working file -+using \fB\-D\fP, \fBcvs\fP records the date you -+specified, so that further updates in the same directory will use the -+same date (unless you explicitly override it; see the description of -+the \fBupdate\fP command). -+.B \-D -+is available with the -+.BR checkout ", " diff ", " history ", " export ", " -+.BR rdiff ", " rtag ", and " -+.B update -+commands. -+Examples of valid date specifications include: -+.in +1i -+.ft B -+.nf -+1 month ago -+2 hours ago -+400000 seconds ago -+last year -+last Monday -+yesterday -+a fortnight ago -+3/31/92 10:00:07 PST -+January 23, 1987 10:05pm -+22:00 GMT -+.fi -+.ft P -+.in -1i -+.TP -+.B \-f -+When you specify a particular date or tag to \fBcvs\fP commands, they -+normally ignore files that do not contain the tag (or did not exist on -+the date) that you specified. Use the \fB\-f\fP option if you want -+files retrieved even when there is no match for the tag or date. (The -+most recent version is used in this situation.) -+.B \-f -+is available with these commands: -+.BR checkout ", " export ", " -+.BR rdiff ", " rtag ", and " update . -+.TP -+\fB\-k\fP \fIkflag\fP -+Alter the default -+processing of keywords. -+The \fB\-k\fP option is available with the -+.BR add ", " checkout ", " diff ", " export ", " -+.BR rdiff ", and " update -+commands. Your \fIkflag\fP specification is ``sticky'' when you use -+it to create a private copy of a source file; that is, when you use -+this option with the \fBcheckout\fP or \fBupdate\fP commands, -+\fBcvs\fP associates your selected \fIkflag\fP with the file, and -+continues to use it with future \fBupdate\fP commands on the same file -+until you specify otherwise. -+.SP -+Some of the more useful \fIkflag\fPs are \-ko and \-kb (for binary files), -+and \-kv which is useful for an -+.B export -+where you wish to retain keyword information after an -+.B import -+at some other site. -+.TP -+.B \-l -+Local; run only in current working directory, rather than recurring through -+subdirectories. Available with the following commands: -+.BR checkout ", " commit ", " diff ", " -+.BR export ", " remove ", " rdiff ", " rtag ", " -+.BR status ", " tag ", and " update . -+.TP -+.B \-n -+Do -+.I not -+run any -+.BR checkout / commit / tag / update -+program. (A program can be specified to run on each of these -+activities, in the modules database; this option bypasses it.) -+Available with the -+.BR checkout ", " commit ", " export ", and " -+.B rtag -+commands. -+.I Warning: -+this is not the same -+as the overall -+.` "cvs \-n" -+option, which you can specify to the -+.I left -+of a -+.B cvs -+command! -+.TP -+.B \-P -+Prune (remove) directories that are empty after being updated, on -+.BR checkout ", or " update . -+Normally, an empty directory (one that is void of revision-controlled -+files) is left alone. -+Specifying -+.B \-P -+will cause these directories to be silently removed from your checked-out -+sources. -+This does not remove the directory from the repository, only from your -+checked out copy. -+Note that this option is implied by the -+.B \-r -+or -+.B \-D -+options of -+.BR checkout " and " export . -+.TP -+.B \-T -+Create/Update CVS/Template by copying it from the (local) repository. -+This option is useful for developers maintaining a local cvs repository -+but committing to a remote repository. By maintaining CVS/Template the -+remote commits will still be able to bring up the proper template in the -+commit editor session. -+Available with the -+.BR checkout " and " update -+commands. -+.TP -+.B \-p -+Pipe the files retrieved from the repository to standard output, -+rather than writing them in the current directory. Available with the -+.BR checkout " and " update -+commands. -+.TP -+\fB\-r\fP \fItag\fP -+Use the revision specified by the -+.I tag -+argument instead of the default ``head'' revision. As well as -+arbitrary tags defined with the \fBtag\fP or \fBrtag\fP command, two -+special tags are always available: -+.` "HEAD" -+refers to the most -+recent version available in the repository, and -+.` "BASE" -+refers to the revision you last checked out into the current working -+directory. -+.SP -+The \fItag\fP specification is ``sticky'' when you use -+this option with -+.` "cvs checkout" -+or -+.` "cvs update" -+to -+make your own copy of a file: \fBcvs\fP remembers the \fItag\fP and -+continues to use it on future \fBupdate\fP commands, until you specify -+otherwise. -+.I tag -+can be either a symbolic or numeric tag. -+Specifying the -+.B \-q -+global option along with the -+.B \-r -+command option is often useful, to suppress the warning messages when the -+.SM RCS -+file does not contain the specified tag. -+.B \-r -+is available with the -+.BR checkout ", " commit ", " diff ", " -+.BR history ", " export ", " -+.BR rdiff ", " rtag ", and " update -+commands. -+.I Warning: -+this is not the same -+as the overall -+.` "cvs \-r" -+option, which you can specify to the -+.I left -+of a -+.B cvs -+command! -+.SH "CVS COMMANDS" -+Here (finally) are details on all the -+.B cvs -+commands and the options each accepts. The summary lines at the top -+of each command's description highlight three kinds of things: -+.TP 1i -+\ \ \ \ Command Options and Arguments -+Special options are described in detail below; common command options -+may appear only in the summary line. -+.TP 1i -+\ \ \ \ Working Directory, or Repository? -+Some \fBcvs\fP commands require a working directory to operate; some -+require a repository. Also, some commands \fIchange\fP the -+repository, some change the working directory, and some change -+nothing. -+.TP 1i -+\ \ \ \ Synonyms -+Many commands have synonyms, which you may find easier to -+remember (or type) than the principal name. -+.PP -+.TP -+\fBadd\fP [\fB\-k\fP \fIkflag\fP] [\fB\-m '\fP\fImessage\fP\fB'\fP] \fIfiles.\|.\|.\fP -+.I Requires: -+repository, working directory. -+.br -+.I Changes: -+working directory. -+.br -+.I Synonym: -+.B new -+.br -+Use the -+.B add -+command to create a new file or directory in the -+source repository. -+The files or directories specified with -+.B add -+must already exist in the current directory (which must have been created -+with the -+.B checkout -+command). -+To add a whole new directory hierarchy to the source repository -+(for example, files received from a third-party vendor), use the -+.` "cvs import" -+command instead. -+.SP -+If the argument to -+.` "cvs add" -+refers to an immediate sub-directory, the directory is -+created at the correct place in the -+source repository, and the necessary -+.B cvs -+administration files are created in your working directory. -+If the directory already exists in the source repository, -+.` "cvs add" -+still creates the administration files in your version of the directory. -+This allows you to use -+.` "cvs add" -+to add a particular directory to your private sources even if -+someone else created that directory after your -+.B checkout -+of the sources. You can do the following: -+.SP -+.in +1i -+.ft B -+.nf -+example% mkdir new_directory -+example% cvs add new_directory -+example% cvs update new_directory -+.fi -+.ft P -+.in -1i -+.SP -+An alternate approach using -+.` "cvs update" -+might be: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs update -d new_directory -+.fi -+.ft P -+.in -1i -+.SP -+(To add \fIany available\fP new directories to your working directory, it's -+probably simpler to use -+.` "cvs checkout" -+or -+.` "cvs update -d".) -+.SP -+The added files are not placed in the -+source repository until you use -+.` "cvs commit" -+to make the change permanent. -+Doing a -+.` "cvs add" -+on a file that was removed with the -+.` "cvs remove" -+command will resurrect the file, if no -+.` "cvs commit" -+command intervened. -+.SP -+You will have the opportunity to specify a logging message, as usual, -+when you use -+.` "cvs commit" -+to make the new file permanent. If you'd like to have another -+logging message associated with just -+.I creation -+of the file (for example, to describe the file's purpose), you can -+specify it with the -+.` "\-m \fImessage\fP" -+option to the -+.B add -+command. -+.SP -+The -+.` "-k kflag" -+option specifies the default way that this -+file will be checked out. -+The -+.` "kflag" -+argument is stored in the -+.SM RCS -+file and can be changed with -+.` "cvs admin". -+Specifying -+.` "-ko" -+is useful for checking in binaries that -+shouldn't have -+keywords expanded. -+.TP -+\fBadmin\fP [\fIrcs-options\fP] \fIfiles.\|.\|.\fP -+.I Requires: -+repository, working directory. -+.br -+.I Changes: -+repository. -+.br -+.I Synonym: -+.B rcs -+.br -+This is the -+.B cvs -+interface to assorted administrative -+facilities, similar to -+.BR rcs ( 1 ). -+This command works recursively, so extreme care should be -+used. -+.TP -+\fBcheckout\fP [\fBoptions\fP] \fImodules\fP.\|.\|. -+.I Requires: -+repository. -+.br -+.I Changes: -+working directory. -+.br -+.I Synonyms: -+.BR co ", " get -+.br -+Make a working directory containing copies of the source files specified by -+.IR modules . -+You must execute -+.` "cvs checkout" -+before using most of the other -+.B cvs -+commands, since most of them operate on your working directory. -+.SP -+\fImodules\fP are either symbolic names (themselves defined as the -+module -+.` "modules" -+in the source repository; see -+.BR cvs ( 5 )) -+for some collection of source directories and files, or paths to -+directories or files in the repository. -+.SP -+Depending on the -+.I modules -+you specify, -+.B checkout -+may recursively create directories and populate them with the appropriate -+source files. -+You can then edit these source files at any time (regardless of whether -+other software developers are editing their own copies of the sources); -+update them to include new changes applied by others to the source -+repository; or commit your work as a permanent change to the -+repository. -+.SP -+Note that -+.B checkout -+is used to create directories. -+The top-level directory created is always added to the directory -+where -+.B checkout -+is invoked, and usually has the same name as the specified -+.IR module . -+In the case of a -+.I module -+alias, the created sub-directory may have a different name, but you can be -+sure that it will be a sub-directory, and that -+.B checkout -+will show the relative path leading to each file as it is extracted into -+your private work area (unless you specify the -+.B \-Q -+global option). -+.SP -+Running -+.` "cvs checkout" -+on a directory that was already built by a prior -+.B checkout -+is also permitted, and -+has the same effect as specifying the -+.B \-d -+option to the -+.B update -+command described below. -+.SP -+The -+.I options -+permitted with -+.` "cvs checkout" -+include the standard command options -+.BR \-P ", " \-f ", " -+.BI \-k " kflag" -+\&, -+.BR \-l ", " \-n ", " \-p ", " -+.BR \-r -+.IR tag ", and" -+.BI \-D " date"\c -+\&. -+.SP -+In addition to those, you can use these special command options -+with -+.BR checkout : -+.SP -+Use the -+.B \-A -+option to reset any sticky tags, dates, or -+.B \-k -+options. (If you get a working file using one of the -+\fB\-r\fP, \fB\-D\fP, or \fB\-k\fP options, \fBcvs\fP remembers the -+corresponding tag, date, or \fIkflag\fP and continues using it on -+future updates; use the \fB\-A\fP option to make \fBcvs\fP forget these -+specifications, and retrieve the ``head'' version of the file). -+.SP -+The -+.BI \-j " branch" -+option merges the changes made between the -+resulting revision and the revision that it is based on (e.g., if -+the tag refers to a branch, -+.B cvs -+will merge all changes made in that branch into your working file). -+.SP -+With two \fB-j\fP options, -+.B cvs -+will merge in the changes between the two respective revisions. -+This can be used to ``remove'' a certain delta from your working file. -+.SP -+In addition, each \fB-j\fP option can contain on optional date -+specification which, when used with branches, can limit the chosen -+revision to one within a specific date. -+An optional date is specified by adding a colon (:) to the tag. -+An example might be what -+.` "cvs import" -+tells you to do when you have -+just imported sources that have conflicts with local changes: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs checkout -jTAG:yesterday -jTAG module -+.fi -+.ft P -+.in -1i -+.SP -+Use the -+.B \-N -+option with -+.` "\-d \fIdir\fP" -+to avoid shortening module paths in your working directory. (Normally, \fBcvs\fP shortens paths as much as possible when you specify an explicit target directory.) -+.SP -+Use the -+.B \-c -+option to copy the module file, sorted, to the standard output, -+instead of creating or modifying any files or directories in your -+working directory. -+.SP -+Use the -+.BI \-d " dir" -+option to create a directory called -+.I dir -+for the working files, instead of using the module name. Unless you -+also use \fB\-N\fP, the paths created under \fIdir\fP will be as short -+as possible. -+.SP -+Use the -+.B \-s -+option to display per-module status information stored with -+the -+.B \-s -+option within the modules file. -+.TP -+\fBcommit\fP [\fB\-lnR\fP] [\fB\-m\fP '\fIlog_message\fP' | \fB\-F\fP \fIfile\fP] [\fB\-r\fP \fIrevision\fP] [\fIfiles.\|.\|.\fP] -+.I Requires: -+working directory, repository. -+.br -+.I Changes: -+repository. -+.br -+.I Synonym: -+.B ci -+.br -+Use -+.` "cvs commit" -+when you want to incorporate changes from your working source -+files into the general source repository. -+.SP -+If you don't specify particular \fIfiles\fP to commit, all -+of the files in your working current directory are examined. -+.B commit -+is careful to change in the repository only those files that you have -+really changed. By default (or if you explicitly specify the -+.B \-R -+option), files -+in subdirectories are also examined and committed if they have -+changed; you can use the -+.B \-l -+option to limit -+.B commit -+to the current directory only. -+Sometimes you may want to force a file to be committed even though it -+is unchanged; this is achieved with the -+.B \-f -+flag, which also has the effect of disabling recursion (you can turn -+it back on with -+.B \-R -+of course). -+.SP -+.B commit -+verifies that the selected files are up to date with the current revisions -+in the source repository; it will notify you, and exit without -+committing, if any of the specified files must be made current first -+with -+.` "cvs update". -+.B commit -+does not call the -+.B update -+command for you, but rather leaves that for you to do when -+the time is right. -+.SP -+When all is well, an editor is invoked to allow you to enter a log -+message that will be written to one or more logging programs and placed in the -+source repository file. -+You can instead specify the log message on the command line with the -+.B \-m -+option, thus suppressing the editor invocation, or use the -+.B \-F -+option to specify that the argument \fIfile\fP contains the log message. -+.SP -+The -+.B \-r -+option can be used to commit to a particular symbolic or numeric revision. -+For example, to bring all your files up to the -+revision ``3.0'' (including those that haven't changed), you might do: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs commit -r3.0 -+.fi -+.ft P -+.in -1i -+.SP -+.B cvs -+will only allow you to commit to a revision that is on the main trunk (a -+revision with a single dot). -+However, you can also commit to a branch revision (one that has an even -+number of dots) with the -+.B \-r -+option. -+To create a branch revision, one typically use the -+.B \-b -+option of the -+.BR rtag " or " tag -+commands. -+Then, either -+.BR checkout " or " update -+can be used to base your sources on the newly created branch. -+From that point on, all -+.B commit -+changes made within these working sources will be automatically added -+to a branch revision, thereby not perturbing main-line development in any -+way. -+For example, if you had to create a patch to the 1.2 version of the -+product, even though the 2.0 version is already under development, you -+might do: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs rtag -b -rFCS1_2 FCS1_2_Patch product_module -+example% cvs checkout -rFCS1_2_Patch product_module -+example% cd product_module -+[[ hack away ]] -+example% cvs commit -+.fi -+.ft P -+.in -1i -+.SP -+Say you have been working on some extremely experimental software, based on -+whatever revision you happened to checkout last week. -+If others in your group would like to work on this software with you, but -+without disturbing main-line development, you could commit your change to a -+new branch. -+Others can then checkout your experimental stuff and utilize the full -+benefit of -+.B cvs -+conflict resolution. -+The scenario might look like: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs tag -b EXPR1 -+example% cvs update -rEXPR1 -+[[ hack away ]] -+example% cvs commit -+.fi -+.ft P -+.in -1i -+.SP -+Others would simply do -+.` "cvs checkout -rEXPR1 whatever_module" -+to work with you on the experimental change. -+.TP -+\fBdiff\fP [\fB\-kl\fP] [\fIformat_options\fP] [[\fB\-r\fP \fIrev1\fP | \fB\-D\fP \fIdate1\fP | \fB\-j\fP \fIrev1:date1\fP] [\fB\-r\fP \fIrev2\fP | \fB\-D\fP \fIdate2\fP | \fB\-j\fP \fIrev2:date2\fP]] [\fIfiles.\|.\|.\fP] -+.I Requires: -+working directory, repository. -+.br -+.I Changes: -+nothing. -+.br -+You can compare your working files with revisions in the source -+repository, with the -+.` "cvs diff" -+command. If you don't specify a particular revision, your files -+are compared with the revisions they were based on. You can also use -+the standard -+.B cvs -+command option -+.B \-r -+to specify a particular revision to compare your files with. Finally, -+if you use -+.B \-r -+twice, you can see differences between two revisions in the -+repository. -+You can also specify -+.B \-D -+options to diff against a revision (on the head branch) in the past, and -+you can also specify -+.B \-j -+options to diff against a revision relative to a branch tag in the past. -+The -+.B \-r -+and -+.B \-D -+and -+.B \-j -+options can be mixed together with at most two options ever specified. -+.SP -+See -+.` "cvs --help diff" -+for a list of supported -+.IR format_options . -+.SP -+If you don't specify any files, -+.B diff -+will display differences for all those files in the current directory -+(and its subdirectories, unless you use the standard option -+.BR \-l ) -+that -+differ from the corresponding revision in the source repository -+(i.e. files that -+.I you -+have changed), or that differ from the revision specified. -+.TP -+\fBexport\fP [\-\fBf\|lNnQq\fP] \fB\-r\fP \fIrev\fP\||\|\fB\-D\fP \fIdate\fP [\fB\-d\fP \fIdir\fP] [\fB\-k\fP \fIkflag\fP] \fImodule\fP.\|.\|. -+.I Requires: -+repository. -+.br -+.I Changes: -+current directory. -+.br -+This command is a variant of -+.` "cvs checkout"; -+use it when you want a copy of the source for \fImodule\fP -+without the \fBcvs\fP administrative directories. For example, you -+might use -+.` "cvs export" -+to prepare source for shipment -+off-site. This command \fIrequires\fP that you specify a date or tag -+(with \fB\-D\fP or \fB\-r\fP), so that you can count on reproducing -+the source you ship to others. -+.SP -+The only non-standard options are -+.` "\-d \fIdir\fP" -+(write the -+source into directory \fIdir\fP) and -+.` "\-N" -+(don't shorten -+module paths). -+These have the same meanings as the same options in -+.` "cvs checkout". -+.SP -+The -+.B \-kv -+option is useful when -+.B export -+is used. -+This causes any -+keywords to be expanded such that an -+.B import -+done at some other site will not lose the keyword revision information. -+Other \fIkflag\fPs may be used with -+.` "cvs export" -+and are described in -+.BR co ( 1 ). -+.TP -+\fBhistory\fP [\fB\-\fP\fIreport\fP] [\fB\-\fP\fIflags\fP] [\fB\-\fP\fIoptions args\fP] [\fIfiles\fP.\|.\|.] -+.I Requires: -+the file -+.` "$CVSROOT/CVSROOT/history" -+.br -+.I Changes: -+nothing. -+.br -+\fBcvs\fP keeps a history file that tracks each use of the -+\fBcheckout\fP, \fBcommit\fP, \fBrtag\fP, \fBupdate\fP, and \fBrelease\fP -+commands. You can use -+.` "cvs history" -+to display this -+information in various formats. -+.SP -+.I Warning: -+.` "cvs history" -+uses -+.` "\-f", -+.` "\-l", -+.` "\-n", -+and -+.` "\-p" -+in ways that conflict with the -+descriptions in -+.SM -+COMMON COMMAND OPTIONS\c -+\&. -+.SP -+Several options (shown above as \fB\-\fP\fIreport\fP) control what -+kind of report is generated: -+.TP 1i -+.B \ \ \ \ \ \ \-c -+Report on each time \fBcommit\fP was used (i.e., each time the -+repository was modified). -+.TP 1i -+\fB\ \ \ \ \ \ \-m\fP \fImodule\fP -+Report on a particular \fImodule\fP. (You can meaningfully use -+\fB\-m\fP more than once on the command line.) -+.TP 1i -+.B \ \ \ \ \ \ \-o -+Report on checked-out modules. -+.TP 1i -+.B \ \ \ \ \ \ \-T -+Report on all tags. -+.TP 1i -+\fB\ \ \ \ \ \ \-x\fP \fItype\fP -+Extract a particular set of record types \fIX\fP from the \fBcvs\fP -+history. The types are indicated by single letters, which you may -+specify in combination. -+Certain commands have a single record type: \fBcheckout\fP (type `O'), -+\fBrelease\fP (type `F'), and \fBrtag\fP (type `T'). One of four -+record types may result from an \fBupdate\fP: `W', when the working copy -+of a file is deleted during update (because it was gone from the -+repository); `U', when a working file was copied from the -+repository; `G', when a merge was necessary and it succeeded; and 'C', -+when a merge was necessary but collisions were detected (requiring -+manual merging). Finally, one of three record types results from -+\fBcommit\fP: `M', when a file was modified; `A', when a file is first -+added; and `R', when a file is removed. -+.TP 1i -+.B \ \ \ \ \ \ \-e -+Everything (all record types); equivalent to specifying -+.` "\-xMACFROGWUT". -+.TP 1i -+\fB\ \ \ \ \ \ \-z\fP \fIzone\fP -+Use time zone -+.I zone -+when outputting history records. -+The zone name -+.B LT -+stands for local time; -+numeric offsets stand for hours and minutes ahead of UTC. -+For example, -+.B +0530 -+stands for 5 hours and 30 minutes ahead of (i.e. east of) UTC. -+.PP -+.RS .5i -+The options shown as \fB\-\fP\fIflags\fP constrain the report without -+requiring option arguments: -+.RE -+.TP 1i -+.B \ \ \ \ \ \ \-a -+Show data for all users (the default is to show data only for the user -+executing -+.` "cvs history"). -+.TP 1i -+.B \ \ \ \ \ \ \-l -+Show last modification only. -+.TP 1i -+.B \ \ \ \ \ \ \-w -+Show only the records for modifications done from the same working -+directory where -+.` "cvs history" -+is executing. -+.PP -+.RS .5i -+The options shown as \fB\-\fP\fIoptions args\fP constrain the report -+based on an argument: -+.RE -+.TP 1i -+\fB\ \ \ \ \ \ \-b\fP \fIstr\fP -+Show data back to a record containing the string \fIstr\fP in either -+the module name, the file name, or the repository path. -+.TP 1i -+\fB\ \ \ \ \ \ \-D\fP \fIdate\fP -+Show data since \fIdate\fP. -+.TP 1i -+\fB\ \ \ \ \ \ \-p\fP \fIrepository\fP -+Show data for a particular source repository (you can specify several -+\fB\-p\fP options on the same command line). -+.TP 1i -+\fB\ \ \ \ \ \ \-r\fP \fIrev\fP -+Show records referring to revisions since the revision or tag -+named \fIrev\fP appears in individual RCS files. -+Each -+.SM RCS -+file is searched for the revision or tag. -+.TP 1i -+\fB\ \ \ \ \ \ \-t\fP \fItag\fP -+Show records since tag \fItag\fP was last added to the history file. -+This differs from the \fB-r\fP flag above in that it reads -+only the history file, not the -+.SM RCS -+files, and is much faster. -+.TP 1i -+\fB\ \ \ \ \ \ \-u\fP \fIname\fP -+Show records for user \fIname\fP. -+.PP -+.TP -+\fBimport\fP [\fB\-\fP\fIoptions\fP] \fIrepository vendortag releasetag\fP.\|.\|. -+.I Requires: -+Repository, source distribution directory. -+.br -+.I Changes: -+repository. -+.br -+Use -+.` "cvs import" -+to incorporate an entire source -+distribution from an outside source (e.g., a source vendor) into your -+source repository directory. You can use this command both for -+initial creation of a repository, and for wholesale updates to the -+module form the outside source. -+.SP -+The \fIrepository\fP argument gives a directory name (or a path to a -+directory) under the CVS root directory for repositories; if the -+directory did not exist, \fBimport\fP creates it. -+.SP -+When you use \fBimport\fP for updates to source that has been modified in your -+source repository (since a prior \fBimport\fP), it -+will notify you of any files that conflict in the two branches of -+development; use -+.` "cvs checkout -j" -+to reconcile the differences, as \fBimport\fP instructs you to do. -+.SP -+By default, certain file names are ignored during -+.` "cvs import": -+names associated with -+.SM CVS -+administration, or with other common source control systems; common -+names for patch files, object files, archive files, and editor backup -+files; and other names that are usually artifacts of assorted utilities. -+For an up to date list of ignored file names, see the Cederqvist manual (as -+described in the SEE ALSO section of this manpage). -+.SP -+The outside source is saved in a first-level -+branch, by default -+.` "1.1.1". -+Updates are leaves of this -+branch; for example, files from the first imported collection of -+source will be revision -+.` "1.1.1.1", -+then files from the first -+imported update will be revision -+.` "1.1.1.2", -+and so on. -+.SP -+At least three arguments are required. \fIrepository\fP is needed to -+identify the collection of source. \fIvendortag\fP is a tag for the -+entire branch (e.g., for -+.` "1.1.1"). -+You must also specify at -+least one \fIreleasetag\fP to identify the files at the leaves created -+each time you execute -+.` "cvs import". -+.SP -+One of the standard -+.B cvs -+command options is available: \fB\-m\fP -+\fImessage\fP. If you do not specify a logging message with -+\fB\-m\fP, your editor is invoked (as with \fBcommit\fP) to allow you -+to enter one. -+.SP -+There are three additional special options. -+.SP -+Use -+.` "\-d" -+to specify that each file's time of last modification should be used -+for the checkin date and time. -+.SP -+Use -+.` "\-b \fIbranch\fP" -+to specify a first-level branch other -+than -+.` "1.1.1". -+.SP -+Use -+.` "\-I \fIname\fP" -+to specify file names that should be -+ignored during \fBimport\fP. You can use this option repeatedly. -+To avoid ignoring any files at all (even those ignored by default), -+specify -+.` "\-I !". -+.TP -+\fBlog\fP [\fB\-l\fP] \fIrlog-options [files\fP\|.\|.\|.] -+.I Requires: -+repository, working directory. -+.br -+.I Changes: -+nothing. -+.br -+.I Synonym: -+.B rlog -+.br -+Display log information for \fIfiles\fP. -+Among the more useful options are \fB\-h\fP -+to display only the header (including tag definitions, but omitting -+most of the full log); \fB\-r\fP to select logs on particular -+revisions or ranges of revisions; and \fB\-d\fP to select particular -+dates or date ranges. See -+.BR rlog ( 1 ) -+for full explanations. -+This command is recursive by default, unless the -+.B \-l -+option is specified. -+.TP -+\fBrdiff\fP [\fB\-\fP\fIflags\fP] [\fB\-V\fP \fIvn\fP] [\fB\-r\fP \fIt\fP|\fB\-D\fP \fId\fP [\fB\-r\fP \fIt2\fP|\fB\-D\fP \fId2\fP]] \fImodules\|.\|.\|.\fP -+.I Requires: -+repository. -+.br -+.I Changes: -+nothing. -+.br -+.I Synonym: -+.B patch -+.br -+Builds a Larry Wall format -+.BR patch ( 1 ) -+file between two releases, that can be fed directly into the -+.B patch -+program to bring an old release up-to-date with the new release. -+(This is one of the few \fBcvs\fP commands that operates directly from -+the repository, and doesn't require a prior -+.BR checkout .) -+The diff output is sent to the standard output device. -+You can specify (using the standard \fB\-r\fP and \fB\-D\fP options) -+any combination of one or two revisions or dates. -+If only one revision or date is specified, the -+patch file reflects differences between that revision or date and the -+current ``head'' revisions in the -+.SM RCS -+file. -+.SP -+Note that if the software release affected -+is contained in more than one directory, then it may be necessary to -+specify the -+.B \-p -+option to the -+.B patch -+command when patching the old sources, so that -+.B patch -+is able to find the files that are located in other directories. -+.SP -+The standard option \fIflags\fP \fB\-f\fP, and \fB\-l\fP -+are available with this command. There are also several -+special option flags: -+.SP -+If you use the -+.B \-s -+option, no patch output is produced. -+Instead, a summary of the changed or added files between the two -+releases is sent to the standard output device. -+This is useful for finding out, for example, which files have changed -+between two dates or revisions. -+.SP -+If you use the -+.B \-t -+option, a diff of the top two revisions is sent to the standard output device. -+This is most useful for seeing what the last change to a file was. -+.SP -+If you use the -+.B \-u -+option, the patch output uses the newer ``unidiff'' format for context -+diffs. -+.SP -+You can use -+.B \-c -+to explicitly specify the -+.` "diff \-c" -+form of context diffs -+(which is the default), if you like. -+.TP -+\fBrelease\fP [\fB\-dQq\fP] \fImodules\fP\|.\|.\|. -+.I Requires: -+Working directory. -+.br -+.I Changes: -+Working directory, history log. -+.br -+This command is meant to safely cancel the effect of -+.` "cvs checkout". -+Since -+.B cvs -+doesn't lock files, it isn't strictly necessary to use this command. -+You can always simply delete your working directory, if you -+like; but you risk losing changes you may have forgotten, and you -+leave no trace in the -+.B cvs -+history file that you've abandoned your checkout. -+.SP -+Use -+.` "cvs release" -+to avoid these problems. This command -+checks that no un-committed changes are present; that you are -+executing it from immediately above, or inside, a \fBcvs\fP working -+directory; and that the repository recorded for your files is the same -+as the repository defined in the module database. -+.SP -+If all these conditions are true, -+.` "cvs release" -+leaves a -+record of its execution (attesting to your intentionally abandoning -+your checkout) in the -+.B cvs -+history log. -+.SP -+You can use the \fB\-d\fP flag to request that your working copies of -+the source files be deleted if the \fBrelease\fP succeeds. -+.TP -+\fBremove\fP [\fB\-lR\fP] [\fIfiles\|.\|.\|.\fP] -+.I Requires: -+Working directory. -+.br -+.I Changes: -+Working directory. -+.br -+.I Synonyms: -+.BR rm ", " delete -+.br -+Use this command to declare that you wish to remove \fIfiles\fP from -+the source repository. Like most -+.B cvs -+commands, -+.` "cvs remove" -+works on files in your working -+directory, not directly on the repository. As a safeguard, it also -+requires that you first erase the specified files from your working -+directory. -+.SP -+The files are not actually removed until you apply your changes to the -+repository with -+.BR commit ; -+at that point, the corresponding -+.SM RCS -+files in the source repository are -+.I moved -+into the -+.` "Attic" -+directory (also within the source repository). -+.SP -+This command is recursive by default, scheduling all physically removed -+files that it finds for removal by the next -+.BR commit . -+Use the -+.B \-l -+option to avoid this recursion, or just specify that actual files that you -+wish remove to consider. -+.TP -+\fBrtag\fP [\fB\-f\|alnRQq\fP] [\fB\-b\fP] [\fB\-d\fP] [\fB\-r\fP \fItag\fP | \fB\-D\fP \fIdate\fP] \fIsymbolic_tag\fP \fImodules\|.\|.\|.\fP -+.I Requires: -+repository. -+.br -+.I Changes: -+repository. -+.br -+.I Synonym: -+.B rfreeze -+.br -+You can use this command to assign symbolic tags to particular, -+explicitly specified source versions in the repository. -+.` "cvs rtag" -+works directly on the repository contents (and requires no -+prior -+.BR checkout ). -+Use -+.` "cvs tag" -+instead, to base the selection of -+versions to tag on the contents of your working directory. -+.SP -+In general, tags (often the symbolic names of software distributions) -+should not be removed, but the -+.B \-d -+option is available as a means to remove completely obsolete symbolic names -+if necessary (as might be the case for an Alpha release, say). -+.SP -+.` "cvs rtag" -+will not move a tag that already exists. With the \fB\-F\fP option, -+however, -+.` "cvs rtag" -+will re-locate any instance of \fIsymbolic_tag\fP that already exists -+on that file to the new repository versions. Without the \fB\-F\fP -+option, attempting to use -+.` "cvs rtag" -+to apply a tag that already exists on that file will produce an error -+message. -+.SP -+The \fB-b\fP option makes the tag a ``branch'' tag, allowing -+concurrent, isolated development. -+This is most useful for creating a patch to a previously released software -+distribution. -+.SP -+You can use the standard \fB\-r\fP and \fB\-D\fP options to tag only those -+files that already contain a certain tag. This method would be used -+to rename a tag: tag only the files identified by the old tag, then delete the -+old tag, leaving the new tag on exactly the same files as the old tag. -+.SP -+.B rtag -+executes recursively by default, tagging all subdirectories of -+\fImodules\fP you specify in the argument. You can restrict its -+operation to top-level directories with the standard \fB\-l\fP option; -+or you can explicitly request recursion with \fB\-R\fP. -+.SP -+The modules database can specify a program to execute whenever a tag -+is specified; a typical use is to send electronic mail to a group of -+interested parties. If you want to bypass that program, use the -+standard \fB\-n\fP option. -+.SP -+Use the -+.B \-a -+option to have -+.B rtag -+look in the -+.` "Attic" -+for removed files that contain the specified tag. -+The tag is removed from these files, which makes it convenient to re-use a -+symbolic tag as development continues (and files get removed from the -+up-coming distribution). -+.TP -+\fBstatus\fP [\fB\-lRqQ\fP] [\fB\-v\fP] [\fIfiles\fP\|.\|.\|.] -+.I Requires: -+working directory, repository. -+.br -+.I Changes: -+nothing. -+.br -+Display a brief report on the current status of \fIfiles\fP with -+respect to the source repository, including any ``sticky'' tags, -+dates, or \fB\-k\fP options. (``Sticky'' options will restrict how -+.` "cvs update" -+operates until you reset them; see the -+description of -+.` "cvs update \-A\|.\|.\|.".) -+.SP -+You can also use this command to anticipate the potential impact of a -+.` "cvs update" -+on your working source directory. If you do -+not specify any \fIfiles\fP explicitly, reports are shown for all -+files that \fBcvs\fP has placed in your working directory. You can -+limit the scope of this search to the current directory itself (not -+its subdirectories) with the standard \fB\-l\fP option flag; or you -+can explicitly request recursive status reports with the \fB\-R\fP -+option. -+.SP -+The -+.B \-v -+option causes the symbolic tags for the -+.SM RCS -+file to be displayed as well. -+.TP -+\fBtag\fP [\fB\-lQqR\fP] [\fB\-F\fP] [\fB\-b\fP] [\fB\-d\fP] [\fB\-r\fP \fItag\fP | \fB\-D\fP \fIdate\fP] [\fB\-f\fP] \fIsymbolic_tag\fP [\fIfiles\fP\|.\|.\|.\|] -+.I Requires: -+working directory, repository. -+.br -+.I Changes: -+repository. -+.br -+.I Synonym: -+.B freeze -+.br -+Use this command to assign symbolic tags to the nearest repository -+versions to your working sources. The tags are applied immediately to -+the repository, as with \fBrtag\fP. -+.SP -+One potentially surprising aspect of the fact that \fBcvs tag\fP -+operates on the repository is that you are tagging the checked-in -+revisions, which may differ from locally modified files in your working -+directory. If you want to avoid doing this by mistake, specify the -+\fB-c\fP option to \fBcvs tag\fP. If there are any locally modified files, CVS -+will abort with an error before it tags any files. -+.SP -+One use for tags is to record a ``snapshot'' of the current sources -+when the software freeze date of a project arrives. As bugs are fixed -+after the freeze date, only those changed sources that are to be part -+of the release need be re-tagged. -+.SP -+The symbolic tags are meant to permanently record which revisions of which -+files were used in creating a software distribution. -+The -+.BR checkout , -+.B export -+and -+.B update -+commands allow you to extract an exact copy of a tagged release at any time in -+the future, regardless of whether files have been changed, added, or removed -+since the release was tagged. -+.SP -+You can use the standard \fB\-r\fP and \fB\-D\fP options to tag only those -+files that already contain a certain tag. This method would be used -+to rename a tag: tag only the files identified by the old tag, then delete the -+old tag, leaving the new tag on exactly the same files as the old tag. -+.SP -+Specifying the \fB\-f\fP flag in addition to the \fB\-r\fP or \fB\-D\fP -+flags will tag those files named on the command line even if they do not -+contain the old tag or did not exist on the specified date. -+.SP -+By default (without a \fB\-r\fP or \fB\-D\fP flag) -+the versions to be tagged are supplied -+implicitly by the \fBcvs\fP records of your working files' history -+rather than applied explicitly. -+.SP -+If you use -+.` "cvs tag \-d \fIsymbolic_tag\fP\|.\|.\|.", -+the -+symbolic tag you specify is -+.I deleted -+instead of being added. \fIWarning\fP: Be very certain of your ground -+before you delete a tag; doing this effectively discards some -+historical information, which may later turn out to have been valuable. -+.SP -+.` "cvs tag" -+will not move a tag that already exists. With the \fB\-F\fP option, -+however, -+.` "cvs tag" -+will re-locate any instance of \fIsymbolic_tag\fP that already exists -+on that file to the new repository versions. Without the \fB\-F\fP -+option, attempting to use -+.` "cvs tag" -+to apply a tag that already exists on that file will produce an error -+message. -+.SP -+The \fB-b\fP option makes the tag a ``branch'' tag, allowing -+concurrent, isolated development. -+This is most useful for creating a patch to a previously released software -+distribution. -+.SP -+Normally, -+.B tag -+executes recursively through subdirectories; you can prevent this by -+using the standard \fB\-l\fP option, or specify the recursion -+explicitly by using \fB\-R\fP. -+.TP -+\fBupdate\fP [\fB\-ACdf\|lPpQqR\fP] [\fB\-d\fP] [\fB\-r\fP \fItag\fP|\fB\-D\fP \fIdate\fP] \fIfiles\|.\|.\|.\fP -+.I Requires: -+repository, working directory. -+.br -+.I Changes: -+working directory. -+.br -+After you've run -+.B checkout -+to create your private copy of source from the common repository, -+other developers will continue changing the central source. From time -+to time, when it is convenient in your development process, you can -+use the -+.B update -+command -+from within your working directory to reconcile your work with any -+revisions applied to the source repository since your last -+.B checkout -+or -+.BR update . -+.SP -+.B update -+keeps you informed of its progress by printing a line for each file, -+prefaced with one of the characters -+.` "U P A R M C ?" -+to indicate the status of the file: -+.TP 1i -+\fBU\fP \fIfile\fP -+The file was brought \fIup to date\fP with respect to the repository. -+This is done for any file that exists in the repository but not in -+your source, and for files that you haven't changed but are not the most -+recent versions available in the repository. -+.TP 1i -+\fBP\fP \fIfile\fP -+Like \fBU\fP, but the CVS server sends a patch instead of an entire file. -+This accomplishes the same thing as \fBU\fP using less bandwidth. -+.TP 1i -+\fBA\fP \fIfile\fP -+The file has been \fIadded\fP to your private copy of the sources, and -+will be added to the -+source repository when you run -+.` "cvs commit" -+on the file. -+This is a reminder to you that the file needs to be committed. -+.TP 1i -+\fBR\fP \fIfile\fP -+The file has been \fIremoved\fP from your private copy of the sources, and -+will be removed from the -+source repository when you run -+.` "cvs commit" -+on the file. -+This is a reminder to you that the file needs to be committed. -+.TP 1i -+\fBM\fP \fIfile\fP -+The file is \fImodified\fP in your working directory. -+.` "M" -+can indicate one of two states for a file you're working on: either -+there were no modifications to the same file in the repository, so -+that your file remains as you last saw it; or there were modifications -+in the repository as well as in your copy, but they were -+\fImerged\fP successfully, without conflict, in your working -+directory. -+.TP 1i -+\fBC\fP \fIfile\fP -+A \fIconflict\fP was detected while trying to merge your changes to -+\fIfile\fP with changes from the source repository. \fIfile\fP (the -+copy in your working directory) is now the result of merging -+the two versions; an unmodified copy of your file is also -+in your working directory, with the name `\fB.#\fP\fIfile\fP\fB.\fP\fIversion\fP', -+where -+.I version -+is the -+revision that your modified file started from. -+(Note that some systems automatically purge files that begin with -+\& -+.` ".#" -+if they have not been accessed for a few days. -+If you intend to keep a copy of your original file, it is a very good -+idea to rename it.) -+.TP 1i -+\fB?\fP \fIfile\fP -+\fIfile\fP is in your working directory, but does not correspond to -+anything in the source repository, and is not in the list of files -+for \fBcvs\fP to ignore (see the description of the \fB\-I\fP option). -+.PP -+.RS .5i -+.SP -+Use the -+.B \-A -+option to reset any sticky tags, dates, or -+.B \-k -+options. (If you get a working copy of a file by using one of the -+\fB\-r\fP, \fB\-D\fP, or \fB\-k\fP options, \fBcvs\fP remembers the -+corresponding tag, date, or \fIkflag\fP and continues using it on -+future updates; use the \fB\-A\fP option to make \fBcvs\fP forget these -+specifications, and retrieve the ``head'' version of the file). -+.SP -+The \fB\-j\fP\fIbranch\fP option -+merges the changes made between the -+resulting revision and the revision that it is based on (e.g., if -+the tag refers to a branch, -+.B cvs -+will merge all changes made in -+that branch into your working file). -+.SP -+With two \fB-j\fP options, -+.B cvs -+will merge in the changes between the two respective revisions. -+This can be used to ``remove'' a certain delta from your working file. -+E.g., If the file foo.c is based on -+revision 1.6 and I want to remove the changes made between 1.3 and -+1.5, I might do: -+.SP -+.in +1i -+.ft B -+.nf -+example% cvs update -j1.5 -j1.3 foo.c # note the order... -+.fi -+.ft P -+.in -1i -+.SP -+In addition, each \fB-j\fP option can contain on optional date -+specification which, when used with branches, can limit the chosen -+revision to one within a specific date. -+An optional date is specified by adding a colon (:) to the tag. -+.SP -+.in +1i -+.ft B -+.nf -+-jSymbolic_Tag:Date_Specifier -+.fi -+.ft P -+.in -1i -+.SP -+Use the -+.B \-d -+option to create any directories that exist in the repository if they're -+missing from the working directory. (Normally, update acts only on -+directories and files that were already enrolled in your -+working directory.) This is useful for updating directories -+that were created in the repository since the initial -+\fBcheckout\fP; but it has an unfortunate side effect. If you -+deliberately avoided certain directories in the repository when you -+created your working directory (either through use of a module name or by -+listing explicitly the files and directories you wanted on the -+command line), then updating with -+.B \-d -+will create those directories, which may not be what you want. -+.SP -+Use \fB\-I\fP \fIname\fP to ignore files whose names match \fIname\fP -+(in your working directory) during the update. You can specify -+\fB\-I\fP more than once on the command line to specify several files -+to ignore. By default, -+\fBupdate\fP ignores files whose names match certain patterns; for -+an up to date list of ignored file names, see the Cederqvist manual (as -+described in the SEE ALSO section of this manpage). -+.SP -+Use -+.` "\-I !" -+to avoid ignoring any files at all. -+.SP -+Use the -+.` "\-C" -+option to overwrite locally modified files with clean copies from -+the repository (the modified file is saved in -+`\fB.#\fP\fIfile\fP\fB.\fP\fIrevision\fP', however). -+.SP -+The standard \fBcvs\fP command options \fB\-f\fP, \fB\-k\fP, -+\fB\-l\fP, \fB\-P\fP, \fB\-p\fP, and \fB\-r\fP -+are also available with \fBupdate\fP. -+.RE -+.SH "FILES" -+For more detailed information on -+.B cvs -+supporting files, see -+.BR cvs ( 5 ). -+.LP -+.I -+Files in home directories: -+.TP -+\&.cvsrc -+The -+.B cvs -+initialization file. Lines in this file can be used to specify default -+options for each -+.B cvs -+command. For example the line -+.` "diff \-c" -+will ensure that -+.` "cvs diff" -+is always passed the -+.B \-c -+option in addition to any other options passed on the command line. -+.TP -+\&.cvswrappers -+Specifies wrappers to be used in addition to those specified in the -+CVSROOT/cvswrappers file in the repository. -+.LP -+.I -+Files in working directories: -+.TP -+CVS -+A directory of \fBcvs\fP administrative files. -+.I -+Do not delete. -+.TP -+CVS/Entries -+List and status of files in your working directory. -+.TP -+CVS/Entries.Backup -+A backup of -+.` "CVS/Entries". -+.TP -+CVS/Entries.Static -+Flag: do not add more entries on -+.` "cvs update". -+.TP -+CVS/Root -+Pathname to the repository ( -+.SM CVSROOT -+) location at the time of checkout. This file is used instead -+of the -+.SM CVSROOT -+environment variable if the environment variable is not -+set. A warning message will be issued when the contents of this -+file and the -+.SM CVSROOT -+environment variable differ. The file may be over-ridden by the -+presence of the -+.SM CVS_IGNORE_REMOTE_ROOT -+environment variable. -+.TP -+CVS/Repository -+Pathname to the corresponding directory in the source repository. -+.TP -+CVS/Tag -+Contains the per-directory ``sticky'' tag or date information. -+This file is created/updated when you specify -+.B \-r -+or -+.B \-D -+to the -+.B checkout -+or -+.B update -+commands, and no files are specified. -+.TP -+CVS/Checkin.prog -+Name of program to run on -+.` "cvs commit". -+.TP -+CVS/Update.prog -+Name of program to run on -+.` "cvs update". -+.LP -+.I -+Files in source repositories: -+.TP -+$CVSROOT/CVSROOT -+Directory of global administrative files for repository. -+.TP -+CVSROOT/commitinfo,v -+Records programs for filtering -+.` "cvs commit" -+requests. -+.TP -+CVSROOT/cvswrappers,v -+Records -+.B cvs -+wrapper commands to be used when checking files into and out of the -+repository. Wrappers allow the file or directory to be processed -+on the way in and out of CVS. The intended uses are many, one -+possible use would be to reformat a C file before the file is checked -+in, so all of the code in the repository looks the same. -+.TP -+CVSROOT/editinfo,v -+Records programs for editing/validating -+.` "cvs commit" -+log entries. -+.TP -+CVSROOT/history -+Log file of \fBcvs\fP transactions. -+.TP -+CVSROOT/loginfo,v -+Records programs for piping -+.` "cvs commit" -+log entries. -+.TP -+CVSROOT/modules,v -+Definitions for modules in this repository. -+.TP -+CVSROOT/rcsinfo,v -+Records pathnames to templates used during a -+.` "cvs commit" -+operation. -+.TP -+CVSROOT/taginfo,v -+Records programs for validating/logging -+.` "cvs tag" -+and -+.` "cvs rtag" -+operations. -+.TP -+MODULE/Attic -+Directory for removed source files. -+.TP -+#cvs.lock -+A lock directory created by -+.B cvs -+when doing sensitive changes to the -+source repository. -+.TP -+#cvs.tfl.\fIpid\fP -+Temporary lock file for repository. -+.TP -+#cvs.rfl.\fIpid\fP -+A read lock. -+.TP -+#cvs.wfl.\fIpid\fP -+A write lock. -+.SH "ENVIRONMENT" -+.TP -+.SM CVSROOT -+Should contain the full pathname to the root of the -+.B cvs -+source repository (where the -+.SM RCS -+files are kept). This information must be available to \fBcvs\fP for -+most commands to execute; if -+.SM CVSROOT -+is not set, or if you wish to override it for one invocation, you can -+supply it on the command line: -+.` "cvs \-d \fIcvsroot cvs_command\fP\|.\|.\|." -+You may not need to set -+.SM CVSROOT -+if your \fBcvs\fP binary has the right path compiled in. -+.TP -+.SM CVSREAD -+If this is set, -+.B checkout -+and -+.B update -+will try hard to make the files in your working directory read-only. -+When this is not set, the default behavior is to permit modification -+of your working files. -+.TP -+.SM CVSREADONLYFS -+If this is set, the -+.B \-R -+option is assumed, and -+.B cvs -+operates in read-only repository mode. -+.TP -+.SM RCSBIN -+Specifies the full pathname where to find -+.SM RCS -+programs, such as -+.BR co ( 1 ) -+and -+.BR ci ( 1 ) -+(CVS 1.9 and older). -+.TP -+.SM CVSEDITOR -+Specifies the program to use for recording log messages during -+.BR commit . -+If not set, the -+.SM VISUAL -+and -+.SM EDITOR -+environment variables are tried (in that order). -+If neither is set, a system-dependent default editor (e.g., -+.BR vi ) -+is used. -+.TP -+.SM CVS_CLIENT_PORT -+If this variable is set then -+.B cvs -+will use this port in -+\fIpserver mode\fP -+rather than the default port (cvspserver 2401). -+.TP -+.SM CVS_IGNORE_REMOTE_ROOT -+If this variable is set then -+.B cvs -+will ignore all references to remote repositories in the CVS/Root file. -+.TP -+.SM CVS_OPTIONS -+Specifies a set of default options for -+.B cvs. -+These options are interpreted before the startup file (\fI~/.cvsrc\fP) is read -+and can be overridden by explicit command line parameters. -+.TP -+.SM CVS_RSH -+.B cvs -+uses the contents of this variable to determine the name of the -+remote shell command to use when starting a -+.B cvs -+server. If this variable is not set then -+.` "ssh" -+is used. -+.TP -+.SM CVS_SERVER -+.B cvs -+uses the contents of this variable to determine the name of the -+.B cvs -+server command. If this variable is not set then -+.` "cvs" -+is used. -+.TP -+.SM CVSWRAPPERS -+This variable is used by the -+.` "cvswrappers" -+script to determine the name of the wrapper file, in addition to the -+wrappers defaults contained in the repository -+.SM (CVSROOT/cvswrappers) -+and the user's home directory (~/.cvswrappers). -+.SH "AUTHORS" -+.TP -+Dick Grune -+Original author of the -+.B cvs -+shell script version posted to -+.B comp.sources.unix -+in the volume6 release of December, 1986. -+Credited with much of the -+.B cvs -+conflict resolution algorithms. -+.TP -+Brian Berliner -+Coder and designer of the -+.B cvs -+program itself in April, 1989, based on the original work done by Dick. -+.TP -+Jeff Polk -+Helped Brian with the design of the -+.B cvs -+module and vendor branch support and author of the -+.BR checkin ( 1 ) -+shell script (the ancestor of -+.` "cvs import"). -+.TP -+And many others too numerous to mention here. -+.SH "SEE ALSO" -+The most comprehensive manual for CVS is -+Version Management with CVS by Per Cederqvist et al. Depending on -+your system, you may be able to get it with the -+.B info cvs -+command or it may be available as cvs.ps (postscript), cvs.texinfo -+(texinfo source), or cvs.html. -+.SP -+For CVS updates, more information on documentation, software related -+to CVS, development of CVS, and more, see: -+.in +1i -+.B http://cvshome.org -+.B http://www.loria.fr/~molli/cvs-index.html -+.in -1i -+.SP -+.BR ci ( 1 ), -+.BR co ( 1 ), -+.BR cvs ( 5 ), -+.BR cvsbug ( 8 ), -+.BR diff ( 1 ), -+.BR grep ( 1 ), -+.BR patch ( 1 ), -+.BR rcs ( 1 ), -+.BR rcsdiff ( 1 ), -+.BR rcsmerge ( 1 ), -+.BR rlog ( 1 ). -Index: man/cvsbug.8 -diff -u src/contrib/cvs/man/cvsbug.8:1.1.1.4 src/contrib/cvs/man/cvsbug.8:1.3 ---- src/contrib/cvs/man/cvsbug.8:1.1.1.4 Mon Sep 2 14:50:19 2002 -+++ man/cvsbug.8 Mon Oct 2 15:43:55 2000 -@@ -17,6 +17,7 @@ - .\" General Public License for more details. - .\" - .\" --------------------------------------------------------------------------- -+.\" FreeBSD: src/contrib/cvs/man/cvsbug.8,v 1.3 2000/10/02 06:43:55 peter Exp $ - .nh - .TH CVSBUG 8 xVERSIONx "February 1993" - .SH NAME -Index: src/buffer.c -diff -u src/contrib/cvs/src/buffer.c:1.1.1.7 src/contrib/cvs/src/buffer.c:1.5 ---- src/contrib/cvs/src/buffer.c:1.1.1.7 Thu Apr 15 10:01:55 2004 -+++ src/buffer.c Thu Apr 15 10:17:26 2004 -@@ -1,5 +1,7 @@ - /* Code for the buffer data structure. */ - -+/* FreeBSD: src/contrib/cvs/src/buffer.c,v 1.5 2004/04/15 01:17:26 peter Exp $ */ -+ - #include <assert.h> - #include "cvs.h" - #include "buffer.h" -Index: src/checkout.c -diff -u src/contrib/cvs/src/checkout.c:1.1.1.13 src/contrib/cvs/src/checkout.c:1.5 ---- src/contrib/cvs/src/checkout.c:1.1.1.13 Thu Apr 15 10:01:55 2004 -+++ src/checkout.c Thu Apr 15 10:17:26 2004 -@@ -33,6 +33,10 @@ - * edited by the user, if necessary (when the repository is moved, e.g.) - */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/checkout.c,v 1.5 2004/04/15 01:17:26 peter Exp $ -+ */ -+ - #include <assert.h> - #include "cvs.h" - -@@ -50,6 +54,7 @@ - "\t-N\tDon't shorten module paths if -d specified.\n", - "\t-P\tPrune empty directories.\n", - "\t-R\tProcess directories recursively.\n", -+ "\t-T\tCreate Template file from local repository for remote commit.\n", - "\t-c\t\"cat\" the module database.\n", - "\t-f\tForce a head revision match if tag/date not found.\n", - "\t-l\tLocal directory only, not recursive\n", -@@ -92,6 +97,7 @@ - static char *join_rev1; - static char *join_rev2; - static int join_tags_validated; -+static int pull_template; - static char *preload_update_dir; - static char *history_name; - static enum mtype m_type; -@@ -139,7 +145,7 @@ - else - { - m_type = CHECKOUT; -- valid_options = "+ANnk:d:flRpQqcsr:D:j:P"; -+ valid_options = "+ANnk:d:flRpTQqcsr:D:j:P"; - valid_usage = checkout_usage; - } - -@@ -168,6 +174,9 @@ - case 'n': - run_module_prog = 0; - break; -+ case 'T': -+ pull_template = 1; -+ break; - case 'Q': - case 'q': - #ifdef SERVER_SUPPORT -@@ -1096,8 +1105,7 @@ - force_tag_match, 0 /* !local */ , - 1 /* update -d */ , aflag, checkout_prune_dirs, - pipeout, which, join_rev1, join_rev2, -- preload_update_dir, m_type == CHECKOUT, -- repository); -+ preload_update_dir, pull_template, repository); - goto out; - } - -@@ -1153,8 +1161,7 @@ - err += do_update (argc - 1, argv + 1, options, tag, date, - force_tag_match, local_specified, 1 /* update -d */, - aflag, checkout_prune_dirs, pipeout, which, join_rev1, -- join_rev2, preload_update_dir, m_type == CHECKOUT, -- repository); -+ join_rev2, preload_update_dir, pull_template, repository); - out: - free (preload_update_dir); - preload_update_dir = oldupdate; -Index: src/client.c -diff -u src/contrib/cvs/src/client.c:1.1.1.16 src/contrib/cvs/src/client.c:1.12 ---- src/contrib/cvs/src/client.c:1.1.1.16 Fri Jun 11 04:05:37 2004 -+++ src/client.c Fri Jun 11 04:12:50 2004 -@@ -10,6 +10,10 @@ - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/client.c,v 1.12 2004/06/10 19:12:50 peter Exp $ -+ */ -+ - #ifdef HAVE_CONFIG_H - # include "config.h" - #endif /* HAVE_CONFIG_H */ -@@ -262,7 +266,7 @@ - } - - /* Now check the value for root. */ -- if (this_root && current_parsed_root -+ if (CVSroot_cmdline == NULL && this_root && current_parsed_root - && (strcmp (this_root, current_parsed_root->original) != 0)) - { - /* Don't send this, since the CVSROOTs don't match. */ -@@ -4732,7 +4736,7 @@ - example in CVS_RSH or other such mechanisms to be devised, - if that is what they want (the manual already tells them - that). */ -- cvs_rsh = "rsh"; -+ cvs_rsh = "ssh"; - if (!cvs_server) - cvs_server = "cvs"; - -@@ -4793,7 +4797,7 @@ - int child_pid; - - if (!cvs_rsh) -- cvs_rsh = "rsh"; -+ cvs_rsh = "ssh"; - if (!cvs_server) - cvs_server = "cvs"; - -@@ -5151,7 +5155,8 @@ - } - else if (vers->ts_rcs == NULL - || args->force -- || strcmp (vers->ts_user, vers->ts_rcs) != 0) -+ || strcmp (vers->ts_user, vers->ts_rcs) != 0 -+ || (vers->vn_user && *vers->vn_user == '0')) - { - if (args->no_contents - && supported_request ("Is-modified")) -Index: src/commit.c -diff -u src/contrib/cvs/src/commit.c:1.1.1.14 src/contrib/cvs/src/commit.c:1.15 ---- src/contrib/cvs/src/commit.c:1.1.1.14 Fri Jun 11 04:05:37 2004 -+++ src/commit.c Fri Jun 11 04:12:50 2004 -@@ -12,6 +12,7 @@ - * - * The call is: cvs commit [options] files... - * -+ * FreeBSD: src/contrib/cvs/src/commit.c,v 1.15 2004/06/10 19:12:50 peter Exp $ - */ - - #include <assert.h> -Index: src/cvs.h -diff -u src/contrib/cvs/src/cvs.h:1.1.1.15 src/contrib/cvs/src/cvs.h:1.20 ---- src/contrib/cvs/src/cvs.h:1.1.1.15 Fri Jun 11 04:05:38 2004 -+++ src/cvs.h Fri Jun 11 04:12:50 2004 -@@ -9,6 +9,7 @@ - /* - * basic information used in all source files - * -+ * FreeBSD: src/contrib/cvs/src/cvs.h,v 1.20 2004/06/10 19:12:50 peter Exp $ - */ - - -@@ -194,6 +195,7 @@ - #define CVSROOTADM_WRITERS "writers" - #define CVSROOTADM_PASSWD "passwd" - #define CVSROOTADM_CONFIG "config" -+#define CVSROOTADM_OPTIONS "options" - - #define CVSNULLREPOS "Emptydir" /* an empty directory */ - -@@ -263,6 +265,8 @@ - #define CVSREAD_ENV "CVSREAD" /* make files read-only */ - #define CVSREAD_DFLT 0 /* writable files by default */ - -+#define CVSREADONLYFS_ENV "CVSREADONLYFS" /* repository is read-only */ -+ - #define TMPDIR_ENV "TMPDIR" /* Temporary directory */ - - #define EDITOR1_ENV "CVSEDITOR" /* which editor to use */ -@@ -372,6 +376,7 @@ - extern int use_editor; - extern int cvswrite; - extern mode_t cvsumask; -+extern char *RCS_citag; - - - -@@ -390,7 +395,9 @@ - - extern int trace; /* Show all commands */ - extern int noexec; /* Don't modify disk anywhere */ -+extern int readonlyfs; /* fail on all write locks; succeed all read locks */ - extern int logoff; /* Don't write history entry */ -+extern int require_real_user; /* skip CVSROOT/passwd, /etc/passwd users only*/ - - extern int top_level_admin; - -@@ -498,6 +505,7 @@ - char *strcat_filename_onto_homedir PROTO ((const char *, const char *)); - char *cvs_temp_name PROTO ((void)); - FILE *cvs_temp_file PROTO ((char **filename)); -+void parseopts PROTO ((const char *root)); - - int numdots PROTO((const char *s)); - char *increment_revnum PROTO ((const char *)); -@@ -576,6 +584,7 @@ - void WriteTag PROTO ((const char *dir, const char *tag, const char *date, - int nonbranch, const char *update_dir, - const char *repository)); -+void WriteTemplate PROTO ((const char *dir, const char *update_dir)); - void cat_module PROTO((int status)); - void check_entries PROTO((char *dir)); - void close_module PROTO((DBM * db)); -Index: src/cvsbug.in -diff -u src/contrib/cvs/src/cvsbug.in:1.1.1.3 src/contrib/cvs/src/cvsbug.in:1.2 ---- src/contrib/cvs/src/cvsbug.in:1.1.1.3 Thu Apr 15 10:01:55 2004 -+++ src/cvsbug.in Wed Sep 7 22:39:44 2005 -@@ -109,14 +109,12 @@ - /usr/bin/ypcat passwd 2>/dev/null | cat - /etc/passwd | grep "^$LOGNAME:" | - cut -f5 -d':' | sed -e 's/,.*//' > $TEMP - ORIGINATOR="`cat $TEMP`" -- rm -f $TEMP - fi - fi - - if [ "$ORIGINATOR" = "" ]; then - grep "^$LOGNAME:" /etc/passwd | cut -f5 -d':' | sed -e 's/,.*//' > $TEMP - ORIGINATOR="`cat $TEMP`" -- rm -f $TEMP - fi - - if [ -n "$ORGANIZATION" ]; then -Index: src/diff.c -diff -u src/contrib/cvs/src/diff.c:1.1.1.12 src/contrib/cvs/src/diff.c:1.21 ---- src/contrib/cvs/src/diff.c:1.1.1.12 Thu Apr 15 10:01:55 2004 -+++ src/diff.c Thu Apr 15 10:31:28 2004 -@@ -12,6 +12,8 @@ - * - * Without any file arguments, runs diff against all the currently modified - * files. -+ * -+ * FreeBSD: src/contrib/cvs/src/diff.c,v 1.21 2004/04/15 01:31:28 peter Exp $ - */ - - #include <assert.h> -@@ -52,6 +54,7 @@ - static char *diff_rev1, *diff_rev2; - /* Command line dates, from -D option. Malloc'd. */ - static char *diff_date1, *diff_date2; -+static char *diff_join1, *diff_join2; - static char *use_rev1, *use_rev2; - static int have_rev1_label, have_rev2_label; - -@@ -272,6 +275,8 @@ - diff_rev2 = NULL; - diff_date1 = NULL; - diff_date2 = NULL; -+ diff_join1 = NULL; -+ diff_join2 = NULL; - - optind = 0; - /* FIXME: This should really be allocating an argv to be passed to diff -@@ -282,7 +287,7 @@ - * to diff. - */ - while ((c = getopt_long (argc, argv, -- "+abcdefhilnpstuwy0123456789BHNRTC:D:F:I:L:U:W:k:r:", -+ "+abcdefhilnpstuwy0123456789BHNRTC:D:F:I:L:U:W:k:r:j:", - longopts, &option_index)) != -1) - { - switch (c) -@@ -345,6 +350,27 @@ - free (options); - options = RCS_check_kflag (optarg); - break; -+ case 'j': -+ { -+ char *ptr; -+ char *cpy = strdup(optarg); -+ -+ if ((ptr = strchr(optarg, ':')) != NULL) -+ *ptr++ = 0; -+ if (diff_rev2 != NULL || diff_date2 != NULL) -+ error (1, 0, -+ "no more than two revisions/dates can be specified"); -+ if (diff_rev1 != NULL || diff_date1 != NULL) { -+ diff_join2 = cpy; -+ diff_rev2 = optarg; -+ diff_date2 = ptr ? Make_Date(ptr) : NULL; -+ } else { -+ diff_join1 = cpy; -+ diff_rev1 = optarg; -+ diff_date1 = ptr ? Make_Date(ptr) : NULL; -+ } -+ } -+ break; - case 'r': - if (diff_rev2 != NULL || diff_date2 != NULL) - error (1, 0, -@@ -393,13 +419,18 @@ - send_option_string (opts); - if (options[0] != '\0') - send_arg (options); -- if (diff_rev1) -+ if (diff_join1) -+ option_with_arg ("-j", diff_join1); -+ else if (diff_rev1) - option_with_arg ("-r", diff_rev1); -- if (diff_date1) -+ else if (diff_date1) - client_senddate (diff_date1); -- if (diff_rev2) -+ -+ if (diff_join2) -+ option_with_arg ("-j", diff_join2); -+ else if (diff_rev2) - option_with_arg ("-r", diff_rev2); -- if (diff_date2) -+ else if (diff_date2) - client_senddate (diff_date2); - send_arg ("--"); - -@@ -413,28 +444,26 @@ - - send_to_server ("diff\012", 0); - err = get_responses_and_close (); -- free (options); -- options = NULL; -- return (err); -- } -+ } else - #endif -- -- if (diff_rev1 != NULL) -- tag_check_valid (diff_rev1, argc, argv, local, 0, ""); -- if (diff_rev2 != NULL) -- tag_check_valid (diff_rev2, argc, argv, local, 0, ""); -- -- which = W_LOCAL; -- if (diff_rev1 != NULL || diff_date1 != NULL) -- which |= W_REPOS | W_ATTIC; -- -- wrap_setup (); -- -- /* start the recursion processor */ -- err = start_recursion (diff_fileproc, diff_filesdoneproc, diff_dirproc, -- diff_dirleaveproc, NULL, argc, argv, local, -- which, 0, CVS_LOCK_READ, (char *) NULL, 1, -- (char *) NULL); -+ { -+ if (diff_rev1 != NULL) -+ tag_check_valid (diff_rev1, argc, argv, local, 0, ""); -+ if (diff_rev2 != NULL) -+ tag_check_valid (diff_rev2, argc, argv, local, 0, ""); -+ -+ which = W_LOCAL; -+ if (diff_rev1 != NULL || diff_date1 != NULL) -+ which |= W_REPOS | W_ATTIC; -+ -+ wrap_setup (); -+ -+ /* start the recursion processor */ -+ err = start_recursion (diff_fileproc, diff_filesdoneproc, diff_dirproc, -+ diff_dirleaveproc, NULL, argc, argv, local, -+ which, 0, CVS_LOCK_READ, (char *) NULL, 1, -+ (char *) NULL); -+ } - - /* clean up */ - free (options); -@@ -444,6 +473,10 @@ - free (diff_date1); - if (diff_date2 != NULL) - free (diff_date2); -+ if (diff_join1 != NULL) -+ free (diff_join1); -+ if (diff_join2 != NULL) -+ free (diff_join2); - - return (err); - } -@@ -489,7 +522,7 @@ - int exists; - - exists = 0; -- /* special handling for TAG_HEAD */ -+ /* special handling for TAG_HEAD XXX */ - if (diff_rev1 && strcmp (diff_rev1, TAG_HEAD) == 0) - { - char *head = -@@ -886,7 +919,7 @@ - - if (diff_rev1 || diff_date1) - { -- /* special handling for TAG_HEAD */ -+ /* special handling for TAG_HEAD XXX */ - if (diff_rev1 && strcmp (diff_rev1, TAG_HEAD) == 0) - { - if (vers->vn_rcs != NULL && vers->srcfile != NULL) -@@ -902,7 +935,7 @@ - } - if (diff_rev2 || diff_date2) - { -- /* special handling for TAG_HEAD */ -+ /* special handling for TAG_HEAD XXX */ - if (diff_rev2 && strcmp (diff_rev2, TAG_HEAD) == 0) - { - if (vers->vn_rcs != NULL && vers->srcfile != NULL) -Index: src/entries.c -diff -u src/contrib/cvs/src/entries.c:1.1.1.8 src/contrib/cvs/src/entries.c:1.4 ---- src/contrib/cvs/src/entries.c:1.1.1.8 Thu Apr 15 10:01:55 2004 -+++ src/entries.c Thu Apr 15 10:41:05 2004 -@@ -11,6 +11,9 @@ - * the Entries file. - */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/entries.c,v 1.4 2004/04/15 01:41:05 peter Exp $ -+ */ - #include "cvs.h" - #include "getline.h" - -@@ -635,6 +638,72 @@ - return (p); - } - -+static char *root_template; -+ -+static int -+get_root_template(const char *repository, const char *path) -+{ -+ if (root_template) { -+ if (strcmp(path, root_template) == 0) -+ return(0); -+ free(root_template); -+ } -+ if ((root_template = strdup(path)) == NULL) -+ return(-1); -+ return(0); -+} -+ -+/* -+ * Write out/Clear the CVS/Template file. -+ */ -+void -+WriteTemplate (dir, update_dir) -+ const char *dir; -+ const char *update_dir; -+{ -+ char *tmp = NULL; -+ struct stat st1; -+ struct stat st2; -+ -+ if (Parse_Info(CVSROOTADM_RCSINFO, "cvs", get_root_template, 1) < 0) -+ return; -+ -+ if (asprintf(&tmp, "%s/%s", dir, CVSADM_TEMPLATE) < 0) -+ error (1, errno, "out of memory"); -+ -+ if (stat(root_template, &st1) == 0) { -+ if (stat(tmp, &st2) < 0 || st1.st_mtime != st2.st_mtime) { -+ FILE *fi; -+ FILE *fo; -+ -+ if ((fi = open_file(root_template, "r")) != NULL) { -+ if ((fo = open_file(tmp, "w")) != NULL) { -+ int n; -+ char buf[256]; -+ -+ while ((n = fread(buf, 1, sizeof(buf), fi)) > 0) -+ fwrite(buf, 1, n, fo); -+ fflush(fo); -+ if (ferror(fi) || ferror(fo)) { -+ fclose(fo); -+ remove(tmp); -+ error (1, errno, "error copying Template"); -+ } else { -+ struct timeval times[2]; -+ fclose(fo); -+ times[0].tv_sec = st1.st_mtime; -+ times[0].tv_usec = 0; -+ times[1] = times[0]; -+ utimes(tmp, times); -+ } -+ } -+ fclose(fi); -+ } -+ } -+ } -+ free(tmp); -+} -+ - /* - * Write out/Clear the CVS/Tag file. - */ -Index: src/filesubr.c -diff -u src/contrib/cvs/src/filesubr.c:1.1.1.12 src/contrib/cvs/src/filesubr.c:1.12 ---- src/contrib/cvs/src/filesubr.c:1.1.1.12 Fri Jun 11 04:05:37 2004 -+++ src/filesubr.c Fri Jun 11 04:12:50 2004 -@@ -17,6 +17,10 @@ - definitions under operating systems (like, say, Windows NT) with different - file system semantics. */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/filesubr.c,v 1.12 2004/06/10 19:12:50 peter Exp $ -+ */ -+ - #include <assert.h> - #include "cvs.h" - -@@ -872,8 +876,8 @@ - const char *link; - { - char *file = NULL; -- int buflen = 128; -- int link_name_len; -+ int buflen = BUFSIZ; -+ int linklen; - - /* Get the name of the file to which `from' is linked. - FIXME: what portability issues arise here? Are readlink & -@@ -881,15 +885,15 @@ - do - { - file = xrealloc (file, buflen); -- link_name_len = readlink (link, file, buflen - 1); -+ errno = 0; -+ linklen = readlink (link, file, buflen - 1); - buflen *= 2; - } -- while (link_name_len < 0 && errno == ENAMETOOLONG); -+ while (linklen == -1 && errno == ENAMETOOLONG); - -- if (link_name_len < 0) -+ if (linklen == -1) - error (1, errno, "cannot readlink %s", link); -- -- file[link_name_len] = '\0'; -+ file[linklen] = '\0'; - - return file; - } -Index: src/import.c -diff -u src/contrib/cvs/src/import.c:1.1.1.13 src/contrib/cvs/src/import.c:1.12 ---- src/contrib/cvs/src/import.c:1.1.1.13 Thu Apr 15 10:01:55 2004 -+++ src/import.c Thu Apr 15 10:17:27 2004 -@@ -14,6 +14,8 @@ - * VendorReleTag Tag for this particular release - * - * Additional arguments specify more Vendor Release Tags. -+ * -+ * FreeBSD: src/contrib/cvs/src/import.c,v 1.12 2004/04/15 01:17:27 peter Exp $ - */ - - #include "cvs.h" -Index: src/lock.c -diff -u src/contrib/cvs/src/lock.c:1.1.1.12 src/contrib/cvs/src/lock.c:1.13 ---- src/contrib/cvs/src/lock.c:1.1.1.12 Thu Apr 15 10:01:55 2004 -+++ src/lock.c Thu Apr 15 10:17:27 2004 -@@ -8,6 +8,8 @@ - * Set Lock - * - * Lock file support for CVS. -+ * -+ * FreeBSD: src/contrib/cvs/src/lock.c,v 1.13 2004/04/15 01:17:27 peter Exp $ - */ - - /* The node Concurrency in doc/cvs.texinfo has a brief introduction to -@@ -407,7 +409,7 @@ - (void) fprintf (stderr, "%s-> Reader_Lock(%s)\n", CLIENT_SERVER_STR, - xrepository); - -- if (noexec) -+ if (noexec || readonlyfs) - return 0; - - /* we only do one directory at a time for read locks! */ -@@ -484,6 +486,11 @@ - if (noexec) - return 0; - -+ if (readonlyfs) { -+ error (0, 0, "write lock failed - read-only repository"); -+ return (1); -+ } -+ - /* We only know how to do one list at a time */ - if (locklist != (List *) NULL) - { -Index: src/log.c -diff -u src/contrib/cvs/src/log.c:1.1.1.12 src/contrib/cvs/src/log.c:1.2 ---- src/contrib/cvs/src/log.c:1.1.1.12 Fri Jun 11 04:05:37 2004 -+++ src/log.c Tue Jul 6 17:10:38 2004 -@@ -10,6 +10,8 @@ - * Prints the RCS "log" (rlog) information for the specified files. With no - * argument, prints the log information for all the files in the directory - * (recursive by default). -+ * -+ * FreeBSD: src/contrib/cvs/src/log.c,v 1.2 2004/07/06 08:10:38 des Exp $ - */ - - #include "cvs.h" -@@ -1605,8 +1607,8 @@ - &sec); - if (year < 1900) - year += 1900; -- sprintf (buf, "%04d/%02d/%02d %02d:%02d:%02d", year, mon, mday, -- hour, min, sec); -+ sprintf (buf, "%04d%c%02d%c%02d %02d:%02d:%02d", -+ year, datesep, mon, datesep, mday, hour, min, sec); - cvs_output (buf, 0); - - cvs_output ("; author: ", 0); -Index: src/login.c -diff -u src/contrib/cvs/src/login.c:1.1.1.9 src/contrib/cvs/src/login.c:1.9 ---- src/contrib/cvs/src/login.c:1.1.1.9 Thu Apr 15 10:01:55 2004 -+++ src/login.c Sat Apr 23 02:58:25 2005 -@@ -5,6 +5,8 @@ - * specified in the README file that comes with CVS. - * - * Allow user to log in for an authenticating server. -+ * -+ * FreeBSD: src/contrib/cvs/src/login.c,v 1.9 2005/04/22 17:58:25 simon Exp $ - */ - - #include "cvs.h" -@@ -114,7 +116,7 @@ - - if (isspace(*(linebuf + 1))) - /* special case since strtoul ignores leading white space */ -- entry_version = 0; -+ q = linebuf + 1; - else - entry_version = strtoul (linebuf + 1, &q, 10); - -Index: src/logmsg.c -diff -u src/contrib/cvs/src/logmsg.c:1.1.1.10 src/contrib/cvs/src/logmsg.c:1.12 ---- src/contrib/cvs/src/logmsg.c:1.1.1.10 Thu Apr 15 10:01:55 2004 -+++ src/logmsg.c Thu Apr 15 10:17:27 2004 -@@ -4,6 +4,8 @@ - * - * You may distribute under the terms of the GNU General Public License as - * specified in the README file that comes with the CVS source distribution. -+ * -+ * FreeBSD: src/contrib/cvs/src/logmsg.c,v 1.12 2004/04/15 01:17:27 peter Exp $ - */ - - #include <assert.h> -@@ -226,6 +228,8 @@ - (*messagep)[strlen (*messagep) - 1] != '\n') - (void) fprintf (fp, "\n"); - } -+ else -+ (void) fprintf (fp, "\n"); - - if (repository != NULL) - /* tack templates on if necessary */ -Index: src/main.c -diff -u src/contrib/cvs/src/main.c:1.1.1.13 src/contrib/cvs/src/main.c:1.25 ---- src/contrib/cvs/src/main.c:1.1.1.13 Thu Apr 15 10:01:55 2004 -+++ src/main.c Tue Jul 6 17:10:38 2004 -@@ -10,10 +10,12 @@ - * Credit to Dick Grune, Vrije Universiteit, Amsterdam, for writing - * the shell-script CVS system that this is based on. - * -+ * FreeBSD: src/contrib/cvs/src/main.c,v 1.25 2004/07/06 08:10:38 des Exp $ - */ - - #include <assert.h> - #include "cvs.h" -+#include "prepend_args.h" - - #ifdef HAVE_WINSOCK_H - #include <winsock.h> -@@ -41,6 +43,8 @@ - int quiet = 0; - int trace = 0; - int noexec = 0; -+int readonlyfs = 0; -+int require_real_user = 0; - int logoff = 0; - - /* Set if we should be writing CVSADM directories at top level. At -@@ -106,7 +110,7 @@ - { - { "add", "ad", "new", add, CVS_CMD_MODIFIES_REPOSITORY | CVS_CMD_USES_WORK_DIR }, - { "admin", "adm", "rcs", admin, CVS_CMD_MODIFIES_REPOSITORY | CVS_CMD_USES_WORK_DIR }, -- { "annotate", "ann", NULL, annotate, CVS_CMD_USES_WORK_DIR }, -+ { "annotate", "ann", "blame", annotate, CVS_CMD_USES_WORK_DIR }, - { "checkout", "co", "get", checkout, 0 }, - { "commit", "ci", "com", commit, CVS_CMD_MODIFIES_REPOSITORY | CVS_CMD_USES_WORK_DIR }, - { "diff", "di", "dif", diff, CVS_CMD_USES_WORK_DIR }, -@@ -247,8 +251,10 @@ - " -q Cause CVS to be somewhat quiet.\n", - " -r Make checked-out files read-only.\n", - " -w Make checked-out files read-write (default).\n", -+ " -g Force group-write perms on checked-out files.\n", - " -n Do not execute anything that will change the disk.\n", - " -t Show trace of program execution -- try with -n.\n", -+ " -R Assume repository is read-only, such as CDROM\n", - " -v CVS version and copyright.\n", - " -T tmpdir Use 'tmpdir' for temporary files.\n", - " -e editor Use 'editor' for editing log information.\n", -@@ -406,7 +412,7 @@ - int help = 0; /* Has the user asked for help? This - lets us support the `cvs -H cmd' - convention to give help for cmd. */ -- static const char short_options[] = "+Qqrwtnvb:T:e:d:Hfz:s:xa"; -+ static const char short_options[] = "+QqgrwtnRvb:T:e:d:Hfz:s:xaU"; - static struct option long_options[] = - { - {"help", 0, NULL, 'H'}, -@@ -469,6 +475,12 @@ - } - if (getenv (CVSREAD_ENV) != NULL) - cvswrite = 0; -+ if (getenv (CVSREADONLYFS_ENV) != NULL) { -+ readonlyfs = 1; -+ logoff = 1; -+ } -+ -+ prepend_default_options (getenv ("CVS_OPTIONS"), &argc, &argv); - - /* Set this to 0 to force getopt initialization. getopt() sets - this to 1 internally. */ -@@ -531,9 +543,20 @@ - case 'w': - cvswrite = 1; - break; -+ case 'g': -+ /* -+ * force full group write perms (used for shared checked-out -+ * source trees, see manual page) -+ */ -+ umask(umask(077) & 007); -+ break; - case 't': - trace = 1; - break; -+ case 'R': -+ readonlyfs = 1; -+ logoff = 1; -+ break; - case 'n': - noexec = 1; - logoff = 1; -@@ -623,6 +646,11 @@ - We will issue an error later if stream - authentication is not supported. */ - break; -+ case 'U': -+#ifdef SERVER_SUPPORT -+ require_real_user = 1; -+#endif -+ break; - case '?': - default: - usage (usg); -@@ -749,6 +777,12 @@ - (void) putenv (env); - /* do not free env, as putenv has control of it */ - } -+ { -+ char *env; -+ env = xmalloc (sizeof "CVS_PID=" + 32); /* XXX pid < 10^32 */ -+ (void) sprintf (env, "CVS_PID=%ld", (long) getpid ()); -+ (void) putenv (env); -+ } - #endif - - #ifndef DONT_USE_SIGNALS -@@ -974,6 +1008,9 @@ - if we didn't, then there would be no way to check in a new - CVSROOT/config file to fix the broken one! */ - parse_config (current_parsed_root->directory); -+ -+ /* Now is a convenient time to read CVSROOT/options */ -+ parseopts(current_parsed_root->directory); - } - - #ifdef CLIENT_SUPPORT -@@ -1166,3 +1203,64 @@ - (void) fprintf (stderr, *cpp); - error_exit (); - } -+ -+void -+parseopts(root) -+ const char *root; -+{ -+ char path[PATH_MAX]; -+ int save_errno; -+ char buf[1024]; -+ const char *p; -+ char *q; -+ FILE *fp; -+ -+ if (root == NULL) { -+ printf("no CVSROOT in parseopts\n"); -+ return; -+ } -+ p = strchr (root, ':'); -+ if (p) -+ p++; -+ else -+ p = root; -+ if (p == NULL) { -+ printf("mangled CVSROOT in parseopts\n"); -+ return; -+ } -+ (void) sprintf (path, "%s/%s/%s", p, CVSROOTADM, CVSROOTADM_OPTIONS); -+ if ((fp = fopen(path, "r")) != NULL) { -+ while (fgets(buf, sizeof buf, fp) != NULL) { -+ if (buf[0] == '#') -+ continue; -+ q = strrchr(buf, '\n'); -+ if (q) -+ *q = '\0'; -+ -+ if (!strcmp(buf, "iso8601")) { -+ datesep = '-'; -+ } -+ if (!strncmp(buf, "tag=", 4)) { -+ char *what; -+ char *rcs_localid; -+ -+ rcs_localid = buf + 4; -+ RCS_setlocalid(rcs_localid); -+ } -+ if (!strncmp(buf, "tagexpand=", 10)) { -+ char *what; -+ char *rcs_incexc; -+ -+ rcs_incexc = buf + 10; -+ RCS_setincexc(rcs_incexc); -+ } -+ /* -+ * OpenBSD has a "umask=" and "dlimit=" command, we silently -+ * ignore them here since they are not much use to us. cvsumask -+ * defaults to 002 already, and the dlimit (data size limit) -+ * should really be handled elsewhere (eg: login.conf). -+ */ -+ } -+ fclose(fp); -+ } -+} -Index: src/mkmodules.c -diff -u src/contrib/cvs/src/mkmodules.c:1.1.1.12 src/contrib/cvs/src/mkmodules.c:1.13 ---- src/contrib/cvs/src/mkmodules.c:1.1.1.12 Thu Apr 15 10:01:55 2004 -+++ src/mkmodules.c Thu Apr 15 10:17:27 2004 -@@ -3,7 +3,10 @@ - * Copyright (c) 1989-1992, Brian Berliner - * - * You may distribute under the terms of the GNU General Public License as -- * specified in the README file that comes with the CVS kit. */ -+ * specified in the README file that comes with the CVS kit. -+ * -+ * FreeBSD: src/contrib/cvs/src/mkmodules.c,v 1.13 2004/04/15 01:17:27 peter Exp $ -+ */ - - #include "cvs.h" - #include "getline.h" -Index: src/parseinfo.c -diff -u src/contrib/cvs/src/parseinfo.c:1.1.1.12 src/contrib/cvs/src/parseinfo.c:1.3 ---- src/contrib/cvs/src/parseinfo.c:1.1.1.12 Thu Apr 15 10:01:55 2004 -+++ src/parseinfo.c Thu Apr 15 10:17:27 2004 -@@ -4,6 +4,8 @@ - * - * You may distribute under the terms of the GNU General Public License as - * specified in the README file that comes with the CVS source distribution. -+ * -+ * FreeBSD: src/contrib/cvs/src/parseinfo.c,v 1.3 2004/04/15 01:17:27 peter Exp $ - */ - - #include "cvs.h" -@@ -350,6 +352,25 @@ - goto error_return; - } - } -+ else if (strcmp (line, "tag") == 0) { -+ RCS_setlocalid(p); -+ } -+ else if (strcmp (line, "umask") == 0) { -+ cvsumask = (mode_t)(strtol(p, NULL, 8) & 0777); -+ } -+ else if (strcmp (line, "dlimit") == 0) { -+#ifdef BSD -+#include <sys/resource.h> -+ struct rlimit rl; -+ -+ if (getrlimit(RLIMIT_DATA, &rl) != -1) { -+ rl.rlim_cur = atoi(p); -+ rl.rlim_cur *= 1024; -+ -+ (void) setrlimit(RLIMIT_DATA, &rl); -+ } -+#endif /* BSD */ -+ } - else if (strcmp (line, "PreservePermissions") == 0) - { - if (strcmp (p, "no") == 0) -Index: src/patch.c -diff -u src/contrib/cvs/src/patch.c:1.1.1.13 src/contrib/cvs/src/patch.c:1.2 ---- src/contrib/cvs/src/patch.c:1.1.1.13 Thu Apr 15 10:01:55 2004 -+++ src/patch.c Sat Apr 23 02:58:25 2005 -@@ -10,6 +10,8 @@ - * Create a Larry Wall format "patch" file between a previous release and the - * current head of a module, or between two releases. Can specify the - * release as either a date or a revision number. -+ * -+ * FreeBSD: src/contrib/cvs/src/patch.c,v 1.2 2005/04/22 17:58:25 simon Exp $ - */ - - #include <assert.h> -@@ -385,6 +387,7 @@ - struct utimbuf t; - char *vers_tag, *vers_head; - char *rcs = NULL; -+ char *rcs_orig = NULL; - RCSNode *rcsfile; - FILE *fp1, *fp2, *fp3; - int ret = 0; -@@ -415,7 +418,7 @@ - if ((rcsfile->flags & VALID) && (rcsfile->flags & INATTIC)) - isattic = 1; - -- rcs = xmalloc (strlen (finfo->file) + sizeof (RCSEXT) + 5); -+ rcs_orig = rcs = xmalloc (strlen (finfo->file) + sizeof (RCSEXT) + 5); - (void) sprintf (rcs, "%s%s", finfo->file, RCSEXT); - - /* if vers_head is NULL, may have been removed from the release */ -@@ -757,8 +760,8 @@ - free (vers_tag); - if (vers_head != NULL) - free (vers_head); -- if (rcs != NULL) -- free (rcs); -+ if (rcs_orig) -+ free (rcs_orig); - return ret; - } - -Index: src/rcs.c -diff -u src/contrib/cvs/src/rcs.c:1.1.1.14 src/contrib/cvs/src/rcs.c:1.28 ---- src/contrib/cvs/src/rcs.c:1.1.1.14 Thu Apr 15 10:01:55 2004 -+++ src/rcs.c Sat Apr 23 02:58:25 2005 -@@ -6,6 +6,8 @@ - * - * The routines contained in this file do all the rcs file parsing and - * manipulation -+ * -+ * FreeBSD: src/contrib/cvs/src/rcs.c,v 1.28 2005/04/22 17:58:25 simon Exp $ - */ - - #include <assert.h> -@@ -24,6 +26,7 @@ - # endif - #endif - -+int datesep = '/'; - int preserve_perms = 0; - - /* The RCS -k options, and a set of enums that must match the array. -@@ -134,6 +137,8 @@ - evaluates its arguments multiple times. */ - #define STREQ(a, b) (*(char *)(a) == *(char *)(b) && strcmp ((a), (b)) == 0) - -+static char * getfullCVSname PROTO ((char *, char **)); -+ - /* - * We don't want to use isspace() from the C library because: - * -@@ -2502,13 +2507,25 @@ - char *rev; - { - int rev_num; -- char *xrev, *test_branch; -+ char *xrev, *test_branch, *local_branch_num; - - xrev = xmalloc (strlen (rev) + 14); /* enough for .0.number */ - check_rev = xrev; - -+ local_branch_num = getenv("CVS_LOCAL_BRANCH_NUM"); -+ if (local_branch_num) -+ { -+ rev_num = atoi(local_branch_num); -+ if (rev_num < 2) -+ rev_num = 2; -+ else -+ rev_num &= ~1; -+ } -+ else -+ rev_num = 2; -+ - /* only look at even numbered branches */ -- for (rev_num = 2; ; rev_num += 2) -+ for ( ; ; rev_num += 2) - { - /* see if the physical branch exists */ - (void) sprintf (xrev, "%s.%d", rev, rev_num); -@@ -3024,8 +3041,7 @@ - if (retval != NULL) - return (retval); - -- if (!force_tag_match || -- (vers != NULL && RCS_datecmp (vers->date, date) <= 0)) -+ if (vers && (!force_tag_match || RCS_datecmp (vers->date, date) <= 0)) - return xstrdup (vers->version); - else - return NULL; -@@ -3481,27 +3497,31 @@ - { - const char *string; - size_t len; -+ int expandit; - }; - #define KEYWORD_INIT(s) (s), sizeof (s) - 1 --static const struct rcs_keyword keywords[] = -+static struct rcs_keyword keywords[] = - { -- { KEYWORD_INIT ("Author") }, -- { KEYWORD_INIT ("Date") }, -- { KEYWORD_INIT ("Header") }, -- { KEYWORD_INIT ("Id") }, -- { KEYWORD_INIT ("Locker") }, -- { KEYWORD_INIT ("Log") }, -- { KEYWORD_INIT ("Name") }, -- { KEYWORD_INIT ("RCSfile") }, -- { KEYWORD_INIT ("Revision") }, -- { KEYWORD_INIT ("Source") }, -- { KEYWORD_INIT ("State") }, -- { NULL, 0 } -+ { KEYWORD_INIT ("Author"), 1 }, -+ { KEYWORD_INIT ("Date"), 1 }, -+ { KEYWORD_INIT ("CVSHeader"), 1 }, -+ { KEYWORD_INIT ("Header"), 1 }, -+ { KEYWORD_INIT ("Id"), 1 }, -+ { KEYWORD_INIT ("Locker"), 1 }, -+ { KEYWORD_INIT ("Log"), 1 }, -+ { KEYWORD_INIT ("Name"), 1 }, -+ { KEYWORD_INIT ("RCSfile"), 1 }, -+ { KEYWORD_INIT ("Revision"), 1 }, -+ { KEYWORD_INIT ("Source"), 1 }, -+ { KEYWORD_INIT ("State"), 1 }, -+ { NULL, 0, 0 }, -+ { NULL, 0, 0 } - }; - enum keyword - { - KEYWORD_AUTHOR = 0, - KEYWORD_DATE, -+ KEYWORD_CVSHEADER, - KEYWORD_HEADER, - KEYWORD_ID, - KEYWORD_LOCKER, -@@ -3510,8 +3530,10 @@ - KEYWORD_RCSFILE, - KEYWORD_REVISION, - KEYWORD_SOURCE, -- KEYWORD_STATE -+ KEYWORD_STATE, -+ KEYWORD_LOCALID - }; -+enum keyword keyword_local = KEYWORD_ID; - - /* Convert an RCS date string into a readable string. This is like - the RCS date2str function. */ -@@ -3527,8 +3549,8 @@ - &sec); - if (year < 1900) - year += 1900; -- sprintf (buf, "%04d/%02d/%02d %02d:%02d:%02d", year, mon, mday, -- hour, min, sec); -+ sprintf (buf, "%04d%c%02d%c%02d %02d:%02d:%02d", -+ year, datesep, mon, datesep, mday, hour, min, sec); - return xstrdup (buf); - } - -@@ -3689,7 +3711,8 @@ - slen = s - srch; - for (keyword = keywords; keyword->string != NULL; keyword++) - { -- if (keyword->len == slen -+ if (keyword->expandit -+ && keyword->len == slen - && strncmp (keyword->string, srch, slen) == 0) - { - break; -@@ -3736,15 +3759,25 @@ - free_value = 1; - break; - -+ case KEYWORD_CVSHEADER: - case KEYWORD_HEADER: - case KEYWORD_ID: -+ case KEYWORD_LOCALID: - { - const char *path; - int free_path; - char *date; -+ char *old_path; - -- if (kw == KEYWORD_HEADER) -+ old_path = NULL; -+ if (kw == KEYWORD_HEADER || -+ (kw == KEYWORD_LOCALID && -+ keyword_local == KEYWORD_HEADER)) - path = rcs->path; -+ else if (kw == KEYWORD_CVSHEADER || -+ (kw == KEYWORD_LOCALID && -+ keyword_local == KEYWORD_CVSHEADER)) -+ path = getfullCVSname(rcs->path, &old_path); - else - path = last_component (rcs->path); - path = escape_keyword_value (path, &free_path); -@@ -3767,6 +3800,8 @@ - * and we can discard the const. - */ - free ((char *)path); -+ if (old_path) -+ free (old_path); - free (date); - free_value = 1; - } -@@ -4103,7 +4138,7 @@ - size_t len; - int free_value = 0; - char *log = NULL; -- size_t loglen; -+ size_t loglen = 0; - Node *vp = NULL; - #ifdef PRESERVE_PERMISSIONS_SUPPORT - uid_t rcs_owner = (uid_t) -1; -@@ -7421,7 +7456,7 @@ - - for (ln = 0; ln < headlines.nlines; ++ln) - { -- char buf[80]; -+ char *buf; - /* Period which separates year from month in date. */ - char *ym; - /* Period which separates month from day in date. */ -@@ -7432,10 +7467,12 @@ - if (prvers == NULL) - prvers = vers; - -+ buf = xmalloc (strlen (prvers->version) + 24); - sprintf (buf, "%-12s (%-8.8s ", - prvers->version, - prvers->author); - cvs_output (buf, 0); -+ free (buf); - - /* Now output the date. */ - ym = strchr (prvers->date, '.'); -@@ -8620,3 +8657,105 @@ - } - return label; - } -+ -+void -+RCS_setlocalid (arg) -+ const char *arg; -+{ -+ char *copy, *next, *key; -+ -+ copy = xstrdup(arg); -+ next = copy; -+ key = strtok(next, "="); -+ -+ keywords[KEYWORD_LOCALID].string = xstrdup(key); -+ keywords[KEYWORD_LOCALID].len = strlen(key); -+ keywords[KEYWORD_LOCALID].expandit = 1; -+ -+ /* options? */ -+ while (key = strtok(NULL, ",")) { -+ if (!strcmp(key, keywords[KEYWORD_ID].string)) -+ keyword_local = KEYWORD_ID; -+ else if (!strcmp(key, keywords[KEYWORD_HEADER].string)) -+ keyword_local = KEYWORD_HEADER; -+ else if (!strcmp(key, keywords[KEYWORD_CVSHEADER].string)) -+ keyword_local = KEYWORD_CVSHEADER; -+ else -+ error(1, 0, "Unknown LocalId mode: %s", key); -+ } -+ free(copy); -+} -+ -+void -+RCS_setincexc (arg) -+ const char *arg; -+{ -+ char *key; -+ char *copy, *next; -+ int include = 0; -+ struct rcs_keyword *keyword; -+ -+ copy = xstrdup(arg); -+ next = copy; -+ switch (*next++) { -+ case 'e': -+ include = 0; -+ break; -+ case 'i': -+ include = 1; -+ break; -+ default: -+ free(copy); -+ return; -+ } -+ -+ if (include) -+ for (keyword = keywords; keyword->string != NULL; keyword++) -+ { -+ keyword->expandit = 0; -+ } -+ -+ key = strtok(next, ","); -+ while (key) { -+ for (keyword = keywords; keyword->string != NULL; keyword++) { -+ if (strcmp (keyword->string, key) == 0) -+ keyword->expandit = include; -+ } -+ key = strtok(NULL, ","); -+ } -+ free(copy); -+ return; -+} -+ -+#define ATTIC "/" CVSATTIC -+static char * -+getfullCVSname(CVSname, pathstore) -+ char *CVSname, **pathstore; -+{ -+ if (current_parsed_root->directory) { -+ int rootlen; -+ char *c = NULL; -+ int alen = sizeof(ATTIC) - 1; -+ -+ *pathstore = xstrdup(CVSname); -+ if ((c = strrchr(*pathstore, '/')) != NULL) { -+ if (c - *pathstore >= alen) { -+ if (!strncmp(c - alen, ATTIC, alen)) { -+ while (*c != '\0') { -+ *(c - alen) = *c; -+ c++; -+ } -+ *(c - alen) = '\0'; -+ } -+ } -+ } -+ -+ rootlen = strlen(current_parsed_root->directory); -+ if (!strncmp(*pathstore, current_parsed_root->directory, rootlen) && -+ (*pathstore)[rootlen] == '/') -+ CVSname = (*pathstore + rootlen + 1); -+ else -+ CVSname = (*pathstore); -+ } -+ return CVSname; -+} -Index: src/rcs.h -diff -u src/contrib/cvs/src/rcs.h:1.1.1.10 src/contrib/cvs/src/rcs.h:1.11 ---- src/contrib/cvs/src/rcs.h:1.1.1.10 Thu Apr 15 10:01:55 2004 -+++ src/rcs.h Tue Jul 6 17:10:38 2004 -@@ -6,6 +6,8 @@ - * specified in the README file that comes with the CVS source distribution. - * - * RCS source control definitions needed by rcs.c and friends -+ * -+ * FreeBSD: src/contrib/cvs/src/rcs.h,v 1.11 2004/07/06 08:10:38 des Exp $ - */ - - /* Strings which indicate a conflict if they occur at the start of a line. */ -@@ -244,8 +246,11 @@ - void RCS_deltas PROTO ((RCSNode *, FILE *, struct rcsbuffer *, const char *, - enum rcs_delta_op, char **, size_t *, - char **, size_t *)); -+void RCS_setincexc PROTO ((const char *arg)); -+void RCS_setlocalid PROTO ((const char *arg)); - char *make_file_label PROTO ((const char *, const char *, RCSNode *)); - -+extern int datesep; - extern int preserve_perms; - - /* From import.c. */ -Index: src/rcscmds.c -diff -u src/contrib/cvs/src/rcscmds.c:1.1.1.10 src/contrib/cvs/src/rcscmds.c:1.10 ---- src/contrib/cvs/src/rcscmds.c:1.1.1.10 Thu Apr 15 10:01:55 2004 -+++ src/rcscmds.c Thu Apr 15 10:17:27 2004 -@@ -7,6 +7,8 @@ - * - * The functions in this file provide an interface for performing - * operations directly on RCS files. -+ * -+ * FreeBSD: src/contrib/cvs/src/rcscmds.c,v 1.10 2004/04/15 01:17:27 peter Exp $ - */ - - #include "cvs.h" -Index: src/recurse.c -diff -u src/contrib/cvs/src/recurse.c:1.1.1.13 src/contrib/cvs/src/recurse.c:1.12 ---- src/contrib/cvs/src/recurse.c:1.1.1.13 Thu Apr 15 10:01:55 2004 -+++ src/recurse.c Thu Apr 15 10:17:27 2004 -@@ -6,6 +6,7 @@ - * - * General recursion handler - * -+ * FreeBSD: src/contrib/cvs/src/recurse.c,v 1.12 2004/04/15 01:17:27 peter Exp $ - */ - - #include "cvs.h" -Index: src/server.c -diff -u src/contrib/cvs/src/server.c:1.1.1.18 src/contrib/cvs/src/server.c:1.24 ---- src/contrib/cvs/src/server.c:1.1.1.18 Fri Jun 11 04:05:38 2004 -+++ src/server.c Fri Jun 11 04:12:50 2004 -@@ -8,6 +8,10 @@ - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/server.c,v 1.24 2004/06/10 19:12:50 peter Exp $ -+ */ -+ - #include <assert.h> - #include "cvs.h" - #include "watch.h" -@@ -773,6 +777,9 @@ - nothing. But for rsh, we need to do it now. */ - parse_config (current_parsed_root->directory); - -+ /* Now is a good time to read CVSROOT/options too. */ -+ parseopts(current_parsed_root->directory); -+ - path = xmalloc (strlen (current_parsed_root->directory) - + sizeof (CVSROOTADM) - + 2); -@@ -5602,7 +5609,10 @@ - password file. If so, that's enough to authenticate with. If - not, we'll check /etc/passwd. */ - -- rc = check_repository_password (username, password, repository, -+ if (require_real_user) -+ rc = 0; /* "not found" */ -+ else -+ rc = check_repository_password (username, password, repository, - &host_user); - - if (rc == 2) -Index: src/tag.c -diff -u src/contrib/cvs/src/tag.c:1.1.1.12 src/contrib/cvs/src/tag.c:1.2 ---- src/contrib/cvs/src/tag.c:1.1.1.12 Thu Apr 15 10:01:55 2004 -+++ src/tag.c Fri Aug 6 02:47:35 2004 -@@ -10,6 +10,8 @@ - * Add or delete a symbolic name to an RCS file, or a collection of RCS files. - * Tag uses the checked out revision in the current directory, rtag uses - * the modules database, if necessary. -+ * -+ * FreeBSD: src/contrib/cvs/src/tag.c,v 1.2 2004/08/05 17:47:35 des Exp $ - */ - - #include "cvs.h" -@@ -1199,6 +1201,9 @@ - || strcmp (name, TAG_HEAD) == 0) - return; - -+ if (readonlyfs) -+ return; -+ - /* FIXME: This routine doesn't seem to do any locking whatsoever - (and it is called from places which don't have locks in place). - If two processes try to write val-tags at the same time, it would -Index: src/update.c -diff -u src/contrib/cvs/src/update.c:1.1.1.15 src/contrib/cvs/src/update.c:1.14 ---- src/contrib/cvs/src/update.c:1.1.1.15 Fri Jun 11 04:05:38 2004 -+++ src/update.c Fri Jun 11 04:12:50 2004 -@@ -31,6 +31,8 @@ - * versions, these are updated too. If the -d option was specified, new - * directories added to the repository are automatically created and updated - * as well. -+ * -+ * FreeBSD: src/contrib/cvs/src/update.c,v 1.14 2004/06/10 19:12:50 peter Exp $ - */ - - #include "cvs.h" -@@ -95,10 +97,10 @@ - static int aflag = 0; - static int toss_local_changes = 0; - static int force_tag_match = 1; -+static int pull_template = 0; - static int update_build_dirs = 0; - static int update_prune_dirs = 0; - static int pipeout = 0; --static int dotemplate = 0; - #ifdef SERVER_SUPPORT - static int patches = 0; - static int rcs_diff_patches = 0; -@@ -123,6 +125,7 @@ - "\t-j rev\tMerge in changes made between current revision and rev.\n", - "\t-I ign\tMore files to ignore (! to reset).\n", - "\t-W spec\tWrappers specification line.\n", -+ "\t-T\tCreate CVS/Template.\n", - "(Specify the --help global option for a list of other help options)\n", - NULL - }; -@@ -138,6 +141,7 @@ - int c, err; - int local = 0; /* recursive by default */ - int which; /* where to look for files and dirs */ -+ int xpull_template = 0; - - if (argc == -1) - usage (update_usage); -@@ -147,7 +151,7 @@ - - /* parse the args */ - optind = 0; -- while ((c = getopt (argc, argv, "+ApCPflRQqduk:r:D:j:I:W:")) != -1) -+ while ((c = getopt (argc, argv, "+ApCPflRQTqduk:r:D:j:I:W:")) != -1) - { - switch (c) - { -@@ -185,6 +189,9 @@ - "-q or -Q must be specified before \"%s\"", - cvs_cmd_name); - break; -+ case 'T': -+ xpull_template = 1; -+ break; - case 'd': - update_build_dirs = 1; - break; -@@ -413,8 +420,8 @@ - /* call the command line interface */ - err = do_update (argc, argv, options, tag, date, force_tag_match, - local, update_build_dirs, aflag, update_prune_dirs, -- pipeout, which, join_rev1, join_rev2, (char *) NULL, 1, -- (char *) NULL); -+ pipeout, which, join_rev1, join_rev2, (char *) NULL, -+ xpull_template, (char *) NULL); - - /* free the space Make_Date allocated if necessary */ - if (date != NULL) -@@ -431,7 +438,7 @@ - int - do_update (argc, argv, xoptions, xtag, xdate, xforce, local, xbuild, xaflag, - xprune, xpipeout, which, xjoin_rev1, xjoin_rev2, preload_update_dir, -- xdotemplate, repository) -+ xpull_template, repository) - int argc; - char **argv; - char *xoptions; -@@ -447,7 +454,7 @@ - char *xjoin_rev1; - char *xjoin_rev2; - char *preload_update_dir; -- int xdotemplate; -+ int xpull_template; - char *repository; - { - int err = 0; -@@ -462,7 +469,7 @@ - aflag = xaflag; - update_prune_dirs = xprune; - pipeout = xpipeout; -- dotemplate = xdotemplate; -+ pull_template = xpull_template; - - /* setup the join support */ - join_rev1 = xjoin_rev1; -@@ -604,7 +611,7 @@ - && tag != NULL - && finfo->rcs != NULL) - { -- char *rev = RCS_getversion (finfo->rcs, tag, NULL, 1, NULL); -+ char *rev = RCS_getversion (finfo->rcs, tag, date, 1, NULL); - if (rev != NULL - && !RCS_nodeisbranch (finfo->rcs, tag)) - nonbranch = 1; -@@ -950,7 +957,7 @@ - via WriteTag. */ - 0, - 0, -- dotemplate); -+ pull_template); - rewrite_tag = 1; - nonbranch = 0; - Subdir_Register (entries, (char *) NULL, dir); -@@ -1009,6 +1016,12 @@ - nonbranch = 0; - } - -+ /* keep the CVS/Template file current */ -+ if (pull_template) -+ { -+ WriteTemplate (dir, update_dir); -+ } -+ - /* initialize the ignore list for this directory */ - ignlist = getlist (); - } -Index: src/update.h -diff -u src/contrib/cvs/src/update.h:1.1.1.4 src/contrib/cvs/src/update.h:1.3 ---- src/contrib/cvs/src/update.h:1.1.1.4 Thu Apr 15 10:01:55 2004 -+++ src/update.h Thu Apr 15 10:17:28 2004 -@@ -10,10 +10,14 @@ - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. */ - -+/* -+ * FreeBSD: src/contrib/cvs/src/update.h,v 1.3 2004/04/15 01:17:28 peter Exp $ -+ */ -+ - int do_update PROTO((int argc, char *argv[], char *xoptions, char *xtag, - char *xdate, int xforce, int local, int xbuild, - int xaflag, int xprune, int xpipeout, int which, - char *xjoin_rev1, char *xjoin_rev2, char *preload_update_dir, -- int xdotemplate, char *repository)); -+ int xpull_template, char *repository)); - int joining PROTO((void)); - extern int isemptydir PROTO ((const char *dir, int might_not_exist)); -Index: src/prepend_args.c -diff -u /dev/null src/gnu/usr.bin/cvs/cvs/prepend_args.c:1.3 ---- /dev/null Fri Oct 20 15:17:40 2006 -+++ src/prepend_args.c Mon Sep 2 15:09:03 2002 -@@ -0,0 +1,86 @@ -+/* prepend_args.c - utilility programs for manpiulating argv[] -+ Copyright (C) 1999 Free Software Foundation, Inc. -+ -+ This program is free software; you can redistribute it and/or modify -+ it under the terms of the GNU General Public License as published by -+ the Free Software Foundation; either version 2, or (at your option) -+ any later version. -+ -+ This program is distributed in the hope that it will be useful, -+ but WITHOUT ANY WARRANTY; without even the implied warranty of -+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -+ GNU General Public License for more details. -+ -+ You should have received a copy of the GNU General Public License -+ along with this program; if not, write to the Free Software -+ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -+ 02111-1307, USA. */ -+ -+/* FreeBSD: src/gnu/usr.bin/cvs/cvs/prepend_args.c,v 1.3 2002/09/02 06:09:03 peter Exp $ */ -+ -+ -+#ifdef HAVE_CONFIG_H -+# include <config.h> -+#endif -+#include "cvs.h" -+#include "prepend_args.h" -+ -+ -+/* Find the white-space-separated options specified by OPTIONS, and -+ using BUF to store copies of these options, set ARGV[0], ARGV[1], -+ etc. to the option copies. Return the number N of options found. -+ Do not set ARGV[N] to NULL. If ARGV is NULL, do not store ARGV[0] -+ etc. Backslash can be used to escape whitespace (and backslashes). */ -+static int -+prepend_args (options, buf, argv) -+ char const *options; -+ char *buf; -+ char **argv; -+{ -+ char const *o = options; -+ char *b = buf; -+ int n = 0; -+ -+ for (;;) -+ { -+ while (isspace ((unsigned char) *o)) -+ o++; -+ if (!*o) -+ return n; -+ if (argv) -+ argv[n] = b; -+ n++; -+ -+ do -+ if ((*b++ = *o++) == '\\' && *o) -+ b[-1] = *o++; -+ while (*o && ! isspace ((unsigned char) *o)); -+ -+ *b++ = '\0'; -+ } -+} -+ -+/* Prepend the whitespace-separated options in OPTIONS to the argument -+ vector of a main program with argument count *PARGC and argument -+ vector *PARGV. */ -+void -+prepend_default_options (options, pargc, pargv) -+ char const *options; -+ int *pargc; -+ char ***pargv; -+{ -+ if (options) -+ { -+ char *buf = xmalloc (strlen (options) + 1); -+ int prepended = prepend_args (options, buf, (char **) NULL); -+ int argc = *pargc; -+ char * const *argv = *pargv; -+ char **pp = (char **) xmalloc ((prepended + argc + 1) * sizeof *pp); -+ *pargc = prepended + argc; -+ *pargv = pp; -+ *pp++ = *argv++; -+ pp += prepend_args (options, buf, pp); -+ while ((*pp++ = *argv++)) -+ continue; -+ } -+} -Index: src/prepend_args.h -diff -u /dev/null src/gnu/usr.bin/cvs/cvs/prepend_args.h:1.2 ---- /dev/null Fri Oct 20 15:17:40 2006 -+++ src/prepend_args.h Mon Sep 2 15:09:03 2002 -@@ -0,0 +1,26 @@ -+/* prepend_args.h - utilility programs for manpiulating argv[] -+ Copyright (C) 1999 Free Software Foundation, Inc. -+ -+ This program is free software; you can redistribute it and/or modify -+ it under the terms of the GNU General Public License as published by -+ the Free Software Foundation; either version 2, or (at your option) -+ any later version. -+ -+ This program is distributed in the hope that it will be useful, -+ but WITHOUT ANY WARRANTY; without even the implied warranty of -+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -+ GNU General Public License for more details. -+ -+ You should have received a copy of the GNU General Public License -+ along with this program; if not, write to the Free Software -+ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -+ 02111-1307, USA. */ -+ -+/* FreeBSD: src/gnu/usr.bin/cvs/cvs/prepend_args.h,v 1.2 2002/09/02 06:09:03 peter Exp $ */ -+ -+/* This code, taken from GNU Grep, originally used the "PARAM" macro, as the -+ current GNU coding standards requires. Older GNU code used the "PROTO" -+ macro, before the GNU coding standards replaced it. We use the older -+ form here to keep from having to include another file in cvs/src/main.c. */ -+ -+void prepend_default_options PROTO ((char const *, int *, char ***)); diff --git a/devel/cvs-devel/files/patch-history_val-tag_world_writeable b/devel/cvs-devel/files/patch-history_val-tag_world_writeable new file mode 100644 index 000000000000..4ec36aa282f2 --- /dev/null +++ b/devel/cvs-devel/files/patch-history_val-tag_world_writeable @@ -0,0 +1,31 @@ +# Don't make history and val-tags files world-writable when creating a +# new repository. (Closes: #125892) +# +# Author unknown, probably Eric Gillespie, Jr. <epg@debian.org> +diff -Nur src/mkmodules.c src/mkmodules.c +--- src/mkmodules.c 2005-05-25 04:59:01.000000000 +0800 ++++ src/mkmodules.c 2006-02-26 22:27:55.000000000 +0800 +@@ -1249,11 +1249,6 @@ + fp = xfopen (info, "w"); + if (fclose (fp) < 0) + error (1, errno, "cannot close %s", info); +- +- /* Make the new history file world-writeable, since every CVS +- user will need to be able to write to it. We use chmod() +- because xchmod() is too shy. */ +- chmod (info, 0666); + } + + /* Make an empty val-tags file to prevent problems creating it later. */ +@@ -1267,11 +1262,6 @@ + fp = xfopen (info, "w"); + if (fclose (fp) < 0) + error (1, errno, "cannot close %s", info); +- +- /* Make the new val-tags file world-writeable, since every CVS +- user will need to be able to write to it. We use chmod() +- because xchmod() is too shy. */ +- chmod (info, 0666); + } + + free (info); diff --git a/devel/cvs-devel/files/patch-homedir b/devel/cvs-devel/files/patch-homedir new file mode 100644 index 000000000000..44961cb36123 --- /dev/null +++ b/devel/cvs-devel/files/patch-homedir @@ -0,0 +1,44 @@ +# Fix handling of homedirectory for pserver, patch from +# Jim Studt <jim@federated.com>. Closes: Bug#51234 +diff -Nur src/filesubr.c src/filesubr.c +--- src/filesubr.c 2005-09-28 23:25:59.000000000 +0800 ++++ src/filesubr.c 2006-02-26 22:31:57.000000000 +0800 +@@ -795,6 +795,11 @@ + The workaround is to put -f in inetd.conf which means that + get_homedir won't get called until after the switch in user ID. + ++ NOTE: the above paragraph is not sufficient if the HOME environment ++ variable is set, it overrides the uid based password lookup, hence ++ the change_uid logic path that blocks the HOME environment variable ++ when the uid gets changed. ++ + The whole concept of a "home directory" on the server is pretty + iffy, although I suppose some people probably are relying on it for + .cvsrc and such, in the cases where it works. */ +@@ -802,15 +807,24 @@ + get_homedir (void) + { + static char *home = NULL; ++ static uid_t home_uid = 0; ++ static int changed_uid = 0; + char *env; ++ uid_t uid = getuid(); + struct passwd *pw; + ++ if ( home && home_uid != uid) { ++ home = 0; ++ home_uid = uid; ++ changed_uid = 1; ++ } ++ + if (home != NULL) + return home; + +- if (!server_active && (env = getenv ("HOME")) != NULL) ++ if (!server_active && ((env = getenv ("HOME")) != NULL) && !changed_uid) + home = env; +- else if ((pw = (struct passwd *) getpwuid (getuid ())) ++ else if ((pw = (struct passwd *) getpwuid (uid)) + && pw->pw_dir) + home = xstrdup (pw->pw_dir); + else diff --git a/devel/cvs-devel/files/patch-import-n-X b/devel/cvs-devel/files/patch-import-n-X new file mode 100644 index 000000000000..3fc01fdaef2c --- /dev/null +++ b/devel/cvs-devel/files/patch-import-n-X @@ -0,0 +1,15 @@ +# Fix `cvs import -X' failure +# Fixes: #374964 +# Patch by Florian Zschocke <zschocke@gmx.net> +diff -Nur src/import.c src/import.c +--- src/import.c 2005-09-04 02:27:44.000000000 +0200 ++++ src/import.c 2006-06-19 19:41:57.000000000 +0200 +@@ -595,7 +595,7 @@ + /* Attempt to make the Attic directory, in case it + does not exist. */ + (void) sprintf (rcs, "%s/%s", repository, CVSATTIC); +- if (CVS_MKDIR (rcs, 0777 ) != 0 && errno != EEXIST) ++ if (noexec == 0 && CVS_MKDIR (rcs, 0777 ) != 0 && errno != EEXIST) + error (1, errno, "cannot make directory `%s'", rcs); + + /* Note that the above clobbered the path name, so we diff --git a/devel/cvs-devel/files/patch-keyword_alphanumerics b/devel/cvs-devel/files/patch-keyword_alphanumerics new file mode 100644 index 000000000000..1ad62b266678 --- /dev/null +++ b/devel/cvs-devel/files/patch-keyword_alphanumerics @@ -0,0 +1,27 @@ +# Fix keyword handling to accept alphanumerics, not just alphabetics. +# Thanks to Branden Robinson for this fix. +diff -Nur src/rcs.c src/rcs.c +--- src/rcs.c 2005-09-28 23:25:59.000000000 +0800 ++++ src/rcs.c 2006-02-26 17:58:32.000000000 +0800 +@@ -3680,13 +3680,18 @@ + srch_len -= (srch_next + 1) - srch; + srch = srch_next + 1; + +- /* Look for the first non alphabetic character after the '$'. */ ++ /* ++ * Accept alphanumerics, not just alphabetics. XFree86, anyone? ++ * Branden Robinson Sat, 7 Sep 2002 02:04:59 -0500 ++ */ ++ ++ /* Look for the first non alphanumeric character after the '$'. */ + send = srch + srch_len; + for (s = srch; s < send; s++) +- if (! isalpha ((unsigned char) *s)) ++ if (! isalnum ((unsigned char) *s)) + break; + +- /* If the first non alphabetic character is not '$' or ':', ++ /* If the first non alphanumeric character is not '$' or ':', + then this is not an RCS keyword. */ + if (s == send || (*s != '$' && *s != ':')) + continue; diff --git a/devel/cvs-devel/files/patch-lib-Makefile.in b/devel/cvs-devel/files/patch-lib-Makefile.in deleted file mode 100644 index 128728d46604..000000000000 --- a/devel/cvs-devel/files/patch-lib-Makefile.in +++ /dev/null @@ -1,37 +0,0 @@ ---- lib/Makefile.in.orig Mon Sep 29 19:05:58 2003 -+++ lib/Makefile.in Tue Sep 30 11:25:43 2003 -@@ -173,8 +173,6 @@ - getopt.c \ - getopt1.c \ - getpass.c \ -- md5.c \ -- regex.c \ - savecwd.c \ - sighandle.c \ - stripslash.c \ -@@ -210,7 +208,7 @@ - libcvs_a_DEPENDENCIES = @LIBOBJS@ - am_libcvs_a_OBJECTS = argmatch.$(OBJEXT) getdate.$(OBJEXT) \ - getline.$(OBJEXT) getopt.$(OBJEXT) getopt1.$(OBJEXT) \ -- getpass.$(OBJEXT) md5.$(OBJEXT) regex.$(OBJEXT) \ -+ getpass.$(OBJEXT) \ - savecwd.$(OBJEXT) sighandle.$(OBJEXT) stripslash.$(OBJEXT) \ - xgetwd.$(OBJEXT) yesno.$(OBJEXT) - libcvs_a_OBJECTS = $(am_libcvs_a_OBJECTS) -@@ -228,7 +226,6 @@ - @AMDEP_TRUE@ ./$(DEPDIR)/argmatch.Po ./$(DEPDIR)/getdate.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/getline.Po ./$(DEPDIR)/getopt.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/getopt1.Po ./$(DEPDIR)/getpass.Po \ --@AMDEP_TRUE@ ./$(DEPDIR)/md5.Po ./$(DEPDIR)/regex.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/savecwd.Po ./$(DEPDIR)/sighandle.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/stripslash.Po ./$(DEPDIR)/xgetwd.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/yesno.Po -@@ -289,8 +286,6 @@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/getopt.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/getopt1.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/getpass.Po@am__quote@ --@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/md5.Po@am__quote@ --@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/regex.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/savecwd.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sighandle.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/stripslash.Po@am__quote@ diff --git a/devel/cvs-devel/files/patch-login_cvspass_message b/devel/cvs-devel/files/patch-login_cvspass_message new file mode 100644 index 000000000000..71b02b8d3b48 --- /dev/null +++ b/devel/cvs-devel/files/patch-login_cvspass_message @@ -0,0 +1,19 @@ +# Print a clearer message if ~/.cvspass does not exist when cvs login is +# called. Closes: #168163. +# +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur src/login.c src/login.c +--- src/login.c 2005-05-14 05:47:28.000000000 +0800 ++++ src/login.c 2006-02-26 21:31:17.000000000 +0800 +@@ -309,7 +309,10 @@ + fp = CVS_FOPEN (passfile, "r"); + if (fp == NULL) + { +- error (0, errno, "warning: failed to open %s for reading", passfile); ++ if (errno == ENOENT) ++ error (0, 0, "CVS password file %s does not exist - creating a new file", passfile); ++ else ++ error (0, errno, "warning: failed to open %s for reading", passfile); + goto process; + } + diff --git a/devel/cvs-devel/files/patch-newlines_in_commit_template b/devel/cvs-devel/files/patch-newlines_in_commit_template new file mode 100644 index 000000000000..858cf7f4bb6d --- /dev/null +++ b/devel/cvs-devel/files/patch-newlines_in_commit_template @@ -0,0 +1,32 @@ +# Change commit template so that there are two newlines at the +# beginning. (closes: #102624) +# +# Patch from Tollef Fog Heen <tfheen@debian.org> +diff -Nur src/logmsg.c src/logmsg.c +--- src/logmsg.c 2005-09-04 08:27:44.000000000 +0800 ++++ src/logmsg.c 2006-02-26 17:57:28.000000000 +0800 +@@ -264,6 +264,11 @@ + } + } + ++ if (!*messagep) ++ { ++ (void) fprintf (fp, "\n"); ++ } ++ + (void) fprintf (fp, + "%s----------------------------------------------------------------------\n", + CVSEDITPREFIX); +@@ -349,7 +354,11 @@ + *messagep = NULL; + } + +- if (pre_stbuf.st_mtime == post_stbuf.st_mtime || *messagep == NULL) ++ if (pre_stbuf.st_mtime == post_stbuf.st_mtime || ++ *messagep == NULL || ++ (*messagep)[0] == '\0' || ++ strcmp (*messagep, "\n") == 0 || ++ strcmp (*messagep, "\n\n") == 0) + { + for (;;) + { diff --git a/devel/cvs-devel/files/patch-normalize_correct_roots b/devel/cvs-devel/files/patch-normalize_correct_roots new file mode 100644 index 000000000000..b8ab013f3b8e --- /dev/null +++ b/devel/cvs-devel/files/patch-normalize_correct_roots @@ -0,0 +1,34 @@ +# Apply patch from 120042, which only tries to parse pserver, gserver +# and kserver methods when doing cvs login. (closes: #120042). +# +# Patch from Horms <horms@vergenet.net> +diff -Nur src/login.c src/login.c +--- src/login.c 2006-02-26 22:10:42.000000000 +0800 ++++ src/login.c 2006-02-26 22:25:14.000000000 +0800 +@@ -200,11 +200,21 @@ + return NULL; + } + *p = ' '; +- tmp_root_canonical = normalize_cvsroot (tmp_root); +- if (strcmp (cvsroot_canonical, tmp_root_canonical) == 0) +- password = p + 1; +- +- free (tmp_root_canonical); ++ switch (tmp_root->method) ++ { ++ case gserver_method: ++ case pserver_method: ++#ifdef HAVE_KERBEROS ++ case kserver_method: ++#endif /* HAVE_KERBEROS */ ++ tmp_root_canonical = normalize_cvsroot (tmp_root); ++ if (strcmp (cvsroot_canonical, tmp_root_canonical) == 0) ++ password = p + 1; ++ free (tmp_root_canonical); ++ break; ++ default: ++ break; ++ } + } + + return password; diff --git a/devel/cvs-devel/files/patch-parseopts b/devel/cvs-devel/files/patch-parseopts new file mode 100644 index 000000000000..7d1432950ff1 --- /dev/null +++ b/devel/cvs-devel/files/patch-parseopts @@ -0,0 +1,108 @@ +diff -Nur src/cvs.h src/cvs.h +--- src/cvs.h 2006-08-19 00:05:38.000000000 +0100 ++++ src/cvs.h 2006-08-19 00:05:41.000000000 +0100 +@@ -177,6 +177,7 @@ + #define CVSROOTADM_LOGINFO "loginfo" + #define CVSROOTADM_MODULES "modules" + #define CVSROOTADM_NOTIFY "notify" ++#define CVSROOTADM_OPTIONS "options" + #define CVSROOTADM_PASSWD "passwd" + #define CVSROOTADM_POSTADMIN "postadmin" + #define CVSROOTADM_POSTPROXY "postproxy" +@@ -506,6 +507,7 @@ + char *strcat_filename_onto_homedir (const char *, const char *); + char *cvs_temp_name (void); + FILE *cvs_temp_file (char **filename); ++void parseopts (const char *root); + + int ls (int argc, char *argv[]); + int unlink_file (const char *f); +diff -Nur src/main.c src/main.c +--- src/main.c 2006-08-19 00:05:38.000000000 +0100 ++++ src/main.c 2006-08-19 00:08:14.000000000 +0100 +@@ -1108,6 +1108,8 @@ + CVSROOT/config file to fix the broken one! */ + if (config) free_config (config); + config = parse_config (current_parsed_root->directory, NULL); ++ /* Now is a convenient time to read CVSROOT/options */ ++ parseopts(current_parsed_root->directory); + + /* Can set TMPDIR in the environment if necessary now, since + * if it was set in config, we now know it. +@@ -1482,5 +1484,63 @@ + exit (EXIT_FAILURE); + } + ++void ++parseopts(root) ++ const char *root; ++{ ++ char path[PATH_MAX]; ++ int save_errno; ++ char buf[1024]; ++ const char *p; ++ char *q; ++ FILE *fp; ++ ++ if (root == NULL) { ++ printf("no CVSROOT in parseopts\n"); ++ return; ++ } ++ p = strchr (root, ':'); ++ if (p) ++ p++; ++ else ++ p = root; ++ if (p == NULL) { ++ printf("mangled CVSROOT in parseopts\n"); ++ return; ++ } ++ (void) sprintf (path, "%s/%s/%s", p, CVSROOTADM, CVSROOTADM_OPTIONS); ++ if ((fp = fopen(path, "r")) != NULL) { ++ while (fgets(buf, sizeof buf, fp) != NULL) { ++ if (buf[0] == '#') ++ continue; ++ q = strrchr(buf, '\n'); ++ if (q) ++ *q = '\0'; ++ ++ if (!strncmp(buf, "tag=", 4)) { ++ char *what; ++ char *rcs_localid; ++ ++ rcs_localid = buf + 4; ++ RCS_setlocalid(path, 0, &config->keywords, rcs_localid); ++ } ++ if (!strncmp(buf, "tagexpand=", 10)) { ++ char *what; ++ char *rcs_incexc; ++ ++ rcs_incexc = buf + 10; ++ RCS_setincexc(&config->keywords, rcs_incexc); ++ } ++ /* ++ * OpenBSD has a "umask=" and "dlimit=" command, we silently ++ * ignore them here since they are not much use to us. cvsumask ++ * defaults to 002 already, and the dlimit (data size limit) ++ * should really be handled elsewhere (eg: login.conf). ++ */ ++ } ++ fclose(fp); ++ } ++} ++ + /* vim:tabstop=8:shiftwidth=4 + */ +diff -Nur src/server.c src/server.c +--- src/server.c 2006-08-19 00:05:38.000000000 +0100 ++++ src/server.c 2006-08-19 00:05:41.000000000 +0100 +@@ -985,6 +985,9 @@ + config->MaxCompressionLevel); + } + ++ /* Now is a good time to read CVSROOT/options too. */ ++ parseopts(current_parsed_root->directory); ++ + path = xmalloc (strlen (current_parsed_root->directory) + + sizeof (CVSROOTADM) + + 2); diff --git a/devel/cvs-devel/files/patch-rcs2log_POSIX_sort b/devel/cvs-devel/files/patch-rcs2log_POSIX_sort new file mode 100644 index 000000000000..7871ebd6cba2 --- /dev/null +++ b/devel/cvs-devel/files/patch-rcs2log_POSIX_sort @@ -0,0 +1,15 @@ +# Make rcs2log use POSIX 1003.1-2001 compliant `sort'. Closes: #368909 +# Patch taken from http://cvs.pld.org.pl/SOURCES/cvs-POSIX.patch?rev=1.1 , +# Thanks to the PLD Team. +diff -Nur contrib/rcs2log.sh.orig contrib/rcs2log.sh +--- contrib/rcs2log.sh.orig 2006-05-26 15:16:54.000000000 +0800 ++++ contrib/rcs2log.sh 2006-05-26 15:16:35.000000000 +0800 +@@ -649,7 +649,7 @@ + # Sort the log entries, first by date+time (in reverse order), + # then by author, then by log entry, and finally by file name and revision + # (just in case). +-sort -t"$SOH" +2 -4r +4 +0 | ++sort -t"$SOH" -k 3,4r -k 5 -k 1 | + + # Finally, reformat the sorted log entries. + $AWK -F"$SOH" ' diff --git a/devel/cvs-devel/files/patch-remove_-R_warning b/devel/cvs-devel/files/patch-remove_-R_warning new file mode 100644 index 000000000000..098e88a5af3a --- /dev/null +++ b/devel/cvs-devel/files/patch-remove_-R_warning @@ -0,0 +1,21 @@ +# +# Turn off read-only warning that breaks pserver client access. Doh! +# Closes: #319467, #264019 +# Patch by Steve McIntyre <steve@einval.com> +diff -Nur src/main.c src/main.c +--- src/main.c 2005-10-02 23:17:21.000000000 +0800 ++++ src/main.c 2006-02-26 18:23:04.000000000 +0800 +@@ -764,13 +764,6 @@ + if (argc < 1) + usage (usg); + +- if (readonlyfs && !really_quiet) { +- error (0, 0, +- "WARNING: Read-only repository access mode selected via `cvs -R'.\n\ +-Using this option to access a repository which some users write to may\n\ +-cause intermittent sandbox corruption."); +- } +- + /* Calculate the cvs global session ID */ + + { diff --git a/devel/cvs-devel/files/patch-rsc2log_fix b/devel/cvs-devel/files/patch-rsc2log_fix new file mode 100644 index 000000000000..4ac5ab23014c --- /dev/null +++ b/devel/cvs-devel/files/patch-rsc2log_fix @@ -0,0 +1,49 @@ +# +# Patch to make the rcs2log script cope with old-format (5 parameter) +# and new-format (6 parameter) log output. Bug#258140 +# +# Patch from Ludovic Rousseau <rousseau@debian.org> +diff -Nur contrib/rcs2log.sh contrib/rcs2log.sh +--- contrib/rcs2log.sh 2005-07-12 22:12:55.000000000 +0800 ++++ contrib/rcs2log.sh 2006-02-26 17:43:11.000000000 +0800 +@@ -416,11 +416,24 @@ + : ;; + esac >$llogout || exit + ++# the date format in 'cvs -q log' changed ++# it was ++# date: 2003/05/06 21:23:30; author: rousseau; state: Exp; lines: +29 -31 ++# it is now ++# date: 2003-05-06 21:23:30 +0000; author: rousseau; state: Exp; lines: +29 -31 + output_authors='/^date: / { +- if ($2 ~ /^[0-9]*[-\/][0-9][0-9][-\/][0-9][0-9]$/ && $3 ~ /^[0-9][0-9]:[0-9][0-9]:[0-9][0-9][-+0-9:]*;$/ && $4 == "author:" && $5 ~ /^[^;]*;$/) { +- print substr($5, 1, length($5)-1) +- } ++ # old date format ++ if ($2 ~ /^[0-9]*[-\/][0-9][0-9][-\/][0-9][0-9]$/ && $3 ~ /^[0-9][0-9]:[0-9][0-9]:[0-9][0-9][-+0-9:]*;$/ && $4 == "author:" && $5 ~ /^[^;]*;$/) { ++ print substr($5, 1, length($5)-1) ++ } ++ else { ++ # new date format ++ if ($2 ~ /^[0-9]*[-\/][0-9][0-9][-\/][0-9][0-9]$/ && $3 ~ /^[0-9][0-9]:[0-9][0-9]:[0-9][0-9][-+0-9:]*$/ && $5 == "author:" && $6 ~ /^[^;]*;$/) { ++ print substr($6, 1, length($6)-1) ++ } ++ } + }' ++ + authors=` + $AWK "$output_authors" <"$rlogfile" | sort -u | comm -23 - $llogout + ` +@@ -611,7 +624,11 @@ + date = newdate date + } + time = substr($3, 1, length($3) - 1) +- author = substr($5, 1, length($5)-1) ++ author = substr($5, 1, length($5)-1) ++ if (author ~ /author/) { ++ # new date format ++ author = substr($6, 1, length($6)-1) ++ } + printf "%s%s%s%s%s%s%s%s%s%s", filename, SOH, rev, SOH, date, SOH, time, SOH, author, SOH + rev = "?" + next diff --git a/devel/cvs-devel/files/patch-server_wrapper b/devel/cvs-devel/files/patch-server_wrapper new file mode 100644 index 000000000000..fe36aa6139b7 --- /dev/null +++ b/devel/cvs-devel/files/patch-server_wrapper @@ -0,0 +1,51 @@ +# +# Added patch to support cvs -W ! - clears all wrappers (patch also +# forwarded to CVS people) #3374 +# +# Patch by Michael Alan Dorman <mdorman@lot49.med.miami.edu> +diff -Nur src/wrapper.c src/wrapper.c +--- src/wrapper.c 2005-09-04 08:27:44.000000000 +0800 ++++ src/wrapper.c 2006-02-26 22:26:53.000000000 +0800 +@@ -86,7 +86,7 @@ + move this to a per-connection data structure, or better yet + think about a cleaner solution. */ + static int wrap_setup_already_done = 0; +- char *homedir; ++ char *homedir = NULL; + + if (wrap_setup_already_done != 0) + return; +@@ -107,6 +107,11 @@ + free (file); + } + ++#ifdef SERVER_SUPPORT ++ if (!server_active) ++#endif ++ { ++ + /* Then add entries found in home dir, (if user has one) and file + exists. */ + homedir = get_homedir (); +@@ -115,6 +120,8 @@ + hand it might be obnoxious to complain when CVS will function + just fine without .cvswrappers (and many users won't even know what + .cvswrappers is). */ ++ } ++ + if (homedir != NULL) + { + char *file = strcat_filename_onto_homedir (homedir, CVSDOTWRAPPER); +@@ -339,6 +346,12 @@ + if (!line || line[0] == '#') + return; + ++ /* Allows user to declare all wrappers null and void */ ++ if ( line[0] == '!') { ++ wrap_kill ( ); ++ return; ++ } ++ + memset (&e, 0, sizeof(e)); + + /* Search for the wild card */ diff --git a/devel/cvs-devel/files/patch-src-Makefile.in b/devel/cvs-devel/files/patch-src-Makefile.in deleted file mode 100644 index 274f9b32cc05..000000000000 --- a/devel/cvs-devel/files/patch-src-Makefile.in +++ /dev/null @@ -1,63 +0,0 @@ ---- src/Makefile.in.orig Mon Sep 29 19:06:14 2003 -+++ src/Makefile.in Tue Sep 30 11:26:22 2003 -@@ -80,7 +80,7 @@ - KRB4 = @KRB4@ - LDFLAGS = @LDFLAGS@ - LIBOBJS = @LIBOBJS@ --LIBS = @LIBS@ -+LIBS = @LIBS@ -lmd -lgnuregex -lz - LN_S = @LN_S@ - LTLIBOBJS = @LTLIBOBJS@ - MAINT = @MAINT@ -@@ -146,7 +146,7 @@ - # some namespace hackery going on that maybe shouldn't be. Long term fix is to - # try and remove naming ocnflicts and fix Automake to allow particular includes - # to be attached only to particular object files. Short term fix is either or. --INCLUDES = -I$(top_srcdir)/lib -I$(top_srcdir)/diff -I$(top_srcdir)/zlib $(includeopt) -+INCLUDES = -I$(top_srcdir)/lib -I$(top_srcdir)/diff $(includeopt) - - bin_PROGRAMS = cvs - bin_SCRIPTS = cvsbug -@@ -187,6 +187,7 @@ - no_diff.c \ - parseinfo.c \ - patch.c \ -+ prepend_args.c \ - rcs.c \ - rcscmds.c \ - recurse.c \ -@@ -224,8 +225,7 @@ - - cvs_LDADD = \ - ../diff/libdiff.a \ -- ../lib/libcvs.a \ -- ../zlib/libz.a -+ ../lib/libcvs.a - - - # extra clean targets -@@ -262,6 +262,7 @@ - main.$(OBJEXT) mkmodules.$(OBJEXT) modules.$(OBJEXT) \ - myndbm.$(OBJEXT) no_diff.$(OBJEXT) parseinfo.$(OBJEXT) \ - patch.$(OBJEXT) rcs.$(OBJEXT) rcscmds.$(OBJEXT) \ -+ prepend_args.$(OBJEXT) \ - recurse.$(OBJEXT) release.$(OBJEXT) remove.$(OBJEXT) \ - repos.$(OBJEXT) root.$(OBJEXT) run.$(OBJEXT) scramble.$(OBJEXT) \ - server.$(OBJEXT) status.$(OBJEXT) subr.$(OBJEXT) tag.$(OBJEXT) \ -@@ -293,7 +294,7 @@ - @AMDEP_TRUE@ ./$(DEPDIR)/main.Po ./$(DEPDIR)/mkmodules.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/modules.Po ./$(DEPDIR)/myndbm.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/no_diff.Po ./$(DEPDIR)/parseinfo.Po \ --@AMDEP_TRUE@ ./$(DEPDIR)/patch.Po ./$(DEPDIR)/rcs.Po \ -+@AMDEP_TRUE@ ./$(DEPDIR)/patch.Po ./$(DEPDIR)/prepend_args.Po ./$(DEPDIR)/rcs.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/rcscmds.Po ./$(DEPDIR)/recurse.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/release.Po ./$(DEPDIR)/remove.Po \ - @AMDEP_TRUE@ ./$(DEPDIR)/repos.Po ./$(DEPDIR)/root.Po \ -@@ -411,6 +412,7 @@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/no_diff.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/parseinfo.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/patch.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/prepend_args.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rcs.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rcscmds.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/recurse.Po@am__quote@ diff --git a/devel/cvs-devel/files/patch-zlib-read-compressed b/devel/cvs-devel/files/patch-zlib-read-compressed new file mode 100644 index 000000000000..e1d137e99264 --- /dev/null +++ b/devel/cvs-devel/files/patch-zlib-read-compressed @@ -0,0 +1,11 @@ +--- src/zlib.c~ 3 Jun 2005 18:26:09 -0000 1.31 ++++ src/zlib.c 27 Oct 2005 17:59:49 -0000 +@@ -229,7 +229,7 @@ compress_buffer_input (void *closure, ch + would fetch all the available bytes, and at least one byte. */ + + status = (*cb->buf->input) (cb->buf->closure, bd->text, +- need, BUFFER_DATA_SIZE, &nread); ++ need ? 1 : 0, BUFFER_DATA_SIZE, &nread); + + if (status == -2) + /* Don't try to recover from memory allcoation errors. */ diff --git a/devel/cvs-devel/pkg-descr b/devel/cvs-devel/pkg-descr index 4b5ee8151a8f..56a8a41e9110 100644 --- a/devel/cvs-devel/pkg-descr +++ b/devel/cvs-devel/pkg-descr @@ -1,3 +1,4 @@ -IPv6 enabled cvs. You can use IPv6 connection when using pserver. +The latest and, or feature release CVS (Concurrent Version System). IPv6 +enabled, you can use IPv6 connection when using pserver. WWW: http://www.cvshome.org/ diff --git a/devel/cvs-devel/pkg-plist b/devel/cvs-devel/pkg-plist index 2b82bbbcbbe0..ee011cfc0cb5 100644 --- a/devel/cvs-devel/pkg-plist +++ b/devel/cvs-devel/pkg-plist @@ -1,24 +1,30 @@ +@comment $FreeBSD$ +@unexec if [ -x /usr/bin/cvs.orig ]; then mv -f /usr/bin/cvs.orig /usr/bin/cvs; fi bin/cvs +@exec if [ ! -x /usr/bin/cvs.orig ]; then mv /usr/bin/cvs /usr/bin/cvs.orig; cp -p %D/%F /usr/bin/%F; fi +@unexec if [ -x /usr/bin/cvsbug.orig ]; then mv -f /usr/bin/cvsbug.orig /usr/bin/cvsbug; fi bin/cvsbug +@exec if [ ! -x /usr/bin/cvsbug.orig ]; then mv /usr/bin/cvsbug /usr/bin/cvsbug.orig; cp -p %D/%F /usr/bin/%F; fi bin/rcs2log share/cvs/contrib/README -share/cvs/contrib/check_cvs share/cvs/contrib/clmerge share/cvs/contrib/cln_hist share/cvs/contrib/commit_prep share/cvs/contrib/cvs2vendor share/cvs/contrib/cvs_acls -share/cvs/contrib/cvscheck -share/cvs/contrib/cvscheck.man share/cvs/contrib/debug_check_log share/cvs/contrib/intro.doc share/cvs/contrib/log share/cvs/contrib/log_accum share/cvs/contrib/mfpipe +share/cvs/contrib/newcvsroot share/cvs/contrib/pvcs2rcs +share/cvs/contrib/rcs-5.7-commitid.patch share/cvs/contrib/rcs-to-cvs share/cvs/contrib/rcs2log share/cvs/contrib/rcslock +share/cvs/contrib/sandbox_status share/cvs/contrib/sccs2rcs +share/cvs/contrib/validate_repo @dirrm share/cvs/contrib @dirrm share/cvs |