dirname.c (98937) | dirname.c (106121) |
---|---|
1/* $OpenBSD: dirname.c,v 1.6 2001/06/28 04:27:19 pjanzen Exp $ */ | 1/* $OpenBSD: dirname.c,v 1.7 2002/05/24 21:22:37 deraadt Exp $ */ |
2 3/* 4 * Copyright (c) 1997 Todd C. Miller <Todd.Miller@courtesan.com> 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: --- 16 unchanged lines hidden (view full) --- 26 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 27 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 */ 29 30#include "includes.h" 31#ifndef HAVE_DIRNAME 32 33#if defined(LIBC_SCCS) && !defined(lint) | 2 3/* 4 * Copyright (c) 1997 Todd C. Miller <Todd.Miller@courtesan.com> 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: --- 16 unchanged lines hidden (view full) --- 26 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 27 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 */ 29 30#include "includes.h" 31#ifndef HAVE_DIRNAME 32 33#if defined(LIBC_SCCS) && !defined(lint) |
34static char rcsid[] = "$OpenBSD: dirname.c,v 1.6 2001/06/28 04:27:19 pjanzen Exp $"; | 34static char rcsid[] = "$OpenBSD: dirname.c,v 1.7 2002/05/24 21:22:37 deraadt Exp $"; |
35#endif /* LIBC_SCCS and not lint */ 36 37#include <errno.h> 38#include <string.h> 39#include <sys/param.h> 40 41char * 42dirname(path) 43 const char *path; 44{ 45 static char bname[MAXPATHLEN]; 46 register const char *endp; 47 48 /* Empty or NULL string gets treated as "." */ 49 if (path == NULL || *path == '\0') { | 35#endif /* LIBC_SCCS and not lint */ 36 37#include <errno.h> 38#include <string.h> 39#include <sys/param.h> 40 41char * 42dirname(path) 43 const char *path; 44{ 45 static char bname[MAXPATHLEN]; 46 register const char *endp; 47 48 /* Empty or NULL string gets treated as "." */ 49 if (path == NULL || *path == '\0') { |
50 (void)strcpy(bname, "."); | 50 (void)strlcpy(bname, ".", sizeof bname); |
51 return(bname); 52 } 53 54 /* Strip trailing slashes */ 55 endp = path + strlen(path) - 1; 56 while (endp > path && *endp == '/') 57 endp--; 58 59 /* Find the start of the dir */ 60 while (endp > path && *endp != '/') 61 endp--; 62 63 /* Either the dir is "/" or there are no slashes */ 64 if (endp == path) { | 51 return(bname); 52 } 53 54 /* Strip trailing slashes */ 55 endp = path + strlen(path) - 1; 56 while (endp > path && *endp == '/') 57 endp--; 58 59 /* Find the start of the dir */ 60 while (endp > path && *endp != '/') 61 endp--; 62 63 /* Either the dir is "/" or there are no slashes */ 64 if (endp == path) { |
65 (void)strcpy(bname, *endp == '/' ? "/" : "."); | 65 (void)strlcpy(bname, *endp == '/' ? "/" : ".", sizeof bname); |
66 return(bname); 67 } else { 68 do { 69 endp--; 70 } while (endp > path && *endp == '/'); 71 } 72 73 if (endp - path + 2 > sizeof(bname)) { 74 errno = ENAMETOOLONG; 75 return(NULL); 76 } 77 strlcpy(bname, path, endp - path + 2); 78 return(bname); 79} 80#endif | 66 return(bname); 67 } else { 68 do { 69 endp--; 70 } while (endp > path && *endp == '/'); 71 } 72 73 if (endp - path + 2 > sizeof(bname)) { 74 errno = ENAMETOOLONG; 75 return(NULL); 76 } 77 strlcpy(bname, path, endp - path + 2); 78 return(bname); 79} 80#endif |