2017-03-30 16:56:49 +02:00
< p align = "center" >
< img width = "40%" src = "http://romainthomas.fr/logo_blue_with_name_500.png" / > < br / >
< / p >
< hr >
< p >
< a href = "https://gitter.im/lief-project" >
< img src = "https://img.shields.io/gitter/room/gitterHQ/gitter.svg" >
< / a >
2017-04-03 18:44:00 +02:00
< a href = "https://travis-ci.org/lief-project/LIEF" >
< img src = "https://travis-ci.org/lief-project/LIEF.svg?branch=master" >
< / a >
2017-04-03 19:18:22 +02:00
2017-07-06 17:41:18 +02:00
< a href = "https://circleci.com/gh/lief-project/LIEF/tree/master" >
< img src = "https://circleci.com/gh/lief-project/LIEF/tree/master.svg?style=svg" >
< / a >
2017-04-03 19:18:22 +02:00
< a href = "https://ci.appveyor.com/project/Romain/lief/branch/master" >
< img src = "https://ci.appveyor.com/api/projects/status/0ijlcujac5vh8cas/branch/master?svg=true" >
< / a >
2017-04-04 09:25:18 +02:00
< a href = "https://github.com/lief-project/LIEF/releases" >
2017-10-14 21:16:32 +02:00
< img src = "https://img.shields.io/badge/release-0.8.0-brightgreen.svg?style=default" >
2017-04-04 09:25:18 +02:00
< / a >
2017-03-30 16:56:49 +02:00
< / p >
The purpose of this project is to provide a cross platform library which can parse, modify and abstract ELF, PE and MachO formats.
Main features:
* **Parsing**: LIEF can parse ELF, PE, MachO and provides an user-friendly API to access to format internals.
* **Modify**: LIEF enables to modify some parts of these formats
* **Abstract**: Three formats have common features like sections, symbols, entry point... LIEF factors them.
* **API**: LIEF can be used in C, C++ and Python
2017-04-07 09:33:29 +02:00
2017-04-07 09:34:05 +02:00
## Downloads / Install
2017-04-07 09:33:29 +02:00
Pre-built packages are automatically generated and uploaded by continuous integration services.
2017-07-13 09:49:31 +02:00
Latest **tagged** version can be downloaded in the [Release ](https://github.com/lief-project/LIEF/releases ) section.
2017-07-14 11:13:59 +02:00
Pre-built packages from the [master ](https://github.com/lief-project/LIEF/tree/master )'s **latest commit** are automatically uploaded in the [*lief-project/packages* ](https://github.com/lief-project/packages ) repository:
2017-07-13 09:49:31 +02:00
2017-10-14 21:16:32 +02:00
:warning: *master* **SDK** packages have a same name as *tagged* packages (e.g. ``LIEF-0.8.0-Linux.tar.gz` `) :warning:
2017-07-25 17:06:30 +02:00
2017-10-14 21:16:32 +02:00
:warning: *master* **Python** package has ``dev`` suffix (e.g. ``pylief-0.8.0.dev.zip` `) :warning:
2017-07-13 09:49:31 +02:00
< table >
< tr > < td colspan = "4" > < img src = "https://img.shields.io/badge/release-master-brightgreen.svg?style=default" > < / td > < / tr >
< tr >
< th > Linux< / th >
< th > Windows - x86< / th >
< th > Windows - x86-64< / th >
< th > OSX< / th >
< / tr >
< tr >
2017-10-14 21:16:32 +02:00
< td > < a href = "https://github.com/lief-project/packages/raw/lief-master-latest/LIEF-0.8.0-Linux.tar.gz" > SDK< / a > < / td >
< td > < a href = "https://github.com/lief-project/packages/raw/lief-master-latest/LIEF-0.8.0-win32.zip" > SDK< / a > < / td >
< td > < a href = "https://github.com/lief-project/packages/raw/lief-master-latest/LIEF-0.8.0-win64.zip" > SDK< / a > < / td >
< td > < a href = "https://github.com/lief-project/packages/raw/lief-master-latest/LIEF-0.8.0-Darwin.tar.gz" > SDK< / a > < / td >
2017-07-13 09:49:31 +02:00
< / tr >
< tr >
2017-10-14 21:16:32 +02:00
< td colspan = "4" > < p align = "center" > < a href = "https://github.com/lief-project/packages/raw/lief-master-latest/pylief-0.8.0.dev.zip" > Python< / a > < / p > < / td >
2017-07-13 09:49:31 +02:00
< / tr >
2017-10-15 08:16:15 +02:00
< / table >
< table >
2017-10-15 08:23:44 +02:00
< tr > < td colspan = "6" > < b > < img src = "https://img.shields.io/badge/release-0.8.0-brightgreen.svg?style=default" > < / b > < / td > < / tr >
2017-10-15 08:16:15 +02:00
< tr >
< th > Linux< / th >
2017-10-15 08:23:44 +02:00
< th > Windows< / th >
2017-10-15 08:16:15 +02:00
< th > OSX< / th >
< th > CentOS< / th >
< th > Android< / th >
< th > Documentation< / th >
< / tr >
2017-07-13 09:49:31 +02:00
< tr >
2017-10-14 21:16:32 +02:00
< td > < a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Linux.tar.gz" > SDK< / a > < / td >
2017-10-15 08:23:44 +02:00
< td >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-win32.zip" > SDK - x86< / a >
< br / >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-win64.zip" > SDK - x86-64< / a >
< / td >
2017-10-14 21:16:32 +02:00
< td > < a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Darwin.tar.gz" > SDK< / a > < / td >
2017-10-15 08:16:15 +02:00
< td > < a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-CentOS.tar.gz" > SDK< / a > < / td >
< td >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Android_x86_64.tar.gz" > SDK - x86-64< / a >
< br / >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Android_x86.tar.gz" > SDK - x86< / a >
< br / >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Android_armeabi-v7a.tar.gz" > SDK - ARM< / a >
< br / >
< a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/LIEF-0.8.0-Android_aarch64.tar.gz" > SDK - AARCH64< / a >
< / td >
< td > < a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/documentation-0.8.0.tar.gz" > Sphinx + Doxygen< / a > < / td >
2017-07-13 09:49:31 +02:00
< / tr >
< tr >
2017-10-15 08:23:44 +02:00
< td colspan = "3" > < p align = "center" > < a href = "https://github.com/lief-project/LIEF/releases/download/0.8.0/pylief-0.8.0.zip" > Python< / a > < / p > < / td >
2017-07-13 09:49:31 +02:00
< / tr >
< / table >
2017-04-07 09:33:29 +02:00
2017-07-12 16:50:09 +02:00
Here one can find guides to install or integrate LIEF:
* [Python ](https://lief.quarkslab.com/doc/installation.html#python )
* [VisualStudio ](https://lief.quarkslab.com/doc/installation.html#visual-studio-integration )
* [XCode ](https://lief.quarkslab.com/doc/installation.html#xcode-integration )
* [CMake ](https://lief.quarkslab.com/doc/installation.html#cmake-integration )
2017-03-30 16:56:49 +02:00
## Getting started
### Python
```python
import lief
# ELF
binary = lief.parse("/usr/bin/ls")
print(binary)
# PE
binary = lief.parse("C:\\Windows\\explorer.exe")
print(binary)
# Mach-O
binary = lief.parse("/usr/bin/ls")
print(binary)
```
### C++
```cpp
#include <LIEF/LIEF.hpp>
int main(int argc, const char** argv) {
LIEF::ELF::Binary* elf = LIEF::ELF::Parser::parse("/usr/bin/ls");
LIEF::PE::Binary* pe = LIEF::PE::Parser::parse("C:\\Windows\\explorer.exe");
LIEF::MachO::Binary* macho = LIEF::MachO::Parser::parse("/usr/bin/ls");
std::cout < < *elf < < std::endl ;
std::cout < < *pe < < std::endl ;
std::cout < < *macho < < std::endl ;
delete elf;
delete pe;
delete macho;
}
```
### C
```cpp
#include <LIEF/LIEF.h>
int main(int argc, const char** argv) {
Elf_Binary_t* elf_binary = elf_parse("/usr/bin/ls");
Pe_Binary_t* pe_binary = pe_parse("C:\\Windows\\explorer.exe");
Macho_Binary_t** macho_binaries = macho_parse("/usr/bin/ls");
Pe_Section_t** pe_sections = pe_binary->sections;
Elf_Section_t** elf_sections = elf_binary->sections;
Macho_Section_t** macho_sections = macho_binaries[0]->sections;
for (size_t i = 0; pe_sections[i] != NULL; ++i) {
printf("%s\n", pe_sections[i]->name)
}
for (size_t i = 0; elf_sections[i] != NULL; ++i) {
printf("%s\n", elf_sections[i]->name)
}
for (size_t i = 0; macho_sections[i] != NULL; ++i) {
printf("%s\n", macho_sections[i]->name)
}
elf_binary_destroy(elf_binary);
pe_binary_destroy(pe_binary);
macho_binaries_destroy(macho_binaries);
}
```
## Documentation
2017-04-03 17:46:27 +02:00
* [Main documentation ](http://lief.quarkslab.com/doc/index.html )
* [Tutorial ](http://lief.quarkslab.com/doc/tutorials/index.html )
* [API ](http://lief.quarkslab.com/doc/api/index.html )
* [Doxygen ](http://lief.quarkslab.com/doxygen/index.html )
2017-03-30 16:56:49 +02:00
2017-04-28 16:36:31 +02:00
## Contact
2017-03-30 16:56:49 +02:00
* **Mail**: lief at quarkslab com
* **Gitter**: [lief-project ](https://gitter.im/lief-project )
## Authors
2017-04-04 10:05:51 +02:00
Romain Thomas ([@rh0main ](https://twitter.com/rh0main )) - [Quarkslab ](https://www.quarkslab.com )
2017-03-30 16:56:49 +02:00
2017-04-04 09:25:18 +02:00
---------------
2017-04-03 17:46:27 +02:00
< p align = "center" >
< img width = "40%" src = "http://lief.quarkslab.com/resources/QB-big.png" / >
< / p >
2017-03-30 16:56:49 +02:00