#replace #uninstall #system #higher-level #self-update #self-uninstall

self-replace

Utility crate that allows executables to replace or uninstall themselves

12 stable releases

1.5.0 Sep 1, 2024
1.4.0 Jul 21, 2024
1.3.7 Sep 19, 2023
1.3.6 Aug 25, 2023
1.3.3 May 19, 2023

#27 in Math

Download history 23940/week @ 2024-09-10 24004/week @ 2024-09-17 26492/week @ 2024-09-24 27474/week @ 2024-10-01 25619/week @ 2024-10-08 24947/week @ 2024-10-15 26306/week @ 2024-10-22 27577/week @ 2024-10-29 30134/week @ 2024-11-05 43144/week @ 2024-11-12 45927/week @ 2024-11-19 37567/week @ 2024-11-26 72133/week @ 2024-12-03 260953/week @ 2024-12-10 41587/week @ 2024-12-17 25760/week @ 2024-12-24

408,405 downloads per month
Used in 82 crates (16 directly)

Apache-2.0

27KB
283 lines

Self-Replace: A Utility For Self Replacing Executables

Crates.io License rustc 1.63.0 Documentation

self-replace is a crate that allows binaries to replace themselves with newer versions or to uninstall themselves. On Unix systems this is a simple feat, but on Windows a few hacks are needed which is why this crate exists.

This is a useful operation when working with single-executable utilties that want to implement a form of self updating or self uninstallation.

For details about the implementation refer to the documentation.

If you are looking for some higher level update logic, have a look at self_update which uses self-replace under the hood but provides automatic updating from GitHub releases or other distribution channels. Note that self_update is maintained by other maintainers.

Uninstall

To uninstall a binary, use self_delete.

self_replace::self_delete()?;

Updating

To replace a binary for updating, use self_replace.

let new_binary = "/path/to/new/binary";
self_replace::self_replace(&new_binary)?;
std::fs::remove_file(&new_binary)?;

Dependencies

~2–11MB
~138K SLoC