ELF_STRPTR(3ELF) ELF Library Functions ELF_STRPTR(3ELF)
NAME
elf_strptr - make a string pointer
SYNOPSIS
cc [
flag ... ]
file ...
-lelf [
library ... ]
#include <libelf.h>
char *elf_strptr(
Elf *elf,
size_t section,
size_t offset);
DESCRIPTION
The
elf_strptr() function converts a string section
offset to a
string pointer.
elf identifies the file in which the string section
resides, and
section identifies the section table index for the
strings.
elf_strptr() normally returns a pointer to a string, but it
returns a null pointer when
elf is null,
section is invalid or is not
a section of type
SHT_STRTAB, the section data cannot be obtained,
offset is invalid, or an error occurs.
EXAMPLES
Example 1: A sample program of calling elf_strptr() function.
A prototype for retrieving section names appears below. The file
header specifies the section name string table in the
e_shstrndx member. The following code loops through the sections, printing their
names.
/* handle the error */ if ((ehdr = elf32_getehdr(elf)) == 0) { return; } ndx = ehdr->e_shstrndx; scn = 0; while ((scn = elf_nextscn(elf, scn)) != 0) { char *name = 0; if ((shdr = elf32_getshdr(scn)) != 0) name = elf_strptr(elf, ndx, (size_t)shdr->sh_name); printf("'%s'\n", name? name: "(null)"); }ATTRIBUTES
See
attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Stable |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+
SEE ALSO
elf(3ELF),
elf32_getshdr(3ELF),
elf32_xlatetof(3ELF),
elf_getdata(3ELF),
libelf(3LIB),
attributes(7)NOTES
A program may call
elf_getdata() to retrieve an entire string table
section. For some applications, that would be both more efficient and
more convenient than using
elf_strptr().
July 11, 2001 ELF_STRPTR(3ELF)