aboutsummaryrefslogtreecommitdiff
path: root/vendor/object/README.md
diff options
context:
space:
mode:
authorValentin Popov <valentin@popov.link>2024-01-08 00:21:28 +0300
committerValentin Popov <valentin@popov.link>2024-01-08 00:21:28 +0300
commit1b6a04ca5504955c571d1c97504fb45ea0befee4 (patch)
tree7579f518b23313e8a9748a88ab6173d5e030b227 /vendor/object/README.md
parent5ecd8cf2cba827454317368b68571df0d13d7842 (diff)
downloadfparkan-1b6a04ca5504955c571d1c97504fb45ea0befee4.tar.xz
fparkan-1b6a04ca5504955c571d1c97504fb45ea0befee4.zip
Initial vendor packages
Signed-off-by: Valentin Popov <valentin@popov.link>
Diffstat (limited to 'vendor/object/README.md')
-rw-r--r--vendor/object/README.md56
1 files changed, 56 insertions, 0 deletions
diff --git a/vendor/object/README.md b/vendor/object/README.md
new file mode 100644
index 0000000..08d9c80
--- /dev/null
+++ b/vendor/object/README.md
@@ -0,0 +1,56 @@
+# `object`
+
+The `object` crate provides a unified interface to working with object files
+across platforms. It supports reading relocatable object files and executable files,
+and writing COFF/ELF/Mach-O/XCOFF relocatable object files and ELF/PE executable files.
+
+For reading files, it provides multiple levels of support:
+
+* raw struct definitions suitable for zero copy access
+* low level APIs for accessing the raw structs ([example](crates/examples/src/readobj/))
+* a higher level unified API for accessing common features of object files, such
+ as sections and symbols ([example](crates/examples/src/objdump.rs))
+
+Supported file formats: ELF, Mach-O, Windows PE/COFF, Wasm, XCOFF, and Unix archive.
+
+## Example for unified read API
+```rust
+use object::{Object, ObjectSection};
+use std::error::Error;
+use std::fs;
+
+/// Reads a file and displays the name of each section.
+fn main() -> Result<(), Box<dyn Error>> {
+ let binary_data = fs::read("path/to/binary")?;
+ let file = object::File::parse(&*binary_data)?;
+ for section in file.sections() {
+ println!("{}", section.name()?);
+ }
+ Ok(())
+}
+```
+
+See [`crates/examples`](crates/examples) for more examples.
+
+## Minimum Supported Rust Version (MSRV)
+
+Changes to MSRV are considered breaking changes. We are conservative about changing the MSRV,
+but sometimes are required to due to dependencies. The MSRV is:
+
+ * 1.60.0 for the `read` feature and its dependencies.
+ * 1.65.0 for other features.
+
+## License
+
+Licensed under either of
+
+ * Apache License, Version 2.0 ([`LICENSE-APACHE`](./LICENSE-APACHE) or https://www.apache.org/licenses/LICENSE-2.0)
+ * MIT license ([`LICENSE-MIT`](./LICENSE-MIT) or https://opensource.org/licenses/MIT)
+
+at your option.
+
+## Contribution
+
+Unless you explicitly state otherwise, any contribution intentionally submitted
+for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
+dual licensed as above, without any additional terms or conditions.