diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2004-07-27 23:12:56 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2004-07-27 23:12:56 +0000 |
commit | 1b94625f19c97c894443dfcb9b7df588215afafd (patch) | |
tree | 12d28dcbf1a16dec3913a6d2536063cad21c88d9 /.cvsignore | |
parent | bdf757d699347dd41cb19b2fcc7b7807edcec3fe (diff) | |
download | coreutils-1b94625f19c97c894443dfcb9b7df588215afafd.tar.xz |
backupfile.c rewrite to avoid arbitrary limits on lengths of
numeric backup extensions.
Include "backupfile.h" first.
Include errno.h, stdbool.h, limits.h, unistd.h, xalloc.h.
(CLOSEDIR, INT_STRLEN_BOUND): Remove.
(pathconf) [! (HAVE_PATHCONF && defined _PC_NAME_MAX)]: New macro.
(_POSIX_NAME_MAX) [!defined _POSIX_NAME_MAX]: New macro.
(NAME_MAX_MAXIMUM): New macro. Unlike the old addext.c, we
also look at _XOPEN_NAME_MAX, for better performance on modern
hosts that support only file names of length 255 or more.
(ISDIGIT): unsigned -> unsigned int
(max_backup_version, version_number): Remove.
(check_extension): New function. Similar to the old addext, but
static, assumes that the extension has already been added,
and a bit more careful on DOS hosts.
(numbered_backup): New function. It does what max_backup_version
and version_number used to do, but it doesn't use integer arithmetic
to calculate extensions so it doesn't overflow.
(find_backup_file_name): Rewrite to use these new functions.
This has a new optimization: we needn't call pathconf if the
new numbered backup name has the same length as the old.
Also, use xmalloc rather than malloc, so that the caller
needn't worry about memory exhaustion.
Diffstat (limited to '.cvsignore')
0 files changed, 0 insertions, 0 deletions