README.md
Crowdin Project: | Documentation:liveconainer.github.io
[!CAUTION] Important Notice Regarding Third-Party Builds of LiveContainer
We have recently noticed the appearance of certain closed-source third-party builds of LiveContainer. Please be aware that all your apps are installed within LiveContainer, which means these third-party builds have full access to your data, including sensitive information such as keychain items and login credentials.
Furthermore, please note that we do not provide any support for issues of these third-party builds.
LiveContainer comes with a standalone version and a version with built-in SideStore. Please read the install guide here
If you encounter any issue please read our FAQ here
| Stable | Nightly |
|---|---|
| <a href="https://github.com/LiveContainer/LiveContainer/releases/latest/download/LiveContainer+SideStore.ipa" target="_blank"></a> | <a href="https://github.com/LiveContainer/LiveContainer/releases/download/nightly/LiveContainer+SideStore.ipa" target="_blank"></a> |
Using multiple LiveContainers allows you to run multiples different apps simultaneously, with almost seamless data transfer between the LiveContainers.
You can now launch multiple apps simultaneously in in-app virtual windows. These windows can be resized, scaled, and even displayed using the native Picture-in-Picture (PiP) feature. On iPads, apps can run in native window mode, displaying each app in a separate system window. And if you wish, you can choose to run apps in multitasking mode by default in settings.
To use multitasking, hold its banner and tap "Multitask". You can also make Multitask the default launch mode in settings.
[!Note]
- To use multitasking, ensure you select "Keep App Extensions" when installing via SideStore/AltStore.
- If you want to enable JIT for multitasked apps, you’ll need a JIT enabler that supports attaching by PID. (StikDebug)
Some apps may experience issues with their file pickers or not be able to apply for notification permission in LiveContainer. To resolve this, enable "Fix File Picker" & "Fix Local Notifications" accordingly in the app-specific settings.
Unfortunately, not all apps work in LiveContainer, so we have a compatibility list to tell if there is apps that have issues. If they aren't on this list, then it's likely going run. However, if it doesn't work, please make an issue about it.
Open Xcode, edit DEVELOPMENT_TEAM[config=Debug] in xcconfigs/Global.xcconfig to your team id and compile.
Localizable.xcstrings is in here for multilingual support. To help us translate LiveContainer, please visit our crowdin project__PAGEZERO segment:
vmaddr to 0xFFFFC000 (0x100000000 - 0x4000)vmsize to 0x4000MH_EXECUTE to MH_DYLIB.TweakLoader.dylib@executable_pathdyld4::APIs::_NSGetExecutablePath_NSGetExecutablePathconfig.process.mainExecutablePath
config.process.mainExecutablePath using dyld4::APIs instance (passed as first parameter)builtin_vm_protect or TPRO unlock to make it writabledyld4::APIs::_NSGetExecutablePath backOld Method
- Call
_NSGetExecutablePathwith an invalid buffer pointer input -> SIGSEGV- Do some magic stuff to overwrite the contents of executable_path.
NSBundle.mainBundledlopen with the guest app's executableUIApplicationMain and start up like any other iOS apps.128 keychain access groups are created and LiveContainer allocates them randomly to each container of the same app. So you can create 128 container with different keychain access groups.