X-Git-Url: https://git.distorted.org.uk/~mdw/checkpath/blobdiff_plain/efa7a97bf01444f8bfdf25f488932912d3710974..c9c391b01d0a980200e7a4ab037086094d2461f1:/checkpath.c diff --git a/checkpath.c b/checkpath.c index 74eb243..4cf0e8f 100644 --- a/checkpath.c +++ b/checkpath.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: checkpath.c,v 1.1 1999/04/06 20:12:07 mdw Exp $ + * $Id: checkpath.c,v 1.3 1999/05/21 22:07:20 mdw Exp $ * * Check a path for safety * @@ -29,8 +29,14 @@ /*----- Revision history --------------------------------------------------* * * $Log: checkpath.c,v $ - * Revision 1.1 1999/04/06 20:12:07 mdw - * Initial revision + * Revision 1.3 1999/05/21 22:07:20 mdw + * Take advantage of new dynamic string macros. + * + * Revision 1.2 1999/05/18 20:49:12 mdw + * Use a dynamic string for reading symlinks. + * + * Revision 1.1.1.1 1999/04/06 20:12:07 mdw + * Import new project. * */ @@ -81,7 +87,7 @@ enum { static struct elt rootnode = { 0, 0, 0 }; /* Root of the list */ static struct elt *sp; /* Stack pointer for list */ -static dstr d; /* Current path string */ +static dstr d = DSTR_INIT; /* Current path string */ /*----- Main code ---------------------------------------------------------*/ @@ -211,13 +217,12 @@ static void report(struct chkpath *cp, int what, int verbose, /* --- Format the message nicely --- */ if (cp->cp_what & CP_REPORT) { - dstr d; + dstr d = DSTR_INIT; va_list ap; const char *q = msg; size_t n; int e = errno; - dstr_create(&d); va_start(ap, msg); if (verbose > 1) dstr_puts(&d, "[ "); @@ -352,7 +357,7 @@ int path_check(const char *p, struct chkpath *cp) struct stat st; int bad = 0; - /* --- Initialise stack pointer and path string --- */ + /* --- Initialize stack pointer and path string --- */ sp = &rootnode; dstr_destroy(&d); @@ -418,18 +423,19 @@ int path_check(const char *p, struct chkpath *cp) /* --- Handle symbolic links specially --- */ if (S_ISLNK(st.st_mode)) { - char buf[PATH_MAX]; + dstr buf = DSTR_INIT; int i; /* --- Resolve the link --- */ - if ((i = readlink(d.buf, buf, sizeof(buf))) < 0) { + dstr_ensure(&buf, st.st_size + 1); + if ((i = readlink(d.buf, buf.buf, buf.sz)) < 0) { report(cp, CP_ERROR, 0, d.buf, "can't readlink: %e"); bad |= CP_ERROR; break; } - buf[i] = 0; - report(cp, CP_SYMLINK, 2, d.buf, "symlink -> `%s'", buf); + buf.buf[i] = 0; + report(cp, CP_SYMLINK, 2, d.buf, "symlink -> `%s'", buf.buf); /* --- Handle sticky parents --- * * @@ -448,11 +454,12 @@ int path_check(const char *p, struct chkpath *cp) /* --- Sort out what to do from here --- */ - if (buf[0] == '/') + if (buf.buf[0] == '/') popall(); else pop(); - ee = splitpath(buf, ee); + ee = splitpath(buf.buf, ee); + dstr_destroy(&buf); continue; }