- Download Xcode 11 For Mac
- Mac Os Xcode
- Mac Os App Binary Xcode Download
- Mac Os App Binary Xcode Version
- Xcode Mac Os Requirements
To receive the latest developer news, visit and subscribe to our News and Updates. Jan 06, 2019 I recently was working on a Mac app to flash an Arduino using the open source project avrdude in my Mac app, and got it working as expected. I then looked at submitting the app to the Mac app store. I had expected that the avrdude binary needed to be signed and placed in the correct location in the app bundle.
Mac transition to Intel processors |
---|
Download Xcode 11 For Mac
The universal binary format is, in Apple parlance, a format for executable files that run natively on either PowerPC or Intel-manufactured IA-32 or Intel 64-based Macintosh computers. The format originated on NeXTStep as 'Multi-Architecture Binaries', and the concept is more generally known as a fat binary, as seen on Power Macintosh.
With the release of Mac OS X Snow Leopard, and before that, since the move to 64-bit architectures in general, some software publishers such as Mozilla[1] have used the term 'universal' to refer to a fat binary that includes builds for both i386 (32-bit Intel) and x86_64 systems. The same mechanism that is used to select between the PowerPC or Intel builds of an application is also used to select between the 32-bit or 64-bit builds of either PowerPC or Intel architectures.
Apple, however, continued to require native compatibility with both PowerPC and Intel in order to grant third-party software publishers permission to use Apple's trademarks related to universal binaries.[2] Apple does not specify whether or not such third-party software publishers must (or should) bundle separate builds for all architectures.
Universal binaries were introduced into Mac OS at the 2005 Apple Worldwide Developers Conference as a means to ease the transition from the existing PowerPC architecture to systems based on Intel processors, which began shipping in 2006. Universal binaries typically include both PowerPC and x86 versions of a compiled application. The operating system detects a universal binary by its header, and executes the appropriate section for the architecture in use. This allows the application to run natively on any supported architecture, with no negative performance impact beyond an increase in the storage space taken up by the larger binary.
Starting with Mac OS X Snow Leopard, only Intel-based Macs are supported, so software that specifically depends upon capabilities present only in Mac OS X 10.6 or newer will only run on Intel-based Macs and therefore does not require Intel/PPC fat binaries. Additionally, starting with OS X Lion, only 64-bit Intel Macs are supported, so software that specifically depends on new features in OS X 10.7 or newer will only run on 64-bit processors and therefore does not require 32-bit/64-bit fat binaries.[3][4] Fat binaries would only be necessary for software that is designed to have backward compatibility with older versions of Mac OS X running on older hardware.
The new Universal 2 binary format was introduced at the 2020 Worldwide Developers Conference.[5] Universal 2 allows applications to run on both Intelx86-64-based and ARM64-based Macintosh computers, for Apple's transition to ARM processors.
Motivation[edit]
There are two general alternative solutions. The first is to simply provide two separate binaries, one compiled for the x86 architecture and one for the PowerPC architecture. However, this can be confusing to software users unfamiliar with the difference between the two, although the confusion can be remedied through improved documentation, or the use of hybrid CDs. The other alternative is to rely on emulation of one architecture by a system running the other architecture. This approach results in lower performance, and is generally regarded an interim solution to be used only until universal binaries or specifically compiled binaries are available as with Rosetta.
Universal binaries are larger than single-platform binaries, because multiple copies of the compiled code must be stored. However, because some non-executable resources are shared by the two architectures, the size of the resulting universal binary can be, and usually is, smaller than both binaries combined. They also do not require extra RAM because only one of those two copies is loaded for execution.
History[edit]
The concept of a universal binary originated with 'Multi-Architecture Binaries' in NeXTSTEP, the main architectural foundation of Mac OS X. NeXTSTEP supports universal binaries so that one executable image can run on multiple architectures, including Motorola's m68k, Intel's x86, Sun Microsystems's SPARC, and Hewlett-Packard's PA-RISC. NeXTSTEP and macOS use Mach-O archive as the binary format underlying the universal binary.
Apple previously used a similar technique during the transition from 68k processors to PowerPC in the mid-1990s. These dual-platform executables are called fat binaries, referring to their larger file size.
Apple's Xcode 2.1 supports the creation of these files, a new feature in that release. A simple application developed with processor-independence in mind might require very few changes to compile as a universal binary, but a complex application designed to take advantage of architecture-specific features might require substantial modification. Applications originally built using other development tools might require additional modification. These reasons have been given for the delay between the introduction of Intel-based Macintosh computers and the availability of third-party applications in universal binary format. Apple's delivery of Intel-based computers several months ahead of their previously announced schedule is another factor in this gap.
Apple's Xcode 2.4 takes the concept of universal binaries even further, by allowing four-architecture binaries to be created (32- and 64-bit for both Intel and PowerPC), therefore allowing a single executable to take full advantage of the CPU capabilities of any Mac OS X machine.
Universal applications[edit]
Many software developers have provided universal binary updates for their products since the 2005 WWDC. As of December 2008, Apple's website listed more than 7,500 Universal applications.[6]
On April 16, 2007, Adobe Systems announced the release of Adobe Creative Suite 3, the first version of the application suite in the Universal Binary format.[7]
From 2006 to 2010, many Mac OS X applications were ported to Universal Binary format, including QuarkXPress, Apple's own Final Cut Studio, Adobe Creative Suite, Microsoft Office 2008, and Shockwave Player with version 11 - after that time most were made Intel-only apps. Non-Universal 32-bit PowerPC programs will run on Intel Macs running Mac OS X 10.4, 10.5, and 10.6 (in most cases), but with non-optimal performance, since they must be translated on-the-fly by Rosetta; they will not run on Mac OS X 10.7 Lion and later as Rosetta is no longer part of the OS.
iOS[edit]
Apple has used the same binary format as Universal Binaries for iOS applications by default on multiple occasions of architectural co-existence: around 2010 during the armv6-armv7-armv7s transition and around 2016 during the armv7-arm64 transition. The App Store automatically thins the binaries. No trade names were derived for this practice, as it is only a concern of the developer.[8]
Universal 2[edit]
Mac transition to Apple Silicon |
---|
On June 22, 2020, Apple announced a two-year permanent transition from Intelx86-64-based processors to ARM64-based Apple Silicon beginning with macOS Big Sur in late 2020.[9] To aid in this transition, a new Universal 2 binary was introduced to enable applications to be run on either x86-64-based processors or ARM64-based processors.[5]
Tools[edit]
The main tool for handling (creating or splitting) universal binaries is the lipo
command found in XCode. The file
command on macOS and several other Unix-like systems can identify Mach-O universal binaries and report architecture support.[10]Snow Leopard's System Profiler provides this information on the Applications tab.
See also[edit]
- Xslimmer, a commercial Mac OS X application that allows the user to slim down the fat universal binaries by removing the code for the platform that's not in use.
References[edit]
- ^'Firefox 4 for Mac OS X: Under the Hood'. November 10, 2010. Retrieved March 3, 2017.
- ^'Mac OS X Universal Logo: Guidelines for Mac OS X Universal Logo Licenses'(PDF). Apple Inc. June 2007. Retrieved October 18, 2013.
- ^'Mac OS X: 64-bit kernel frequently asked questions'. Apple Inc. October 4, 2012. Retrieved October 18, 2013.
- ^'Does Mac OS X 10.7 'Lion' run on Macs with a 32-bit EFI? How does the performance of Mac OS X 10.7 'Lion' compare to Mac OS X 10.6 'Snow Leopard' in 'real-world' tests? @ EveryMac.com'. everymac.com. Kyle Media. Retrieved October 6, 2017.
- ^ abAxon, Samuel (June 22, 2020). 'This is Apple's roadmap for moving the first Macs away from Intel'. Ars Technica. Retrieved June 23, 2020.
- ^'Macintosh Products Guide: Universal Applications'. Apple Computer. Retrieved December 22, 2008.
- ^'Adobe Ships Creative Suite 3'. Adobe Systems. April 16, 2007. Archived from the original on July 8, 2012. Retrieved October 18, 2013.
- ^'lipo - iOS fat binaries and thinning out'. Stack Overflow.
- ^Amadeo, Ron (June 22, 2020). 'Apple announces macOS 11, 'Big Sur,' with an emphasis on design'. Ars Technica. Retrieved June 23, 2020.
- ^stany (September 6, 2005). 'Mac OS X: Trimming fat from Mach-O fat files'. theconsultant.net. Retrieved October 18, 2013.
External links[edit]
- Apple Developer Transition Resource Center
- Apple Universal Binary Programming Guidelines
In this Quick Start you get a macOS app up and running in a sandbox. You verify that the app is indeed sandboxed and then learn how to troubleshoot and resolve a typical App Sandbox error. The apps you use are Xcode, Activity Monitor, Terminal, and Console.
Create the Xcode Project
The app you create in this Quick Start uses a web view and consequently uses a network connection. Under App Sandbox, network connections don’t work unless you specifically allow them—making this a good example app for learning about sandboxing.
In Xcode, create a new Xcode project for a macOS Cocoa application.
Name the project AppSandboxQuickStart.
Set an organization name and identifier, if none is already set. The organization identifier, which becomes the first part of the bundle identifier, is typically constructed using the reverse-DNS format, as described in About Bundle IDs. So if your organization name is Acme, your organization identifier would be
com.Acme
, which results in a bundle identifier ofcom.Acme.AppSandboxQuickStart
.Ensure that the Use Storyboards checkbox is selected and that the other checkboxes are unselected.
In the project navigator, click the
Main.storyboard
file.In the object library (in the utilities area), locate the
WKWebView
object.Drag a WebKit view onto the view managed by the view controller in the View Controller Scene on the canvas.
(Optional) To improve the display of the web view in the running app, perform the following steps:
Drag the sizing controls on the web view so that it completely fills the view controller’s main view.
Add constraints to the web view to pin its top, bottom, left, and right edges to the main view.
Import the WebKit framework by adding the following statement above the interface block in the
ViewController.h
header file:Link the WebKit framework to the Quick Start project as a required framework.
Note: If you are compiling for OS X 10.7 and want to play HTML5 embedded videos in this application, you must also link to the AV Foundation framework. This is not required in macOS 10.8 and later.
Create and connect an outlet for the web view in the
ViewController
class.In the view controller’s interface (either in
ViewController.h
or in a category inViewController.m
), add this:Connect the web view to the app delegate outlet you just created.
Add the following to the
viewDidLoad
method of the view controller:When the view loads, this method requests the specified URL from the computer’s network connection and then sends the result to the web view for display.
Mac Os Xcode
Confirm That the App Is Sandboxed
The window opens, but no web content appears. This is because sandboxing is enabled for all new Cocoa apps by default, but you haven’t yet conferred permission to access a network connection.
Apart from blocked behavior, there are a few specific signs that a macOS app is sandboxed.
Select the project file in the Xcode project navigator, and then the target, and finally the Capabilities pane. You should see that the App Sandbox capability is On, but that no specific capabilities are selected. If you did want to disable sandboxing, you would do it by changing the switch to Off.
In Finder, look at the contents of the
~/Library/Containers/
folder.Because the Quick Start app is sandboxed, there's now a container folder named after your app. The name includes the company identifier for the project, so the complete folder name would be, for example,
com.Acme.AppSandboxQuickStart
.The system creates an app’s container folder, for a given user, the first time the user runs the app.
Note: In macOS 10.8 and later, Finder hides the
~/Library
folder by default. To see it, choose Go > Go To Folder… and enter~/Library
in the dialog that appears.In Activity Monitor, check that the system recognizes the app as sandboxed.
Launch Activity Monitor (available in
/Applications/Utilities
).In Activity Monitor, choose View > Columns.
Ensure that the Sandbox menu item is checked.
In the Sandbox column, confirm that the value for the Quick Start app is Yes.
To make it easier to locate the app in Activity monitor, enter the name of the Quick Start app in the Filter field.
Check that the app binary is sandboxed. In a Terminal window, enter the following command:
where
<executable-path>
is the complete path for the app’s main executable binary inside the app bundle (for example,AppSandboxQuickStart.app/Contents/MacOS/AppSandboxQuickStart
). The output generated by this command contains the property list of entitlements, which includescom.apple.security.app-sandbox
set totrue
if the app is sandboxed.
Important: The above steps are sufficient for the Quick Start app, but are not sufficient for apps that contain embedded helper apps, XPC services, or other tools. For more information, read External Tools, XPC Services, and Privilege Separation.
Tip: If the app crashes when you attempt to run it, specifically by receiving an EXC_BAD_INSTRUCTION
signal, the most likely reason is that you previously ran a sandboxed app with the same bundle identifier but a different code signature. This crashing upon launch is an App Sandbox security feature that prevents one app from masquerading as another and thereby gaining access to the other app’s container.
You learn how to design and build your apps, in light of this security feature, in App Sandbox and Code Signing.
Resolve an App Sandbox Violation
An App Sandbox violation occurs if your app tries to do something that App Sandbox doesn’t allow. For example, you have already seen in this Quick Start that the sandboxed app is unable to retrieve content from the web. Fine-grained restriction over access to system resources is the heart of how App Sandbox provides protection should an app become compromised by malicious code. Resolving such violations involves adding specific entitlements in Xcode corresponding to the capabilities your app needs.
In the Capabilities tab of the target editor, within the App Sandbox section, select the entitlement that corresponds to Outgoing Connections (Client). Doing so applies a
TRUE
value for the needed entitlement to the Xcode project by modifying the.entitlements
property list file.Note: Network entitlements are specified in terms of who establishes the connection, not the primary direction of data flow. In this example, you need the Outbound Connection capability because the app is initiating the connection. An app acting as a server would require the Inbound Connection entitlement.
The intended webpage now displays in the app.
Mac Os App Binary Xcode Download
Next Steps
This chapter has shown how to use entitlements to enable App Sandbox and request resource access for a simple example app, but this is only a start. For a real app, you additionally code sign your app with a distribution identity before you can distribute it. When you begin to access the file system, you work within your container directories. When files are brought into your sandbox by the user through natural interactions like drag and drop, you create security-scoped bookmarks to maintain persistent access to these files over time. As your app grows in complexity, you introduce privilege separation to implement even finer grained resource control. Together, these techniques offer a means to contain damage if the worst happens.
Mac Os App Binary Xcode Version
Xcode Mac Os Requirements
Copyright © 2016 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2016-09-13
Comments are closed.