summaryrefslogtreecommitdiff
path: root/usr.bin/cvs
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/cvs')
-rw-r--r--usr.bin/cvs/cvs.h4
-rw-r--r--usr.bin/cvs/logmsg.c52
2 files changed, 39 insertions, 17 deletions
diff --git a/usr.bin/cvs/cvs.h b/usr.bin/cvs/cvs.h
index c9915a81e23..9b972c5a971 100644
--- a/usr.bin/cvs/cvs.h
+++ b/usr.bin/cvs/cvs.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cvs.h,v 1.32 2004/11/26 15:15:36 jfb Exp $ */
+/* $OpenBSD: cvs.h,v 1.33 2004/12/02 17:45:44 jfb Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -282,7 +282,7 @@ int cvs_hist_append (CVSHIST *, struct cvs_hent *);
/* from logmsg.c */
char* cvs_logmsg_open (const char *);
-char* cvs_logmsg_get (const char *);
+char* cvs_logmsg_get (const char *, struct cvs_flist *);
int cvs_logmsg_send (struct cvsroot *, const char *);
/* from util.c */
diff --git a/usr.bin/cvs/logmsg.c b/usr.bin/cvs/logmsg.c
index 5ac6c3ee50d..b9d0ea7ac54 100644
--- a/usr.bin/cvs/logmsg.c
+++ b/usr.bin/cvs/logmsg.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: logmsg.c,v 1.2 2004/11/26 16:23:50 jfb Exp $ */
+/* $OpenBSD: logmsg.c,v 1.3 2004/12/02 17:45:44 jfb Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -39,10 +39,9 @@
#include "proto.h"
-#define CVS_LOGMSG_TERMWIDTH 80
#define CVS_LOGMSG_BIGMSG 32000
#define CVS_LOGMSG_FTMPL "/tmp/cvsXXXXXXXXXX"
-#define CVS_LOGMSG_LOGPREFIX "CVS:"
+#define CVS_LOGMSG_PREFIX "CVS:"
#define CVS_LOGMSG_LOGLINE \
"----------------------------------------------------------------------"
@@ -124,8 +123,8 @@ cvs_logmsg_open(const char *path)
len = strlen(lbuf);
if (len == 0)
continue;
- else if ((lcont == 0) && (strncmp(lbuf, CVS_LOGMSG_LOGPREFIX,
- strlen(CVS_LOGMSG_LOGPREFIX)) == 0))
+ else if ((lcont == 0) && (strncmp(lbuf, CVS_LOGMSG_PREFIX,
+ strlen(CVS_LOGMSG_PREFIX)) == 0))
/* skip lines starting with the prefix */
continue;
@@ -150,12 +149,13 @@ cvs_logmsg_open(const char *path)
*/
char*
-cvs_logmsg_get(const char *dir)
+cvs_logmsg_get(const char *dir, struct cvs_flist *files)
{
- int ret, fd, argc, fds[3];
- size_t len;
- char *argv[4], buf[16], path[MAXPATHLEN], *msg;
+ int ret, fd, argc, fds[3], nl;
+ size_t len, tlen;
+ char *argv[4], buf[16], path[MAXPATHLEN], fpath[MAXPATHLEN], *msg;
FILE *fp;
+ CVSFILE *cvsfp;
struct stat st1, st2;
msg = NULL;
@@ -176,19 +176,41 @@ cvs_logmsg_get(const char *dir)
fp = fdopen(fd, "w");
if (fp == NULL) {
cvs_log(LP_ERRNO, "failed to fdopen");
+ (void)close(fd);
+ if (unlink(path) == -1)
+ cvs_log(LP_ERRNO, "failed to unlink temporary file");
+ return (NULL);
} else {
fprintf(fp,
"\n%s %s\n%s Enter Log. Lines beginning with `%s' are "
"removed automatically\n%s\n%s Commiting in %s\n"
- "%s\n%s Modified Files:\n",
- CVS_LOGMSG_LOGPREFIX, CVS_LOGMSG_LOGLINE,
- CVS_LOGMSG_LOGPREFIX, CVS_LOGMSG_LOGPREFIX,
- CVS_LOGMSG_LOGPREFIX, CVS_LOGMSG_LOGPREFIX,
- dir, CVS_LOGMSG_LOGPREFIX, CVS_LOGMSG_LOGPREFIX);
+ "%s\n",
+ CVS_LOGMSG_PREFIX, CVS_LOGMSG_LOGLINE,
+ CVS_LOGMSG_PREFIX, CVS_LOGMSG_PREFIX,
+ CVS_LOGMSG_PREFIX, CVS_LOGMSG_PREFIX,
+ dir, CVS_LOGMSG_PREFIX);
/* XXX list files here */
+ fprintf(fp, "%s Modified Files:", CVS_LOGMSG_PREFIX);
+ nl = 1;
+ TAILQ_FOREACH(cvsfp, files, cf_list) {
+ /* take the space into account */
+ cvs_file_getpath(cvsfp, fpath, sizeof(fpath));
+ len = strlen(fpath) + 1;
+ if (tlen + len >= 72)
+ nl = 1;
+
+ if (nl) {
+ fprintf(fp, "\n%s\t", CVS_LOGMSG_PREFIX);
+ tlen = 8;
+ nl = 0;
+ }
+
+ fprintf(fp, " %s", fpath);
+ tlen += len;
+ }
- fprintf(fp, "%s %s\n", CVS_LOGMSG_LOGPREFIX,
+ fprintf(fp, "\n%s %s\n", CVS_LOGMSG_PREFIX,
CVS_LOGMSG_LOGLINE);
}
(void)fflush(fp);