Go to file
CuriousTommy 4a68f33a3a
Merge pull request #1640 from jlucfarias/add-avfoundation-symbols
Add AVFAudio framework
2025-12-13 15:20:32 -08:00
.circleci
.github Fix Ci Errors 2024-01-14 01:10:55 +00:00
.vscode
Developer chore: add AVFAudio framework 2025-12-12 16:02:26 -03:00
basic-headers Remove architecture from Darling repo. Add symbol link to architecture submodule. 2023-01-25 11:26:10 -08:00
ci [ci/deb] Allow using an existing UID/GID for the CI user 2023-11-01 21:28:48 -04:00
cmake CMake protect PATH in dSYM generation 2025-10-19 10:56:36 +02:00
debian
etc Remove obsolete files 2018-08-14 11:10:57 +03:00
framework-include chore: add AVFAudio framework 2025-12-12 16:02:26 -03:00
framework-private-include Add private framework UIFoundation 2025-10-13 15:08:27 -03:00
misc
rpm
src chore: add AVFAudio framework 2025-12-12 16:02:26 -03:00
tests/src
tools Update darling stub generator to use up to date copyright header 2025-05-23 20:32:21 +02:00
.gdbinit
.gitignore
.gitmodules
CMakeLists.txt
CONTRIBUTORS.md
LICENSE
README.md

README.md

Darling

Darling logo

Darling is a runtime environment for macOS applications.

Please note that most GUI applications will not run at the moment.

Download

Packages for some distributions are available for download under releases.

Build Instructions

For build instructions, visit Darling Docs.

Prefixes

Darling has support for DPREFIXes, which are very similar to WINEPREFIXes. They are virtual “chroot” environments with an macOS-like filesystem structure, where you can install software safely. The default DPREFIX location is ~/.darling, but this can be changed by exporting an identically named environment variable. A prefix is automatically created and initialized on first use.

Please note that we use overlayfs for creating prefixes, and so we cannot support putting prefix on a filesystem like NFS or eCryptfs. In particular, the default prefix location won't work if you have an encrypted home directory.

Hello world

Let's start with a Hello world:

$ darling shell echo Hello world
Hello world

Congratulations, you have printed Hello world through Darling's OS X system call emulation and runtime libraries.

Installing software

You can install .pkg packages with the installer tool available inside shell. It is a somewhat limited cousin of OS X's installer:

$ darling shell
Darling [~]$ installer -pkg mc-4.8.7-0.pkg -target /

The Midnight Commander package from the above example is available for download.

You can uninstall and list packages with the uninstaller command.

Working with DMG images

DMG images can be attached and detached from inside darling shell with hdiutil. This is how you can install Xcode along with its toolchain and SDKs (note that Xcode itself doesn't run yet):

Darling [~]$ hdiutil attach Xcode_7.2.dmg
/Volumes/Xcode_7.2
Darling [~]$ cp -r /Volumes/Xcode_7.2/Xcode.app /Applications
Darling [~]$ export SDKROOT=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk
Darling [~]$ echo 'void main() { puts("Hello world"); }' > helloworld.c
Darling [~]$ /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang helloworld.c -o helloworld
Darling [~]$ ./helloworld
Hello world

Congratulations, you have just compiled and run your own Hello world application with Apple's toolchain.

Working with XIP archives

Xcode is now distributed in .xip files. These can be installed using unxip:

cd /Applications
unxip Xcode_11.3.xip