diff options
-rw-r--r-- | usr.bin/cvs/rcs.c | 109 | ||||
-rw-r--r-- | usr.bin/cvs/rcs.h | 24 |
2 files changed, 119 insertions, 14 deletions
diff --git a/usr.bin/cvs/rcs.c b/usr.bin/cvs/rcs.c index 9f0e39e51af..33f39108c02 100644 --- a/usr.bin/cvs/rcs.c +++ b/usr.bin/cvs/rcs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rcs.c,v 1.26 2005/02/27 00:22:08 jfb Exp $ */ +/* $OpenBSD: rcs.c,v 1.27 2005/03/02 04:19:34 jfb Exp $ */ /* * Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -147,6 +147,7 @@ static struct rcs_key { #define RCS_NKEYS (sizeof(rcs_keys)/sizeof(rcs_keys[0])) +static int rcs_write (RCSFILE *); static int rcs_parse (RCSFILE *); static int rcs_parse_admin (RCSFILE *); static int rcs_parse_delta (RCSFILE *); @@ -314,7 +315,7 @@ rcs_close(RCSFILE *rfp) * path is in <rf_path>. * Returns 0 on success, or -1 on failure. */ -int +static int rcs_write(RCSFILE *rfp) { FILE *fp; @@ -453,6 +454,107 @@ rcs_sym_add(RCSFILE *rfp, const char *sym, RCSNUM *snum) /* + * rcs_sym_remove() + * + * Remove the symbol with name <sym> from the symbol list for the RCS file + * <file>. If no such symbol is found, the call fails and returns with an + * error. + * Returns 0 on success, or -1 on failure. + */ +int +rcs_sym_remove(RCSFILE *file, const char *sym) +{ + struct rcs_sym *symp; + + TAILQ_FOREACH(symp, &(file->rf_symbols), rs_list) + if (strcmp(symp->rs_name, sym) == 0) + break; + + if (symp == NULL) { + cvs_log(LP_ERR, "%s: no such symbol `%s'", file->rf_path, sym); + return (-1); + } + + TAILQ_REMOVE(&(file->rf_symbols), symp, rs_list); + free(symp->rs_name); + rcsnum_free(symp->rs_num); + free(symp); + + /* not synced anymore */ + file->rf_flags &= ~RCS_SYNCED; + + return (0); +} + + +/* + * rcs_sym_getrev() + * + * Retrieve the RCS revision number associated with the symbol <sym> for the + * RCS file <file>. The returned value is a dynamically-allocated copy and + * should be freed by the caller once they are done with it. + * Returns the RCSNUM on success, or NULL on failure. + */ +RCSNUM* +rcs_sym_getrev(RCSFILE *file, const char *sym) +{ + RCSNUM *num; + struct rcs_sym *symp; + + num = NULL; + + TAILQ_FOREACH(symp, &(file->rf_symbols), rs_list) + if (strcmp(symp->rs_name, sym) == 0) + break; + + if (symp == NULL) { + /* XXX set error */ + } else if (((num = rcsnum_alloc()) != NULL) && + (rcsnum_cpy(symp->rs_num, num, 0) < 0)) { + rcsnum_free(num); + num = NULL; + } + + return (num); +} + + +/* + * rcs_desc_get() + * + * Retrieve the description for the RCS file <file>. + */ +const char* +rcs_desc_get(RCSFILE *file) +{ + return (file->rf_desc); +} + + +/* + * rcs_desc_set() + * + * Set the description for the RCS file <file>. + * Returns 0 on success, or -1 on failure. + */ +int +rcs_desc_set(RCSFILE *file, const char *desc) +{ + char *tmp; + + if ((tmp = strdup(desc)) == NULL) + return (-1); + + if (file->rf_desc != NULL) + free(file->rf_desc); + file->rf_desc = tmp; + file->rf_flags &= ~RCS_SYNCED; + + return (0); +} + + +/* * rcs_patch() * * Apply an RCS-format patch pointed to by <patch> to the file contents @@ -766,7 +868,8 @@ rcs_kwexp_set(RCSFILE *file, int mode) return (-1); } - free(file->rf_expand); + if (file->rf_expand != NULL) + free(file->rf_expand); file->rf_expand = tmp; return (0); diff --git a/usr.bin/cvs/rcs.h b/usr.bin/cvs/rcs.h index 3731ff98965..fa4d8a8e06f 100644 --- a/usr.bin/cvs/rcs.h +++ b/usr.bin/cvs/rcs.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rcs.h,v 1.9 2005/02/27 00:22:08 jfb Exp $ */ +/* $OpenBSD: rcs.h,v 1.10 2005/03/02 04:19:34 jfb Exp $ */ /* * Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -145,16 +145,18 @@ typedef struct rcs_file { } RCSFILE; -RCSFILE* rcs_open (const char *, int, ...); -void rcs_close (RCSFILE *); -int rcs_write (RCSFILE *); -int rcs_sym_add (RCSFILE *, const char *, RCSNUM *); -int rcs_sym_remove (RCSFILE *, const char *); -BUF* rcs_getrev (RCSFILE *, RCSNUM *); -BUF* rcs_gethead (RCSFILE *); -RCSNUM* rcs_getrevbydate (RCSFILE *, struct tm *); -int rcs_kwexp_set (RCSFILE *, int); -int rcs_kwexp_get (RCSFILE *); +RCSFILE* rcs_open (const char *, int, ...); +void rcs_close (RCSFILE *); +int rcs_sym_add (RCSFILE *, const char *, RCSNUM *); +int rcs_sym_remove (RCSFILE *, const char *); +RCSNUM* rcs_sym_getrev (RCSFILE *, const char *); +BUF* rcs_getrev (RCSFILE *, RCSNUM *); +BUF* rcs_gethead (RCSFILE *); +RCSNUM* rcs_getrevbydate (RCSFILE *, struct tm *); +const char* rcs_desc_get (RCSFILE *); +int rcs_desc_set (RCSFILE *, const char *); +int rcs_kwexp_set (RCSFILE *, int); +int rcs_kwexp_get (RCSFILE *); int rcs_kflag_get (const char *); void rcs_kflag_usage (void); |