elf_next
— provide
sequential access to the next archive member
ELF Access Library (libelf, -lelf)
#include
<libelf.h>
Elf_Cmd
elf_next
(Elf
*elf);
The
elf_next
()
function causes the ELF archive descriptor corresponding to argument
elf to be adjusted to provide access to the next
member in the archive on a subsequent call to
elf_begin
().
The return value of
elf_next
()
is suitable for use in a loop invoking
elf_begin
().
If successful, function elf_next
() returns
the value ELF_C_READ
. Otherwise, if argument
elf was not associated with an archive, or if it was
NULL
, or if any other error occurred, the value
ELF_C_NULL
is returned.
To process all the members of an archive use:
Elf_Cmd cmd;
Elf *archive, *e;
...
cmd = ELF_C_READ;
archive = elf_begin(fd, cmd, NULL);
while ((e = elf_begin(fd, cmd, archive)) != (Elf *) 0)
{
... process `e' here ...
cmd = elf_next(e);
elf_end(e);
}
elf_end(archive);
Function elf_next
() may fail with the
following error:
- [
ELF_E_ARGUMENT
]
- Argument elf was not associated with a containing
ar(1)
archive.
- [
ELF_E_ARGUMENT
]
- An error was encountered while parsing the archive containing argument
elf.