From 65d7792690eb257bdac6776e5ef0fe4261dc05c2 Mon Sep 17 00:00:00 2001 From: Jean-Francois Brousseau Date: Fri, 30 Jul 2004 16:52:14 +0000 Subject: When calling cvs_mkadmin(), only create the files if they don't already exist --- usr.bin/cvs/util.c | 65 +++++++++++++++++++++++++++++------------------------- 1 file changed, 35 insertions(+), 30 deletions(-) (limited to 'usr.bin/cvs') diff --git a/usr.bin/cvs/util.c b/usr.bin/cvs/util.c index 499c87ac537..adfd8854ba2 100644 --- a/usr.bin/cvs/util.c +++ b/usr.bin/cvs/util.c @@ -1,4 +1,4 @@ -/* $OpenBSD: util.c,v 1.4 2004/07/30 01:49:24 jfb Exp $ */ +/* $OpenBSD: util.c,v 1.5 2004/07/30 16:52:13 jfb Exp $ */ /* * Copyright (c) 2004 Jean-Francois Brousseau * All rights reserved. @@ -37,6 +37,7 @@ #include "cvs.h" #include "log.h" +#include "file.h" /* letter -> mode type map */ @@ -160,12 +161,12 @@ cvs_strtomode(const char *str, mode_t *mode) for (sp = ms; *sp != '\0'; sp++) { if ((*sp <= 'a') || (*sp >= 'z') || - (cvs_modes[type][*sp - 'a'] == 0)) { + (cvs_modes[(int)type][*sp - 'a'] == 0)) { cvs_log(LP_WARN, "invalid permission bit `%c'", *sp); } else - m |= cvs_modes[type][*sp - 'a']; + m |= cvs_modes[(int)type][*sp - 'a']; } } @@ -387,7 +388,8 @@ cvs_freeargv(char **argv, int argc) /* * cvs_mkadmin() * - * Create the CVS administrative files within the directory . + * Create the CVS administrative files within the directory . If the + * files already exist, they are kept as is. * Returns 0 on success, or -1 on failure. */ @@ -397,45 +399,49 @@ cvs_mkadmin(struct cvs_file *cdir, mode_t mode) char path[MAXPATHLEN]; FILE *fp; CVSENTRIES *ef; + struct stat st; struct cvsroot *root; snprintf(path, sizeof(path), "%s/" CVS_PATH_CVSDIR, cdir->cf_path); - if (mkdir(path, mode) == -1) { + if ((mkdir(path, mode) == -1) && (errno != EEXIST)) { cvs_log(LP_ERRNO, "failed to create directory %s", path); return (-1); } + /* just create an empty Entries file */ ef = cvs_ent_open(cdir->cf_path, O_WRONLY); (void)cvs_ent_close(ef); - snprintf(path, sizeof(path), "%s/" CVS_PATH_ROOTSPEC, cdir->cf_path); - fp = fopen(path, "w"); - if (fp == NULL) { - cvs_log(LP_ERRNO, "failed to open %s", path); - return (-1); - } root = cdir->cf_ddat->cd_root; - if (root->cr_user != NULL) { - fprintf(fp, "%s", root->cr_user); - if (root->cr_pass != NULL) - fprintf(fp, ":%s", root->cr_pass); - if (root->cr_host != NULL) - putc('@', fp); - } + snprintf(path, sizeof(path), "%s/" CVS_PATH_ROOTSPEC, cdir->cf_path); + if ((stat(path, &st) != 0) && (errno == ENOENT) && (root != NULL)) { + fp = fopen(path, "w"); + if (fp == NULL) { + cvs_log(LP_ERRNO, "failed to open %s", path); + return (-1); + } + if (root->cr_user != NULL) { + fprintf(fp, "%s", root->cr_user); + if (root->cr_pass != NULL) + fprintf(fp, ":%s", root->cr_pass); + if (root->cr_host != NULL) + putc('@', fp); + } - if (root->cr_host != NULL) { - fprintf(fp, "%s", root->cr_host); - if (root->cr_dir != NULL) - putc(':', fp); + if (root->cr_host != NULL) { + fprintf(fp, "%s", root->cr_host); + if (root->cr_dir != NULL) + putc(':', fp); + } + if (root->cr_dir) + fprintf(fp, "%s", root->cr_dir); + putc('\n', fp); + (void)fclose(fp); } - if (root->cr_dir) - fprintf(fp, "%s", root->cr_dir); - putc('\n', fp); - (void)fclose(fp); - if (cdir->cf_ddat->cd_repo != NULL) { - snprintf(path, sizeof(path), "%s/" CVS_PATH_REPOSITORY, - cdir->cf_path); + snprintf(path, sizeof(path), "%s/" CVS_PATH_REPOSITORY, cdir->cf_path); + if ((stat(path, &st) != 0) && (errno == ENOENT) && + (cdir->cf_ddat->cd_repo != NULL)) { fp = fopen(path, "w"); if (fp == NULL) { cvs_log(LP_ERRNO, "failed to open %s", path); @@ -445,6 +451,5 @@ cvs_mkadmin(struct cvs_file *cdir, mode_t mode) (void)fclose(fp); } - return (0); } -- cgit v1.2.3