Patched AppRun binary to check libgcc and libstdc++ dependencies at runtime.
Go to file
darealshinji 2f04ad81c6
Merge pull request #5 from pamarcos/append_ld_preload
Append old LD_PRELOAD when modifying it
2018-01-06 11:43:00 +01:00
.gitignore Update .gitignore 2017-04-26 15:30:02 +02:00
.travis.yml Update .travis.yml 2017-12-06 21:33:18 +01:00
AppRun.c.patch get the right AppRun.c file, explicitly set \0 in sprintf 2017-12-21 16:40:15 +01:00
AppRun.sh simple AppRun shell script for testing 2017-12-21 16:38:55 +01:00
checkrt.c Merge pull request #5 from pamarcos/append_ld_preload 2018-01-06 11:43:00 +01:00
checkrt.h Print debug logs when APPIMAGE_CHECKRT_DEBUG is set 2018-01-06 10:27:32 +01:00
exec.c Print debug logs when APPIMAGE_CHECKRT_DEBUG is set 2018-01-06 10:27:32 +01:00
Makefile get the right AppRun.c file, explicitly set \0 in sprintf 2017-12-21 16:40:15 +01:00
README.md load exec() wrapper if optional runtimes are present 2017-12-06 14:37:47 +01:00

The problem

Some projects require newer C++ standards to build them. To keep the glibc dependency low you can build a newer GCC version on an older distro and use it to compile the project. This project however will now require a newer version of the libstdc++.so.6 library than available on that distro. Bundling libstdc++.so.6 however will in most cases break compatibility with distros that have a newer library version installed into their system than the bundled one. So blindly bundling the library is not reliable.

By the way, while this is primarily an issue with libstdc++.so.6 in some rare cases this might also occur with libgcc_s.so.1. That's because both libraries are part of GCC.

The solution

You would have to know the library version of the host system and decide whether to use a bundled library or not before the application is started. This is exactly what the patched AppRun binary does. It will search for usr/optional/libstdc++/libstdc++.so.6 and usr/optional/libgcc_s/libgcc_s.so.1 inside the AppImage or AppDir. If found it will compare their internal versions with the ones found on the system and prepend their paths to LD_LIBRARY_PATH if necessary. You should also put exec.so into usr/optional.