aboutsummaryrefslogtreecommitdiff
path: root/grp
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1999-06-08 20:25:31 +0000
committerUlrich Drepper <drepper@redhat.com>1999-06-08 20:25:31 +0000
commit1dc3d266ef6f3d8b0091ebfbb982859ca35ead50 (patch)
tree9303e136bf25a668b6fa1176da59f2bc2893c03d /grp
parentUpdate. (diff)
downloadglibc-1dc3d266ef6f3d8b0091ebfbb982859ca35ead50.tar.gz
glibc-1dc3d266ef6f3d8b0091ebfbb982859ca35ead50.tar.bz2
glibc-1dc3d266ef6f3d8b0091ebfbb982859ca35ead50.zip
Update.
* grp/fgetgrent.c (buffer): Make file local variable. (free_mem): New function. Call for malloc debugging.
Diffstat (limited to 'grp')
-rw-r--r--grp/fgetgrent.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/grp/fgetgrent.c b/grp/fgetgrent.c
index ac8d093f05..d2e3de69a7 100644
--- a/grp/fgetgrent.c
+++ b/grp/fgetgrent.c
@@ -26,11 +26,12 @@
/* We need to protect the dynamic buffer handling. */
__libc_lock_define_initialized (static, lock);
+static char *buffer;
+
/* Read one entry from the given stream. */
struct group *
fgetgrent (FILE *stream)
{
- static char *buffer;
static size_t buffer_size;
static struct group resbuf;
fpos_t pos;
@@ -85,3 +86,14 @@ fgetgrent (FILE *stream)
return result;
}
+
+
+/* Free all resources if necessary. */
+static void __attribute__ ((unused))
+free_mem (void)
+{
+ if (buffer != NULL)
+ free (buffer);
+}
+
+text_set_element (__libc_subfreeres, free_mem);