X-Git-Url: https://git.distorted.org.uk/u/mdw/catacomb/blobdiff_plain/d11a0bf77a5230387d222ec727865a898767ff3e..025c5f4aa5ffbf8948482a4233318db81c2df5d2:/key-file.c diff --git a/key-file.c b/key-file.c index ab620e7..6e422b1 100644 --- a/key-file.c +++ b/key-file.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: key-file.c,v 1.1 1999/12/22 15:47:48 mdw Exp $ + * $Id$ * * System-dependent key filing operations * @@ -27,14 +27,6 @@ * MA 02111-1307, USA. */ -/*----- Revision history --------------------------------------------------* - * - * $Log: key-file.c,v $ - * Revision 1.1 1999/12/22 15:47:48 mdw - * Major key-management revision. - * - */ - /*----- Header files ------------------------------------------------------*/ #include @@ -68,6 +60,7 @@ static int fdcopy(int source, int dest) { char buf[4096]; + char *p; if (lseek(source, 0, SEEK_SET) < 0|| lseek(dest, 0, SEEK_SET) < 0 || @@ -79,8 +72,14 @@ static int fdcopy(int source, int dest) return (-1); else if (n == 0) break; - else if (write(dest, buf, n) < 0) - return (-1); + p = buf; + while (n) { + int nn = write(dest, p, n); + if (nn < 0) + return (-1); + p += nn; + n -= nn; + } } return (0); } @@ -108,6 +107,8 @@ int key_save(key_file *f) if (!(f->f & KF_MODIFIED)) return (KWRITE_OK); + if (!f->fp) + return (KWRITE_FAIL); /* --- Write a new key file out --- * * @@ -271,7 +272,7 @@ fail_write: * * Arguments: @key_file *f@ = pointer to file structure to initialize * @const char *file@ = pointer to the file name - * @int how@ = opening options (@KOPEN_*@). + * @unsigned how@ = opening options (@KOPEN_*@). * * Returns: Zero if it worked, nonzero otherwise. * @@ -286,15 +287,22 @@ fail_write: * for the private use of @key_open@. */ -int key_lockfile(key_file *f, const char *file, int how) +int key_lockfile(key_file *f, const char *file, unsigned how) { int of, lf; const char *ff; int fd; + /* --- Handle the magic no-file option --- */ + + if (how & KOPEN_NOFILE) { + f->fp = 0; + return (0); + } + /* --- Lots of things depend on whether we're writing --- */ - switch (how) { + switch (how & KOPEN_MASK) { case KOPEN_READ: of = O_RDONLY; lf = LOCK_NONEXCL;