summaryrefslogtreecommitdiff
path: root/bfd/cache.c
diff options
context:
space:
mode:
authorJerome Guitton <guitton@adacore.com>2004-06-17 11:47:51 +0000
committerJerome Guitton <guitton@adacore.com>2004-06-17 11:47:51 +0000
commit02d5a37b2d1262e7f7d877ba134350cadae67973 (patch)
tree205b91712ff52eb11310f26fcf9b6c67994cc935 /bfd/cache.c
parentd2bef492886e2d8828c191362b683a3391107991 (diff)
downloadbinutils-gdb-02d5a37b2d1262e7f7d877ba134350cadae67973.tar.gz
* bfd-in.h (bfd_cache_close_all): New function declaration.
* bfd-in2.h: Regenerate. * cache.c (bfd_cache_close_all): New function definition.
Diffstat (limited to 'bfd/cache.c')
-rw-r--r--bfd/cache.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/bfd/cache.c b/bfd/cache.c
index 58eda916bbc..63d4d786aea 100644
--- a/bfd/cache.c
+++ b/bfd/cache.c
@@ -344,6 +344,31 @@ bfd_cache_close (bfd *abfd)
}
/*
+FUNCTION
+ bfd_cache_close_all
+
+SYNOPSIS
+ bfd_boolean bfd_cache_close_all (void);
+
+DESCRIPTION
+ Remove all BFDs from the cache. If the attached file is open,
+ then close it too.
+
+RETURNS
+ <<FALSE>> is returned if closing one of the file fails, <<TRUE>> is
+ returned if all is well.
+*/
+
+bfd_boolean
+bfd_cache_close_all ()
+{
+ bfd_boolean ret = TRUE;
+
+ while (bfd_last_cache != NULL)
+ ret &= bfd_cache_close (bfd_last_cache);
+}
+
+/*
INTERNAL_FUNCTION
bfd_open_file