summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoris Vink <joris@cvs.openbsd.org>2007-01-03 22:28:31 +0000
committerJoris Vink <joris@cvs.openbsd.org>2007-01-03 22:28:31 +0000
commit36b0c9e066cc83ad9bbae99899730308b0b802eb (patch)
treeb5c55a3542f5b9f561e594756a325960b55bd1f3
parent154ac13620baabf42e54a1cd83dcec4f9fc9d6ec (diff)
add support for 'remove' in a remote setup.
testing appriciated, as always.
-rw-r--r--usr.bin/cvs/checkout.c13
-rw-r--r--usr.bin/cvs/client.c21
-rw-r--r--usr.bin/cvs/commit.c19
-rw-r--r--usr.bin/cvs/remote.h3
-rw-r--r--usr.bin/cvs/remove.c21
-rw-r--r--usr.bin/cvs/server.c25
6 files changed, 55 insertions, 47 deletions
diff --git a/usr.bin/cvs/checkout.c b/usr.bin/cvs/checkout.c
index 1d0cd273148..bc4f9ff2eb6 100644
--- a/usr.bin/cvs/checkout.c
+++ b/usr.bin/cvs/checkout.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: checkout.c,v 1.68 2007/01/03 20:48:26 joris Exp $ */
+/* $OpenBSD: checkout.c,v 1.69 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -263,14 +263,11 @@ cvs_checkout_file(struct cvs_file *cf, RCSNUM *rnum, BUF *bp, int flags)
if ((p = strrchr(cf->file_rpath, ',')) != NULL)
*p = '\0';
- if (flags & CO_COMMIT) {
- cvs_server_send_response("Checked-in %s/",
- cf->file_wd);
- } else {
- cvs_server_send_response("Updated %s/", cf->file_wd);
- }
+ if (flags & CO_COMMIT)
+ cvs_server_update_entry("Checked-in", cf);
+ else
+ cvs_server_update_entry("Updated", cf);
- cvs_remote_output(cf->file_rpath);
cvs_remote_output(entry);
if (!(flags & CO_COMMIT)) {
diff --git a/usr.bin/cvs/client.c b/usr.bin/cvs/client.c
index 77207d19d50..ccb1a0823c6 100644
--- a/usr.bin/cvs/client.c
+++ b/usr.bin/cvs/client.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: client.c,v 1.43 2007/01/03 21:00:43 joris Exp $ */
+/* $OpenBSD: client.c,v 1.44 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -591,8 +591,9 @@ cvs_client_checkedin(char *data)
fatal("cvs_client_checkedin: overflow");
}
- l = snprintf(entry, CVS_ENT_MAXLINELEN, "/%s/%s/%s//%s/",
- newent->ce_name, rev, timebuf, sticky);
+ l = snprintf(entry, CVS_ENT_MAXLINELEN, "/%s/%s%s/%s//%s/",
+ newent->ce_name, (newent->ce_status == CVS_ENT_REMOVED) ? "-" : "",
+ rev, timebuf, sticky);
if (l == -1 || l >= CVS_ENT_MAXLINELEN)
fatal("cvs_client_checkedin: overflow");
@@ -710,27 +711,19 @@ cvs_client_removed(char *data)
void
cvs_client_remove_entry(char *data)
{
- int l;
CVSENTRIES *entlist;
- char *filename, *rpath, *fpath;
+ char *filename, *rpath;
rpath = cvs_remote_input();
if ((filename = strrchr(rpath, '/')) == NULL)
fatal("bad rpath in cvs_client_remove_entry: %s", rpath);
*filename++;
- fpath = xmalloc(MAXPATHLEN);
- l = snprintf(fpath, MAXPATHLEN, "%s%s", data, filename);
- if (l == -1 || l >= MAXPATHLEN)
- fatal("cvs_client_remove_entry: overflow");
-
- xfree(rpath);
-
entlist = cvs_ent_open(data);
- cvs_ent_remove(entlist, fpath);
+ cvs_ent_remove(entlist, filename);
cvs_ent_close(entlist, ENT_SYNC);
- xfree(fpath);
+ xfree(rpath);
}
void
diff --git a/usr.bin/cvs/commit.c b/usr.bin/cvs/commit.c
index c11902e7415..29c5aeab00c 100644
--- a/usr.bin/cvs/commit.c
+++ b/usr.bin/cvs/commit.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: commit.c,v 1.84 2007/01/03 20:48:26 joris Exp $ */
+/* $OpenBSD: commit.c,v 1.85 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
* Copyright (c) 2006 Xavier Santolaria <xsa@openbsd.org>
@@ -358,6 +358,9 @@ cvs_commit_local(struct cvs_file *cf)
xfree(repo);
xfree(attic);
+
+ if (cvs_server_active == 1)
+ cvs_server_update_entry("Remove-entry", cf);
}
if (verbosity > 1)
@@ -366,20 +369,6 @@ cvs_commit_local(struct cvs_file *cf)
cvs_log(LP_NOTICE, "checking in '%s'; revision %s -> %s",
cf->file_path, rbuf, nbuf);
}
-
- if (cvs_server_active == 1) {
- if ((p = strrchr(cf->file_rpath, ',')) != NULL)
- *p = '\0';
-
- if (cf->file_status == FILE_REMOVED) {
- cvs_server_send_response("Remove-entry %s/",
- cf->file_wd);
- cvs_remote_output(cf->file_rpath);
- }
-
- if (p != NULL)
- *p = ',';
- }
}
static char *
diff --git a/usr.bin/cvs/remote.h b/usr.bin/cvs/remote.h
index 8966d72788e..80df1555137 100644
--- a/usr.bin/cvs/remote.h
+++ b/usr.bin/cvs/remote.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: remote.h,v 1.16 2007/01/03 19:27:28 joris Exp $ */
+/* $OpenBSD: remote.h,v 1.17 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -84,6 +84,7 @@ void cvs_server_set(char *);
void cvs_server_static_directory(char *);
void cvs_server_sticky(char *);
void cvs_server_update_patches(char *);
+void cvs_server_update_entry(const char *, struct cvs_file *cf);
void cvs_server_add(char *);
void cvs_server_admin(char *);
diff --git a/usr.bin/cvs/remove.c b/usr.bin/cvs/remove.c
index edd580f62b3..2046759accb 100644
--- a/usr.bin/cvs/remove.c
+++ b/usr.bin/cvs/remove.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: remove.c,v 1.57 2006/12/14 09:31:17 xsa Exp $ */
+/* $OpenBSD: remove.c,v 1.58 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2005, 2006 Xavier Santolaria <xsa@openbsd.org>
*
@@ -98,7 +98,7 @@ cvs_remove(int argc, char **argv)
}
if (removed != 0) {
- if (verbosity > 1) {
+ if (verbosity > 0) {
cvs_log(LP_NOTICE,
"use '%s commit' to remove %s "
"permanently", __progname, (removed > 1) ?
@@ -147,7 +147,7 @@ cvs_remove_local(struct cvs_file *cf)
cf->file_name);
existing++;
} else {
- switch(cf->file_status) {
+ switch (cf->file_status) {
case FILE_ADDED:
entlist = cvs_ent_open(cf->file_wd);
cvs_ent_remove(entlist, cf->file_name);
@@ -167,7 +167,7 @@ cvs_remove_local(struct cvs_file *cf)
}
return;
case FILE_REMOVED:
- if (verbosity > 1 ) {
+ if (verbosity > 0) {
cvs_log(LP_ERR,
"file `%s' already scheduled for removal",
cf->file_name);
@@ -187,13 +187,18 @@ cvs_remove_local(struct cvs_file *cf)
if (l == -1 || l >= CVS_ENT_MAXLINELEN)
fatal("cvs_remove_local: overflow");
- entlist = cvs_ent_open(cf->file_wd);
- cvs_ent_add(entlist, entry);
- cvs_ent_close(entlist, ENT_SYNC);
+ if (cvs_server_active == 1) {
+ cvs_server_update_entry("Checked-in", cf);
+ cvs_remote_output(entry);
+ } else {
+ entlist = cvs_ent_open(cf->file_wd);
+ cvs_ent_add(entlist, entry);
+ cvs_ent_close(entlist, ENT_SYNC);
+ }
xfree(entry);
- if (verbosity > 1) {
+ if (verbosity > 0) {
cvs_log(LP_NOTICE,
"scheduling file `%s' for removal",
cf->file_name);
diff --git a/usr.bin/cvs/server.c b/usr.bin/cvs/server.c
index 1cc91a8f058..91c7aa05886 100644
--- a/usr.bin/cvs/server.c
+++ b/usr.bin/cvs/server.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: server.c,v 1.46 2006/12/19 14:11:21 xsa Exp $ */
+/* $OpenBSD: server.c,v 1.47 2007/01/03 22:28:30 joris Exp $ */
/*
* Copyright (c) 2006 Joris Vink <joris@openbsd.org>
*
@@ -587,3 +587,26 @@ cvs_server_version(char *data)
cvs_version(server_argc, server_argv);
cvs_server_send_response("ok");
}
+
+void
+cvs_server_update_entry(const char *resp, struct cvs_file *cf)
+{
+ int l;
+ char *p, *response;
+
+ if ((p = strrchr(cf->file_rpath, ',')) != NULL)
+ *p = '\0';
+
+ response = xmalloc(MAXPATHLEN);
+ l = snprintf(response, MAXPATHLEN, "%s %s/", resp, cf->file_wd);
+ if (l == -1 || l >= MAXPATHLEN)
+ fatal("cvs_server_update_entry: overflow");
+
+ cvs_server_send_response("%s", response);
+ cvs_remote_output(cf->file_rpath);
+
+ if (p != NULL)
+ *p = ',';
+
+ xfree(response);
+}