summaryrefslogtreecommitdiff
path: root/usr.bin/cvs/commit.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/cvs/commit.c')
-rw-r--r--usr.bin/cvs/commit.c138
1 files changed, 133 insertions, 5 deletions
diff --git a/usr.bin/cvs/commit.c b/usr.bin/cvs/commit.c
index 263da620078..88f03c4b755 100644
--- a/usr.bin/cvs/commit.c
+++ b/usr.bin/cvs/commit.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: commit.c,v 1.2 2004/07/30 01:49:22 jfb Exp $ */
+/* $OpenBSD: commit.c,v 1.3 2004/11/09 20:59:31 krapht Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -40,11 +40,16 @@
#include "proto.h"
+#define CVS_COMMIT_BIGMSG 8000
+#define CVS_COMMIT_FTMPL "/tmp/cvsXXXXXXXXXX"
+#define CVS_COMMIT_LOGPREFIX "CVS:"
+#define CVS_COMMIT_LOGLINE \
+"----------------------------------------------------------------------"
-static char* cvs_commit_openmsg (const char *);
-
+static char* cvs_commit_openmsg (const char *);
+static char* cvs_commit_getmsg (const char *);
/*
@@ -63,6 +68,10 @@ cvs_commit(int argc, char **argv)
mfile = NULL;
msg = NULL;
+#if 0
+ cvs_commit_getmsg(".");
+#endif
+
while ((ch = getopt(argc, argv, "F:flm:R")) != -1) {
switch (ch) {
case 'F':
@@ -112,9 +121,9 @@ cvs_commit(int argc, char **argv)
static char*
cvs_commit_openmsg(const char *path)
{
- int fd;
+ int fd, ch;
size_t sz;
- char *msg;
+ char buf[32], *msg;
struct stat st;
if (stat(path, &st) == -1) {
@@ -122,6 +131,35 @@ cvs_commit_openmsg(const char *path)
return (NULL);
}
+ if (!S_ISREG(st.st_mode)) {
+ cvs_log(LP_ERR, "message file must be a regular file");
+ return (NULL);
+ }
+
+ if (st.st_size > CVS_COMMIT_BIGMSG) {
+ do {
+ fprintf(stderr,
+ "The specified message file seems big. "
+ "Proceed anyways? (y/n) ");
+ if (fgets(buf, sizeof(buf), stdin) == NULL) {
+ cvs_log(LP_ERRNO,
+ "failed to read from standard input");
+ return (NULL);
+ }
+
+ sz = strlen(buf);
+ if ((sz == 0) || (sz > 2)) {
+ continue;
+ }
+
+ cvs_log(LP_ERR, "aborted by user");
+ return (NULL);
+ }
+
+ fprintf(stderr, "Invalid character\n");
+ } while (1);
+ }
+
sz = st.st_size + 1;
msg = (char *)malloc(sz);
@@ -144,3 +182,93 @@ cvs_commit_openmsg(const char *path)
return (msg);
}
+
+
+/*
+ * cvs_commit_getmsg()
+ *
+ * Get a commit log message by forking the user's editor.
+ * Returns the message in a dynamically allocated string on success, NULL on
+ * failure.
+ */
+
+static char*
+cvs_commit_getmsg(const char *dir)
+{
+ int ret, fd, argc, fds[3];
+ char *argv[4], path[MAXPATHLEN], *msg;
+ FILE *fp;
+
+ fds[0] = -1;
+ fds[1] = -1;
+ fds[2] = -1;
+ strlcpy(path, CVS_COMMIT_FTMPL, sizeof(path));
+ argc = 0;
+ argv[argc++] = cvs_editor;
+ argv[argc++] = path;
+ argv[argc] = NULL;
+
+ if ((fd = mkstemp(path)) == -1) {
+ cvs_log(LP_ERRNO, "failed to create temporary file");
+ return (NULL);
+ }
+
+ fp = fdopen(fd, "w");
+ if (fp == NULL) {
+ cvs_log(LP_ERRNO, "failed to fdopen");
+ exit(1);
+ } 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_COMMIT_LOGPREFIX, CVS_COMMIT_LOGLINE,
+ CVS_COMMIT_LOGPREFIX, CVS_COMMIT_LOGPREFIX,
+ CVS_COMMIT_LOGPREFIX, CVS_COMMIT_LOGPREFIX,
+ dir, CVS_COMMIT_LOGPREFIX, CVS_COMMIT_LOGPREFIX);
+
+ /* XXX list files here */
+
+ fprintf(fp, "%s %s\n", CVS_COMMIT_LOGPREFIX,
+ CVS_COMMIT_LOGLINE);
+ }
+ (void)fflush(fp);
+ (void)fclose(fp);
+
+ do {
+ ret = cvs_exec(argc, argv, fds);
+ if (ret == -1) {
+ fprintf(stderr,
+ "Log message unchanged or not specified\n"
+ "a)bort, c)ontinue, e)dit, !)reuse this message "
+ "unchanged for remaining dirs\nAction: () ");
+
+ ret = getchar();
+ if (ret == 'a') {
+ cvs_log(LP_ERR, "aborted by user");
+ break;
+ } else if (ret == 'c') {
+ } else if (ret == 'e') {
+ } else if (ret == '!') {
+ }
+
+ }
+ } while (0);
+
+ (void)close(fd);
+
+ return (msg);
+}
+
+
+/*
+ * cvs_commit_gettmpl()
+ *
+ * Get the template to display when invoking the editor to get a commit
+ * message.
+ */
+
+cvs_commit_gettmpl(void)
+{
+
+}