ELF Library Functions elf_strptr(3ELF)
NAME
elf_strptr - make a string pointer
SYNOPSIS
cc [ flag ... ] file ... -lelf [ library ... ]
#include
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 sectiontable 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 typeSHT_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 thee_shstrndx member. The following code loops through the sec-
tions, 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(5) for descriptions of the following attri-
butes:SunOS 5.11 Last change: 11 Jul 2001 1
ELF Library Functions elf_strptr(3ELF)
____________________________________________________________
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
|_____________________________|_____________________________|
| Interface Stability | Committed ||_____________________________|_____________________________|
| MT-Level | MT-Safe |
|_____________________________|_____________________________|
SEE ALSO
elf(3ELF), elf32_getshdr(3ELF), elf32_xlatetof(3ELF),
elf_getdata(3ELF), libelf(3LIB), attributes(5)
NOTESA 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 usingelf_strptr().
SunOS 5.11 Last change: 11 Jul 2001 2