summaryrefslogtreecommitdiff
path: root/usr.bin/cvs
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/cvs')
-rw-r--r--usr.bin/cvs/checkout.c9
-rw-r--r--usr.bin/cvs/cvs.h3
-rw-r--r--usr.bin/cvs/update.c18
3 files changed, 27 insertions, 3 deletions
diff --git a/usr.bin/cvs/checkout.c b/usr.bin/cvs/checkout.c
index e86bd49de4c..ce59cb2c704 100644
--- a/usr.bin/cvs/checkout.c
+++ b/usr.bin/cvs/checkout.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: checkout.c,v 1.64 2006/06/19 05:05:17 joris Exp $ */
+/* $OpenBSD: checkout.c,v 1.65 2006/07/01 20:30:46 reyk Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -176,6 +176,13 @@ cvs_checkout_file(struct cvs_file *cf, RCSNUM *rnum, BUF *bp, int flags)
nbp = rcs_kwexp_buf(bp, cf->file_rcs, rnum);
+ if (flags & CO_DUMP) {
+ if (cvs_buf_write_fd(nbp, STDOUT_FILENO) == -1)
+ fatal("cvs_checkout_file: %s", strerror(errno));
+ cvs_buf_free(nbp);
+ return;
+ }
+
oflags = O_WRONLY | O_TRUNC;
if (cf->fd != -1) {
exists = 1;
diff --git a/usr.bin/cvs/cvs.h b/usr.bin/cvs/cvs.h
index fd14180dbae..381e35f80e8 100644
--- a/usr.bin/cvs/cvs.h
+++ b/usr.bin/cvs/cvs.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cvs.h,v 1.114 2006/06/19 05:05:17 joris Exp $ */
+/* $OpenBSD: cvs.h,v 1.115 2006/07/01 20:30:46 reyk Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -356,5 +356,6 @@ int update_has_conflict_markers(struct cvs_file *);
#define CO_MERGE 0x01
#define CO_SETSTICKY 0x02
+#define CO_DUMP 0x04
#endif
diff --git a/usr.bin/cvs/update.c b/usr.bin/cvs/update.c
index b0ceafc04ac..d5955e3fa28 100644
--- a/usr.bin/cvs/update.c
+++ b/usr.bin/cvs/update.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: update.c,v 1.75 2006/06/19 05:05:17 joris Exp $ */
+/* $OpenBSD: update.c,v 1.76 2006/07/01 20:30:46 reyk Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -23,6 +23,7 @@
int cvs_update(int, char **);
int prune_dirs = 0;
+int dump = 0;
int build_dirs = 0;
int reset_stickies = 0;
static char *tag = NULL;
@@ -77,6 +78,7 @@ cvs_update(int argc, char **argv)
prune_dirs = 1;
break;
case 'p':
+ dump = 1;
break;
case 'Q':
case 'q':
@@ -244,6 +246,7 @@ cvs_update_local(struct cvs_file *cf)
BUF *bp;
int ret, flags;
CVSENTRIES *entlist;
+ char rbuf[16];
cvs_log(LP_TRACE, "cvs_update_local(%s)", cf->file_path);
@@ -271,6 +274,19 @@ cvs_update_local(struct cvs_file *cf)
cf->file_rcsrev = rcs_head_get(cf->file_rcs);
}
+ if (dump && cf->file_status != FILE_UNKNOWN) {
+ bp = rcs_getrev(cf->file_rcs, cf->file_rcsrev);
+ if (bp == NULL)
+ fatal("cvs_update_local: failed to get HEAD");
+ rcsnum_tostr(cf->file_rcsrev, rbuf, sizeof(rbuf));
+ if (verbosity > 1)
+ cvs_printf("%s\nChecking out %s\n"
+ "RCS:\t%s\nVERS:\t%s\n***************\n",
+ RCS_DIFF_DIV, cf->file_path, cf->file_rpath, rbuf);
+ cvs_checkout_file(cf, cf->file_rcsrev, bp, CO_DUMP);
+ return;
+ }
+
switch (cf->file_status) {
case FILE_UNKNOWN:
cvs_printf("? %s\n", cf->file_path);