Expand description
§elb-dl
A library that resolves ELF dependencies without loading and executing them.
Based on elb
crate.
§Examples
§Resolve immediate dependencies
use elb_dl::{DependencyTree, DynamicLoader, Error, glibc};
fn resolve_immediate() -> Result<(), Error> {
let loader = DynamicLoader::options()
.search_dirs(glibc::get_search_dirs("/")?)
.new_loader();
let mut tree = DependencyTree::new();
let deps = loader.resolve_dependencies("/bin/sh", &mut tree)?;
for path in deps.iter() {
eprintln!("{:?}", path);
}
Ok(())
}
§Resolve dependencies recursively
use elb_dl::{DependencyTree, DynamicLoader, Error, glibc};
use std::collections::{BTreeSet, VecDeque};
use std::path::Path;
fn resolve_all() -> Result<(), Error> {
let loader = DynamicLoader::options()
.search_dirs(glibc::get_search_dirs("/")?)
.new_loader();
let mut tree = DependencyTree::new();
let mut queue = VecDeque::new();
queue.push_back(Path::new("/bin/sh").to_path_buf());
while let Some(path) = queue.pop_front() {
let deps = loader.resolve_dependencies(&path, &mut tree)?;
queue.extend(deps);
}
// Print dependency table.
for (dependent, dependencies) in tree.iter() {
eprintln!("{dependent:?} => {dependencies:?}");
}
Ok(())
}
Modules§
- glibc
glibc
- Functionality specific to GNU libc’s implementation of the dynamic loader.
- musl
musl
- Functionality specific to musl libc’s implementation of the dynamic loader.
Structs§
- Dependency
Tree - Dependency table.
- Dynamic
Loader - Dynamic loader.
- ElfRelocator
relocate
- Relocates ELF together with its dependencies.
- Loader
Options - Dynamic loader options.
Enums§
Functions§
- get_
search_ dirs_ from_ env - Get library search directories from the environment variables.