aboutsummaryrefslogtreecommitdiff
path: root/dirent/scandir.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@gmail.com>2011-08-08 13:49:37 -0400
committerUlrich Drepper <drepper@gmail.com>2011-08-08 13:49:37 -0400
commit879165f25a1a6b13995e43c11e88b1a21b6f101e (patch)
tree64b72b93baa2dd1f0f96bfb7e000c72d254f30af /dirent/scandir.c
parent16292eddd77f66002e2104848e75a0fb4d316692 (diff)
downloadglibc-879165f25a1a6b13995e43c11e88b1a21b6f101e.zip
glibc-879165f25a1a6b13995e43c11e88b1a21b6f101e.tar.gz
glibc-879165f25a1a6b13995e43c11e88b1a21b6f101e.tar.bz2
Avoid multiple definitions of identical scandir cancellation handler
Diffstat (limited to 'dirent/scandir.c')
-rw-r--r--dirent/scandir.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/dirent/scandir.c b/dirent/scandir.c
index 2e03578..e90b942 100644
--- a/dirent/scandir.c
+++ b/dirent/scandir.c
@@ -1,4 +1,5 @@
-/* Copyright (C) 1992-1998,2000,2002,2003,2009 Free Software Foundation, Inc.
+/* Copyright (C) 1992-1998,2000,2002,2003,2009,2011
+ Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -23,13 +24,13 @@
#include <bits/libc-lock.h>
#ifndef SCANDIR
-#define SCANDIR scandir
-#define READDIR __readdir
-#define DIRENT_TYPE struct dirent
+# define SCANDIR scandir
+# define READDIR __readdir
+# define DIRENT_TYPE struct dirent
#endif
#ifndef SCANDIR_CANCEL
-#define SCANDIR_CANCEL
+# define SCANDIR_CANCEL
struct scandir_cancel_struct
{
DIR *dp;
@@ -37,8 +38,9 @@ struct scandir_cancel_struct
size_t cnt;
};
-static void
-cancel_handler (void *arg)
+# ifndef SKIP_SCANDIR_CANCEL
+void
+__scandir_cancel_handler (void *arg)
{
struct scandir_cancel_struct *cp = arg;
size_t i;
@@ -49,6 +51,9 @@ cancel_handler (void *arg)
free (v);
(void) __closedir (cp->dp);
}
+# else
+extern void __scandir_cancel_handler (void *arg);
+# endif
#endif
@@ -75,7 +80,7 @@ SCANDIR (dir, namelist, select, cmp)
c.dp = dp;
c.v = NULL;
c.cnt = 0;
- __libc_cleanup_push (cancel_handler, &c);
+ __libc_cleanup_push (__scandir_cancel_handler, &c);
while ((d = READDIR (dp)) != NULL)
{