Successor to armake written in Rust for maintainability and memory safety, aiming to provide the same features except for the custom P3D binarization, which was never finished.
Status: PAA commands not implemented, some options not implemented, testing.
preprocess
commandpack
command for non-binarized PBOs instead of build -p
rapify
commandPerformance should be equal or better than armake
depending on modification makeup and environment. More is done in-memory, reducing disk I/O at the expense of memory usage. Especially during binarization, less copies are performed, resulting in much faster builds for asset-heavy modifications or users without SSDs.
armake1:
Time (mean ± σ): 676.463 s ± 17.609 s [User: 1.5 ms, System: 3.9 ms]
Range (min … max): 653.793 s … 706.619 s
armake2:
Time (mean ± σ): 434.666 s ± 1.109 s [User: 0.0 ms, System: 4.1 ms]
Range (min … max): 433.415 s … 435.526 s
Speedup: 1.56
armake1:
Time (mean ± σ): 110.083 s ± 2.772 s [User: 4.9 ms, System: 16.8 ms]
Range (min … max): 108.270 s … 113.274 s
armake2:
Time (mean ± σ): 98.190 s ± 0.452 s [User: 0.0 ms, System: 13.6 ms]
Range (min … max): 97.767 s … 98.666 s
Speedup: 1.12
(all benchmarks performed with 4 threads on a 4 core VM on an i5-8600K)
The build requires cargo
, Rust's package manager and the OpenSSL development libraries.
To compile and run, use:
cargo run
To build a release, use:
cargo build --release
On Windows, the easiest way to get compilation and static linking of OpenSSL to work is to download precompiled OpenSSL binaries (non-light, 64bit) and set the following environment variables:
OPENSSL_DIR=C:\OpenSSL-WIN64
OPENSSL_STATIC=1
OPENSSL_LIBS=libssl_static:libcrypto_static
``` armake2
Usage:
armake2 rapify [-v] [-f] [-w
See armake2 --help
for more.