diff options
author | Jean-Francois Brousseau <jfb@cvs.openbsd.org> | 2005-04-12 16:14:00 +0000 |
---|---|---|
committer | Jean-Francois Brousseau <jfb@cvs.openbsd.org> | 2005-04-12 16:14:00 +0000 |
commit | c6aad862a4fb4c528aa679b0bee714a4c0ea5645 (patch) | |
tree | 34a3ff76e7a98b4b60e051805c5ca668ec3cf447 /usr.bin | |
parent | df142819b3d1028518b52af7e7b7548ee8a1b252 (diff) |
* 'Up to date' --> 'Up-to-date', and add the 'Lost' status string
* first stab at cvs_status_local(), which will run the command in
local mode or remotely when acting as server (not hooked yet)
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/cvs/status.c | 136 |
1 files changed, 85 insertions, 51 deletions
diff --git a/usr.bin/cvs/status.c b/usr.bin/cvs/status.c index b0ea48ef2b6..afb2bd8b31f 100644 --- a/usr.bin/cvs/status.c +++ b/usr.bin/cvs/status.c @@ -1,4 +1,4 @@ -/* $OpenBSD: status.c,v 1.14 2005/04/12 14:58:40 joris Exp $ */ +/* $OpenBSD: status.c,v 1.15 2005/04/12 16:13:59 jfb Exp $ */ /* * Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -39,20 +39,26 @@ #include "proto.h" +#define CVS_STATUS_SEP \ + "===================================================================" + + const char *cvs_statstr[] = { "Unknown", - "Up to date", + "Up-to-date", "Locally Modified", "Added", "Removed", "Conflict", "Patched", + "Lost", }; -int cvs_status_file(CVSFILE *, void *); -int cvs_status_options(char *, int, char **, int *); -int cvs_status_sendflags(struct cvsroot *); +int cvs_status_file (CVSFILE *, void *); +int cvs_status_local (CVSFILE *, void *); +int cvs_status_options (char *, int, char **, int *); +int cvs_status_sendflags (struct cvsroot *); struct cvs_cmd_info cvs_status = { cvs_status_options, @@ -108,7 +114,7 @@ int cvs_status_file(CVSFILE *cfp, void *arg) { int ret; - char *repo, fpath[MAXPATHLEN], rcspath[MAXPATHLEN]; + char *repo, fpath[MAXPATHLEN]; RCSFILE *rf; struct cvs_ent *entp; struct cvsroot *root; @@ -119,63 +125,91 @@ cvs_status_file(CVSFILE *cfp, void *arg) repo = CVS_DIR_REPO(cfp); if (cfp->cf_type == DT_DIR) { - if (root->cr_method != CVS_METHOD_LOCAL) { - if (cfp->cf_cvstat == CVS_FST_UNKNOWN) - ret = cvs_sendreq(root, CVS_REQ_QUESTIONABLE, - CVS_FILE_NAME(cfp)); - else - ret = cvs_senddir(root, cfp); - } - + if (cfp->cf_cvstat == CVS_FST_UNKNOWN) + ret = cvs_sendreq(root, CVS_REQ_QUESTIONABLE, + CVS_FILE_NAME(cfp)); + else + ret = cvs_senddir(root, cfp); return (ret); } cvs_file_getpath(cfp, fpath, sizeof(fpath)); entp = cvs_ent_getent(fpath); - if (root->cr_method != CVS_METHOD_LOCAL) { - if ((entp != NULL) && (cvs_sendentry(root, entp) < 0)) { - cvs_ent_free(entp); - return (CVS_EX_PROTO); - } + if ((entp != NULL) && (cvs_sendentry(root, entp) < 0)) { + cvs_ent_free(entp); + return (-1); + } - switch (cfp->cf_cvstat) { - case CVS_FST_UNKNOWN: - ret = cvs_sendreq(root, CVS_REQ_QUESTIONABLE, - CVS_FILE_NAME(cfp)); - break; - case CVS_FST_UPTODATE: - ret = cvs_sendreq(root, CVS_REQ_UNCHANGED, - CVS_FILE_NAME(cfp)); - break; - case CVS_FST_MODIFIED: - ret = cvs_sendreq(root, CVS_REQ_MODIFIED, - CVS_FILE_NAME(cfp)); - if (ret == 0) - ret = cvs_sendfile(root, fpath); - default: - break; - } - } else { - if (cfp->cf_cvstat == CVS_FST_UNKNOWN) { - cvs_log(LP_WARN, "I know nothing about %s", fpath); - return (0); - } + switch (cfp->cf_cvstat) { + case CVS_FST_UNKNOWN: + ret = cvs_sendreq(root, CVS_REQ_QUESTIONABLE, + CVS_FILE_NAME(cfp)); + break; + case CVS_FST_UPTODATE: + ret = cvs_sendreq(root, CVS_REQ_UNCHANGED, + CVS_FILE_NAME(cfp)); + break; + case CVS_FST_MODIFIED: + ret = cvs_sendreq(root, CVS_REQ_MODIFIED, + CVS_FILE_NAME(cfp)); + if (ret == 0) + ret = cvs_sendfile(root, fpath); + default: + break; + } - snprintf(rcspath, sizeof(rcspath), "%s/%s/%s%s", - root->cr_dir, repo, CVS_FILE_NAME(cfp), RCS_FILE_EXT); + if (entp != NULL) + cvs_ent_free(entp); + return (ret); +} - rf = rcs_open(rcspath, RCS_READ); - if (rf == NULL) { - if (entp != NULL) - cvs_ent_free(entp); - return (CVS_EX_DATA); - } +int +cvs_status_local(CVSFILE *cfp, void *arg) +{ + char *repo, numbuf[64], fpath[MAXPATHLEN], rcspath[MAXPATHLEN]; + RCSFILE *rf; + struct cvs_ent *entp; + struct cvsroot *root; + + if (cfp->cf_type == DT_DIR) + return (0); + + root = CVS_DIR_ROOT(cfp); + repo = CVS_DIR_REPO(cfp); - rcs_close(rf); + cvs_file_getpath(cfp, fpath, sizeof(fpath)); + entp = cvs_ent_getent(fpath); + + if (cfp->cf_cvstat == CVS_FST_UNKNOWN) { + cvs_log(LP_WARN, "I know nothing about %s", fpath); + return (0); + } + + snprintf(rcspath, sizeof(rcspath), "%s/%s/%s%s", + root->cr_dir, repo, CVS_FILE_NAME(cfp), RCS_FILE_EXT); + + rf = rcs_open(rcspath, RCS_READ); + if (rf == NULL) { + if (entp != NULL) + cvs_ent_free(entp); + return (-1); } + cvs_printf(CVS_STATUS_SEP "\nFile: %-18sStatus: %s\n\n", + CVS_FILE_NAME(cfp), cvs_statstr[cfp->cf_cvstat]); + + rcsnum_tostr(entp->ce_rev, numbuf, sizeof(numbuf)); + cvs_printf(" Working revision: %s %s\n", numbuf, "date here"); + rcsnum_tostr(rf->rf_head, numbuf, sizeof(numbuf)); + cvs_printf(" Repository revision: %s %s\n", numbuf, rcspath); + cvs_printf(" Sticky Tag: %s\n", "(none)"); + cvs_printf(" Sticky Date: %s\n", "(none)"); + cvs_printf(" Sticky Options: %s\n", "(none)"); + + rcs_close(rf); + if (entp != NULL) cvs_ent_free(entp); - return (ret); + return (0); } |