2016-09-27 22:01:08 +03:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2008-02-28 00:26:35 +03:00
|
|
|
#ifndef cmELF_h
|
|
|
|
#define cmELF_h
|
|
|
|
|
2016-09-01 21:59:28 +03:00
|
|
|
#include <cmConfigure.h>
|
|
|
|
|
|
|
|
#include <iosfwd>
|
|
|
|
#include <string>
|
|
|
|
|
2008-02-28 00:26:35 +03:00
|
|
|
#if !defined(CMAKE_USE_ELF_PARSER)
|
2016-05-16 17:34:04 +03:00
|
|
|
#error "This file may be included only if CMAKE_USE_ELF_PARSER is enabled."
|
2008-02-28 00:26:35 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
class cmELFInternal;
|
|
|
|
|
|
|
|
/** \class cmELF
|
|
|
|
* \brief Executable and Link Format (ELF) parser.
|
|
|
|
*/
|
|
|
|
class cmELF
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/** Construct with the name of the ELF input file to parse. */
|
|
|
|
cmELF(const char* fname);
|
|
|
|
|
|
|
|
/** Destruct. */
|
|
|
|
~cmELF();
|
|
|
|
|
|
|
|
/** Get the error message if any. */
|
2016-05-16 17:34:04 +03:00
|
|
|
std::string const& GetErrorMessage() const { return this->ErrorMessage; }
|
2008-02-28 00:26:35 +03:00
|
|
|
|
|
|
|
/** Boolean conversion. True if the ELF file is valid. */
|
|
|
|
operator bool() const { return this->Valid(); }
|
|
|
|
|
|
|
|
/** Enumeration of ELF file types. */
|
|
|
|
enum FileType
|
|
|
|
{
|
|
|
|
FileTypeInvalid,
|
|
|
|
FileTypeRelocatableObject,
|
|
|
|
FileTypeExecutable,
|
|
|
|
FileTypeSharedLibrary,
|
2008-03-03 00:19:40 +03:00
|
|
|
FileTypeCore,
|
|
|
|
FileTypeSpecificOS,
|
|
|
|
FileTypeSpecificProc
|
2008-02-28 00:26:35 +03:00
|
|
|
};
|
|
|
|
|
2008-02-29 19:12:59 +03:00
|
|
|
/** Represent string table entries. */
|
|
|
|
struct StringEntry
|
|
|
|
{
|
|
|
|
// The string value itself.
|
|
|
|
std::string Value;
|
|
|
|
|
|
|
|
// The position in the file at which the string appears.
|
|
|
|
unsigned long Position;
|
2008-03-01 20:50:42 +03:00
|
|
|
|
|
|
|
// The size of the string table entry. This includes the space
|
|
|
|
// allocated for one or more null terminators.
|
|
|
|
unsigned long Size;
|
2008-04-14 23:02:24 +04:00
|
|
|
|
|
|
|
// The index of the section entry referencing the string.
|
|
|
|
int IndexInSection;
|
2008-02-29 19:12:59 +03:00
|
|
|
};
|
|
|
|
|
2008-02-28 00:26:35 +03:00
|
|
|
/** Get the type of the file opened. */
|
|
|
|
FileType GetFileType() const;
|
|
|
|
|
|
|
|
/** Get the number of ELF sections present. */
|
|
|
|
unsigned int GetNumberOfSections() const;
|
|
|
|
|
2008-04-14 23:02:24 +04:00
|
|
|
/** Get the number of DYNAMIC section entries before the first
|
|
|
|
DT_NULL. Returns zero on error. */
|
|
|
|
unsigned int GetDynamicEntryCount() const;
|
|
|
|
|
|
|
|
/** Get the position of a DYNAMIC section header entry. Returns
|
|
|
|
zero on error. */
|
|
|
|
unsigned long GetDynamicEntryPosition(int index) const;
|
|
|
|
|
|
|
|
/** Read bytes from the file. */
|
|
|
|
bool ReadBytes(unsigned long pos, unsigned long size, char* buf) const;
|
|
|
|
|
2008-02-28 00:26:35 +03:00
|
|
|
/** Get the SONAME field if any. */
|
|
|
|
bool GetSOName(std::string& soname);
|
2008-02-29 19:12:59 +03:00
|
|
|
StringEntry const* GetSOName();
|
|
|
|
|
|
|
|
/** Get the RPATH field if any. */
|
|
|
|
StringEntry const* GetRPath();
|
|
|
|
|
|
|
|
/** Get the RUNPATH field if any. */
|
|
|
|
StringEntry const* GetRunPath();
|
2008-02-28 00:26:35 +03:00
|
|
|
|
|
|
|
/** Print human-readable information about the ELF file. */
|
|
|
|
void PrintInfo(std::ostream& os) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
friend class cmELFInternal;
|
|
|
|
bool Valid() const;
|
|
|
|
cmELFInternal* Internal;
|
|
|
|
std::string ErrorMessage;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|