diff options
author | Joris Vink <joris@cvs.openbsd.org> | 2005-10-15 23:39:37 +0000 |
---|---|---|
committer | Joris Vink <joris@cvs.openbsd.org> | 2005-10-15 23:39:37 +0000 |
commit | d445f839b3e8dd6df691ad459da3b966c0a11311 (patch) | |
tree | b692d6a86317330193406d5ae02fe696672d0702 /usr.bin | |
parent | 279bbf31701028d14e8aee0c36a1287df4f6e43d (diff) |
RCSINIT support;
ok niallo@
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/rcs/rcsprog.c | 67 | ||||
-rw-r--r-- | usr.bin/rcs/rcsprog.h | 3 |
2 files changed, 66 insertions, 4 deletions
diff --git a/usr.bin/rcs/rcsprog.c b/usr.bin/rcs/rcsprog.c index b259797a2d9..c382feea62d 100644 --- a/usr.bin/rcs/rcsprog.c +++ b/usr.bin/rcs/rcsprog.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rcsprog.c,v 1.28 2005/10/13 12:35:30 joris Exp $ */ +/* $OpenBSD: rcsprog.c,v 1.29 2005/10/15 23:39:36 joris Exp $ */ /* * Copyright (c) 2005 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -42,6 +42,8 @@ #include "rcsprog.h" #include "strtab.h" +#define RCS_CMD_MAXARG 128 + const char rcs_version[] = "OpenCVS RCS version 3.6"; int verbose = 1; @@ -63,6 +65,48 @@ struct rcs_prog { }; int +rcs_init(char *envstr, char **argv, int argvlen) +{ + u_int i; + int argc, error; + char linebuf[256], *lp, *cp; + + strlcpy(linebuf, envstr, sizeof(linebuf)); + memset(argv, 0, argvlen * sizeof(char *)); + + error = argc = 0; + for (lp = linebuf; lp != NULL;) { + cp = strsep(&lp, " \t\b\f\n\r\t\v");; + if (cp == NULL) + break; + else if (*cp == '\0') + continue; + + if (argc == argvlen) { + error++; + break; + } + + argv[argc] = strdup(cp); + if (argv[argc] == NULL) { + cvs_log(LP_ERRNO, "failed to copy argument"); + error++; + break; + } + + argc++; + } + + if (error != 0) { + for (i = 0; i < (u_int)argc; i++) + free(argv[i]); + argc = -1; + } + + return (argc); +} + +int rcs_getopt(int argc, char **argv, const char *optstr) { char *a; @@ -164,17 +208,34 @@ int main(int argc, char **argv) { u_int i; - int ret; + char *rcsinit, *cmd_argv[RCS_CMD_MAXARG]; + int ret, cmd_argc; ret = -1; rcs_optind = 1; cvs_strtab_init(); cvs_log_init(LD_STD, 0); + cmd_argc = 0; + if ((rcsinit = getenv("RCSINIT")) != NULL) { + cmd_argv[cmd_argc++] = argv[0]; + ret = rcs_init(rcsinit, cmd_argv + 1, + RCS_CMD_MAXARG - 1); + if (ret < 0) { + cvs_log(LP_ERRNO, "failed to prepend RCSINIT options"); + exit (1); + } + + cmd_argc += ret; + } + + for (ret = 1; ret < argc; ret++) + cmd_argv[cmd_argc++] = argv[ret]; + for (i = 0; i < (sizeof(programs)/sizeof(programs[0])); i++) if (strcmp(__progname, programs[i].prog_name) == 0) { usage = programs[i].prog_usage; - ret = programs[i].prog_hdlr(argc, argv); + ret = programs[i].prog_hdlr(cmd_argc, cmd_argv); break; } diff --git a/usr.bin/rcs/rcsprog.h b/usr.bin/rcs/rcsprog.h index 27e8ece22f4..663f0d948ec 100644 --- a/usr.bin/rcs/rcsprog.h +++ b/usr.bin/rcs/rcsprog.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rcsprog.h,v 1.11 2005/10/15 18:26:24 niallo Exp $ */ +/* $OpenBSD: rcsprog.h,v 1.12 2005/10/15 23:39:36 joris Exp $ */ /* * Copyright (c) 2005 Joris Vink <joris@openbsd.org> * All rights reserved. @@ -46,6 +46,7 @@ void rlog_usage(void); void ident_usage(void); void (*usage)(void); +int rcs_init(char *, char **, int); int rcs_getopt(int, char **, const char *); int rcs_statfile(char *, char *, size_t); int checkout_rev(RCSFILE *, RCSNUM *, const char *, int, const char *); |