#slp #empires #genie #engine #file-format #read-file #aoe

chariot_slp

A library for reading/writing Age of Empires (1997) SLP files

3 releases

Uses old Rust 2015

0.1.2 May 16, 2017
0.1.1 May 10, 2017
0.1.0 May 5, 2017

#5 in #empires

MIT license

21KB
307 lines

Chariot SLP Crate

This crate handles the SLP file format used by Age of Empires (1997). Currently, it can read SLP files.

While the ability to write an SLP file is a nice to have, it's not strictly necessary for the rest of the Chariot project, and thus, is not implemented at this time.

The code herein falls under the same license as the rest of the Chariot project.

Building

You'll need the Rust compiler and Cargo build system. Once you have those, you can compile with:

$ cargo build

Example

match slp::SlpFile::read_from_file("/path/to/file.slp", 1u8) {
    Ok(slp_file) => {
        println!("Shape count: {}", slp_file.header.shape_count);
        for shape in &slp_file.shapes {
            println!("{:?}", shape.header);
        }
    },
    Err(err) => {
        println!("Failed to read the SLP file: {}", err);
    }
}

SLP format in ASCII form

+-----------------------------+
|          SlpHeader          |
+-----------------------------+
|SlpShapeHeader|SlpShapeHeader|
+-----------------------------+
|                             |
| Array of u16 padding pairs  | <-+ Each SlpShapeHeader has a "shape_outline_offset"
|                             |     that points to a pair in this array
+-----------------------------+
|                             |
| Arrays of u32 offsets to    | <-+ Each SlpShapeHeader has a "shape_data_offsets"
|  first command in each row  |     that points to an array
|                             |
+-----------------------------+
|                             |
| Drawing commands used to    |
|  produce indexed image data |
|                             |
+-----------------------------+

Dependencies

~1.5MB
~29K SLoC