79 lines
2.7 KiB
C
79 lines
2.7 KiB
C
|
/* Extract the last component (base name) of a file name.
|
||
|
|
||
|
Copyright (C) 1998, 2001, 2003-2006, 2009-2022 Free Software Foundation,
|
||
|
Inc.
|
||
|
|
||
|
This file is free software: you can redistribute it and/or modify
|
||
|
it under the terms of the GNU Lesser General Public License as
|
||
|
published by the Free Software Foundation; either version 2.1 of the
|
||
|
License, or (at your option) any later version.
|
||
|
|
||
|
This file is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU Lesser General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU Lesser General Public License
|
||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||
|
|
||
|
#ifndef _BASENAME_LGPL_H
|
||
|
#define _BASENAME_LGPL_H
|
||
|
|
||
|
#include <stddef.h>
|
||
|
|
||
|
#ifndef DOUBLE_SLASH_IS_DISTINCT_ROOT
|
||
|
# define DOUBLE_SLASH_IS_DISTINCT_ROOT 0
|
||
|
#endif
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
|
||
|
/* Return the address of the last file name component of FILENAME.
|
||
|
If FILENAME has some trailing slash(es), they are considered to be
|
||
|
part of the last component.
|
||
|
If FILENAME has no relative file name components because it is a file
|
||
|
system root, return the empty string.
|
||
|
Examples:
|
||
|
FILENAME RESULT
|
||
|
"foo.c" "foo.c"
|
||
|
"foo/bar.c" "bar.c"
|
||
|
"/foo/bar.c" "bar.c"
|
||
|
"foo/bar/" "bar/"
|
||
|
"foo/bar//" "bar//"
|
||
|
"/" ""
|
||
|
"//" ""
|
||
|
"" ""
|
||
|
The return value is a tail of the given FILENAME; do NOT free() it! */
|
||
|
|
||
|
/* This function was traditionally called 'basename', but we avoid this
|
||
|
function name because
|
||
|
* Various platforms have different functions in their libc.
|
||
|
In particular, the glibc basename(), defined in <string.h>, does
|
||
|
not consider trailing slashes to be part of the component:
|
||
|
FILENAME RESULT
|
||
|
"foo/bar/" ""
|
||
|
"foo/bar//" ""
|
||
|
* The 'basename' command eliminates trailing slashes and for a root
|
||
|
produces a non-empty result:
|
||
|
FILENAME RESULT
|
||
|
"foo/bar/" "bar"
|
||
|
"foo/bar//" "bar"
|
||
|
"/" "/"
|
||
|
"//" "/"
|
||
|
*/
|
||
|
extern char *last_component (char const *filename) _GL_ATTRIBUTE_PURE;
|
||
|
|
||
|
/* Return the length of the basename FILENAME.
|
||
|
Typically FILENAME is the value returned by base_name or last_component.
|
||
|
Act like strlen (FILENAME), except omit all trailing slashes. */
|
||
|
extern size_t base_len (char const *filename) _GL_ATTRIBUTE_PURE;
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
} /* extern "C" */
|
||
|
#endif
|
||
|
|
||
|
#endif /* _BASENAME_LGPL_H */
|