Run dynamically linked ELF binaries everywhere (musl and glibc are supported).
- Its works with userland-execve by mapping the interpreter (such as ld-linux-x86-64.so.2) into memory, creating a stack for it (containing the auxiliary vector, arguments, and environment variables), and then jumping to the entry point with the new stack.
- lib4bin pulls out the binary file and all the libraries on which it depends, strip it and forms the
bin
,shared/{bin,lib,lib32}
directories (see screenshots) and generate a fileshared/{lib,lib32}/lib.path
with a list of all directories that contain libraries for pass it to interpreter--library-path
. The paths in this file are specified on a new line with a+
at the beginning and relative to the directory in which it is located.
- aarch64
- x86_64
- Download the latest revision
git clone https://github.com/VHSgunzo/sharun.git && cd sharun
- Compile a binary
rustup default nightly
rustup target add $(uname -m)-unknown-linux-musl
rustup component add rust-src --toolchain nightly
cargo build --release
cp ./target/$(uname -m)-unknown-linux-musl/release/sharun .
./sharun --help
./sharun lib4bin --help
- Or take an already precompiled binary file from the releases
[ Usage ]: sharun [OPTIONS] [EXEC ARGS]...
Use lib4bin for create 'bin' and 'shared' dirs
[ Arguments ]:
[EXEC ARGS]... Command line arguments for execution
[ Options ]:
l, lib4bin [ARGS] Launch the built-in lib4bin
-g, --gen-lib-path Generate a lib.path file
-v, --version Print version
-h, --help Print help
[ Environments ]:
SHARUN_WORKING_DIR=/path Specifies the path to the working directory
SHARUN_LDNAME=ld.so Specifies the name of the interpreter
SHARUN_DIR Sharun directory
[ Usage ]: lib4bin [OPTIONS] /path/executable -- [STRACE MODE EXEC ARGS]
[ Options ]:
-a, --any-executable Pack any executable (env: ANY_EXECUTABLE=1)
-d, --dst-dir '/path' Destination directory (env: DST_DIR=/path)
-e, --strace-mode Use strace for get libs (env: STRACE_MODE=1, STRACE_TIME=5)
-g, --gen-lib-path Generate a lib.path file (env: GEN_LIB_PATH=1)
-h, --help Show this message
-i, --patch-interpreter Patch INTERPRETER to a relative path (env: PATCH_INTERPRETER=1)
-k, --with-hooks Pack additional files required for libraries (env: WITH_HOOKS=1)
-l, --libs-only Pack only libraries without executables (env: LIBS_ONLY=1)
-n, --not-one-dir Separate directories for each executable (env: ONE_DIR=0)
-p, --hard-links Pack sharun and create hard links (env: HARD_LINKS=1)
-q, --quiet-mode Show only errors (env: QUIET_MODE=1)
-r, --patch-rpath Patch RPATH to a relative path (env: PATCH_RPATH=1)
-s, --strip Strip binaries and libraries (env: STRIP=1)
-v, --verbose Verbose mode (env: VERBOSE=1)
-w, --with-sharun Pack sharun from PATH or env or download
(env: WITH_SHARUN=1, SHARUN=/path|URL, SHARUN_URL=URL, UPX_SHARUN=1)
# run lib4bin with the paths to the binary files that you want to make portable
./sharun lib4bin --with-sharun --dst-dir test /bin/bash
# or for correct /proc/self/exe you can use --hard-links flag
./sharun lib4bin --hard-links --dst-dir test /bin/bash
# this will create hard links from 'test/sharun' in the 'test/bin' directory
# now you can move 'test' dir to other linux system and run binaries from the 'bin' dir
./test/bin/bash --version
# or specify them as an argument to 'sharun'
./test/sharun bash --version
-
You can create a hard link from
sharun
toAppRun
and write the name of the executable file from thebin
directory to the.app
file for compatibility with AppImageAppDir
. If the.app
file does not exist, the*.desktop
file will be used. -
Additional env var can be specified in the
.env
file (see dotenv). Env var can also be deleted usingunset ENV_VAR
in the end of the.env
file. -
You can preload libraries using
.preload
file. Specify the necessary libraries in it from a new line. You can use the full paths to libraries or only their names if they are located inshared/{lib,lib32}/
This can be useful, for example, to use ld-preload-open library to reassign paths. -
Also you can package the
sharun directory
with your applications into a single executable file using wrappe
PATH |
${SHARUN_DIR}/bin |
PYTHONHOME and PYTHONDONTWRITEBYTECODE |
${SHARUN_DIR}/shared/$LIB/python* |
PERLLIB |
${SHARUN_DIR}/shared/$LIB/perl* |
GCONV_PATH |
${SHARUN_DIR}/shared/$LIB/gconv |
GIO_MODULE_DIR |
${SHARUN_DIR}/shared/$LIB/gio/modules |
GTK_PATH , GTK_EXE_PREFIX and GTK_DATA_PREFIX |
${SHARUN_DIR}/shared/$LIB/gtk-* |
QT_PLUGIN_PATH |
${SHARUN_DIR}/shared/$LIB/qt*/plugins |
BABL_PATH |
${SHARUN_DIR}/shared/$LIB/babl-* |
GEGL_PATH |
${SHARUN_DIR}/shared/$LIB/gegl-* |
GIMP2_PLUGINDIR |
${SHARUN_DIR}/shared/$LIB/gimp/2.0 |
TCL_LIBRARY |
${SHARUN_DIR}/shared/$LIB/tcl* |
TK_LIBRARY |
${SHARUN_DIR}/shared/$LIB/tk* |
GST_PLUGIN_PATH , GST_PLUGIN_SYSTEM_PATH , GST_PLUGIN_SYSTEM_PATH_1_0 , and GST_PLUGIN_SCANNER |
${SHARUN_DIR}/shared/$LIB/gstreamer-* |
GDK_PIXBUF_MODULEDIR and GDK_PIXBUF_MODULE_FILE |
${SHARUN_DIR}/shared/$LIB/gdk-pixbuf-* |
LIBDECOR_PLUGIN_DIR |
${SHARUN_DIR}/shared/$LIB/libdecor/plugins-1 |
GTK_IM_MODULE_FILE |
${SHARUN_DIR}/shared/$LIB/gtk-*/*/immodules.cache |
LIBGL_DRIVERS_PATH |
${SHARUN_DIR}/shared/$LIB/dri |
SPA_PLUGIN_DIR |
${SHARUN_DIR}/shared/$LIB/spa-* |
PIPEWIRE_MODULE_DIR |
${SHARUN_DIR}/shared/$LIB/pipewire-* |
--- | --- |
XDG_DATA_DIRS |
${SHARUN_DIR}/share |
VK_DRIVER_FILES |
${SHARUN_DIR}/share/vulkan/icd.d |
__EGL_VENDOR_LIBRARY_DIRS |
${SHARUN_DIR}/share/glvnd/egl_vendor.d |
XKB_CONFIG_ROOT |
${SHARUN_DIR}/share/X11/xkb |
GSETTINGS_SCHEMA_DIR |
${SHARUN_DIR}/share/glib-2.0/schemas |
GIMP2_DATADIR |
${SHARUN_DIR}/share/gimp/2.0 |
TERMINFO |
${SHARUN_DIR}/share/terminfo |
--- | --- |
FONTCONFIG_FILE |
${SHARUN_DIR}/etc/fonts/fonts.conf |
GIMP2_SYSCONFDIR |
${SHARUN_DIR}/etc/gimp/2.0 |