Locations for Public Frameworks
Third-party frameworks can go in a number of different file-system locations, depending on certain factors.
-
Most public frameworks should be installed at the local level in
/Library/Frameworks
. -
If your framework should only be used by a single user, you can install it in the
~/Library/Frameworks
subdirectory of the current user; however, this option should be avoided if possible. -
If they are to be used across a local area network, they can be installed in
/Network/Library/Frameworks
; however, this option should be avoided if possible.
For nearly all cases, installing your frameworks in /Library/Frameworks
is the best choice. Frameworks in this location are discovered automatically by the compiler at compile time and the dynamic linker at runtime. Applications that link to frameworks in other directories, such as ~/Library/Frameworks
or /Network/Library/Frameworks
, must specify the exact path to the framework at build time so that the dynamic linker can find it. If the path changes (as it might for a user home directory), the dynamic linker may be unable to find the framework.
Another reason to avoid installing frameworks in ~/Library/Frameworks
or /Network/Library/Frameworks
is the potential performance penalties. Frameworks installed in network directories or in network-based user home directories can cause significant delays in compilation times. Loading the framework across the network can also slow down the launch of the target application.
Third-party frameworks should never be installed in the /System/Library/Frameworks
directory. Access to this directory is restricted and is reserved for Apple-provided frameworks only.
When you build an application or other executable, the compiler looks for frameworks in/System/Library/Frameworks
as well as any other location specified to the compiler. The compiler writes path information for any required frameworks in the executable file itself, along with version information for each framework. When the application is run, the dynamic link editor tries to find a suitable version of each framework using the paths in the executable file. If it cannot find a suitable framework in the specified location (perhaps because it was moved or deleted), it looks for frameworks in the following locations, in this order:
-
The explicit path to the framework that was specified at link time.
-
The
/Library/Frameworks
directory. -
The
/System/Library/Frameworks
directory.
If the dynamic link editor cannot locate a required framework, it generates a link edit error, which terminates the application.
https://developer.apple.com/library/archive/documentation/MacOSX/Conceptual/BPFrameworks/Tasks/InstallingFrameworks.html#//apple_ref/doc/uid/20002261-BBCCFBJA