Note: the information in this document changes from time to time for different versions of BOINC. For any version of BOINC source files, the corresponding version of this document can be found in the source tree at:
boinc/mac_build/HowToBuildBOINC_XCode.rtfContents of this document:
Beware of using the wrong compiler! Apple's release notes for GCC 4.0 say:
If your application must support versions of Mac OS X prior to 10.3.9, you must not use the GCC 4.0 compiler. Instead, build your project using the GCC 3.3 compiler.Elsewhere on Apple's web site is the warning:
Do not link C++ modules compiled with one of these compilers against modules compiled with the other. Even if the modules appear to link correctly, C++ ABI differences may still cause problems that will not manifest themselves until run time.Be sure to follow the directions in this document to ensure that these requirements are met.
(If you wish, you can combine separate Intel and PowerPC builds in a single Universal Binary mach-O file using the command-line utility lipo. For details on lipo, type 'man lipo' in Terminal; it is available on all Macs running OS10.4.x.)
After building the libraries as Universal Binaries using the second method, you probably still want to build your actual application separately on the two architectures: on a PowerPC Mac running OS 10.3.x (do NOT use OS 10.4), and also on an Intel Mac running OS 10.4.x. Or you can look at the scripts buildcurl.sh and buildjpeg.sh for examples of environment settings which can cross-compile on one Mac running OS 10.4.x.
wxMac-2.8.2 (needed only if you are building the BOINC Manager): "; show_link("http://www.wxwidgets.org"); show_link("http://prdownloads.sourceforge.net/wxwindows/wxMac-2.8.2.tar.gz"); echo "
curl-7.16.1: "; show_link("http://curl.haxx.se"); show_link("http://curl.haxx.se/download/curl-7.16.1.tar.gz"); echo "
jpeg-6b (needed only if you are building the BOINC libboinc_graphics_api.a library): "; show_link("http://www.ijg.org"); show_link("ftp://ftp.uu.net/graphics/jpeg/jpegsrc.v6b.tar.gz"); echo "
XCode 2.2 installs autoconf 2.59 and automake 1.63. To determine the version number, type 'autoconf --version' or 'automake --version' . Building wxMac-2.8.2 and curl-7.16.1 require autoconf 2.59 and automake 1.93 or later.
Upgrades for autoconf and automake are available from www.gnu.org: "; show_link("http://ftp.gnu.org/gnu/autoconf/autoconf-2.59.tar.gz"); show_link("http://ftp.gnu.org/gnu/automake/automake-1.9.3.tar.gz"); echo "
XCode installed these utilities in the /usr/bin/ directory, but the upgrades by default will install in /usr/local/bin/. If you install there, you must also set your PATH environment variable to include that location. The scripts referenced below do this automatically.
As stated above, all BOINC software for Power PC Macs must be built using GCC 3.3 and MacOS10.3.9 SDK to assure backward compatibility with OS 10.3. All BOINC software for Intel Macs must be built using GCC 4.0 and MacOS10.4.u SDK to allow cross-compiling.
These are not done by either the XCode projects which come with wxMac-2.8.2, nor the AutoMake scripts supplied with wxMac-2.8.2, curl-7.16.1, or jpeg-6b. So be sure to use our special scripts to build these packages.
Building BOINC and the library packages on which it depends requires OS 10.4.4 and XCode 2.2 (or greater). It may be possible to use XCode 2.1 and/or versions of OS X earlier than 10.4.4, but this has not been tested by the authors.
curl-7.16.1 jpeg-6b wxMac-2.8.2Important: do not change the names of any of these 3 directories.
cd {path}/BOINC_dev/ cvs -d :pserver:anonymous:@alien.ssl.berkeley.edu:/home/cvs/cvsroot checkout boinc(You may change the name of the boinc directory to anything you wish.)
The command above retrieves the source code from the HEAD or development branch of the CVS repository. For more information on getting the BOINC source code, see: "; show_link("http://boinc.berkeley.edu/source_code.php"); echo "
cd {path}/BOINC_dev/boinc/mac_build/ source setupForBoinc.sh -cleanIf you don't wish to force a full rebuild of everything, omit the -clean argument.
Note: this script builds curl first, followed by jpeg and finally wxMac. If you haven't downloaded wxMac because you aren't building the BOINC Manager, the script will build curl and jpeg. Likewise, if you only downloaded curl because you need neither graphics nor the BOINC Manager, the script will build curl before quitting.
cd {path}/BOINC_dev/boinc/mac_build/ source BuildMacBOINC.shThe complete syntax for this script is
source BuildMacBOINC.sh [-dev] [-noclean] [-all] [-lib] [-client]The options for BuildMacBOINC.sh are:
cd {path}/BOINC_dev/boinc/ source {path}/BOINC_dev/boinc/mac_installer/release_boinc.sh x y zSubstitute the 3 parts of the BOINC version number for x y and z in the above. For example, to build the installer for BOINC version 5.5.4, the command would be
source {path}/BOINC_dev/boinc/mac_installer/release_boinc.sh 5 5 4This will create a directory 'BOINC_Installer/New_Release_5_5_4' in the BOINC_dev directory.
To build version 5.5.4 of the Grid Republic flavor of BOINC, you would type:
cd {path}/BOINC_dev/boinc/ source {path}/BOINC_dev/boinc/mac_installer/release_GridRepublic.sh 5 5 4This will create a directory 'BOINC_Installer/New_Release_GR_5_5_4' in the BOINC_dev directory.
The GDB debugger can't attach to applications which are running as a diferent user or group so it ignores the S_ISUID and S_ISGID permisison bits when launching an application. To work around this, BOINC does not use the special boinc_master or boinc_project users or groups when run from XCode.
The Development build only of the BOINC Manager allows you to change the ownership and permission settings of the BOINC Data and executables by entering an administrator user name and password. This also streamlines the development cycle by avoiding the need to run the installer for every change.
To restore the standard ownerships and permissions, run the installer.
All future releases of BOINC will include 'universal binary' builds for the Macintosh of BOINC Manager, command-line BOINC client and the boinc_cmd command-line tool. (Universal binaries contain both PowerPC and Intel executables in one file; the Macintosh OS automatically selects the appropriate one for that computer.)
The advantage of 'universal binaries' is that you only need to have one copy of the application, and it will run on either PowerPC or Intel Macs, so users don't need to choose between two options. Since BOINC participants manually download BOINC from the web site, we will be providing BOINC in 'universal binary' form.
However, participants do not manually download project applications; this is done automatically by BOINC. So there would be no advantage to combining the Intel and PowerPC versions in a single 'universal binary' file, but doing so would double the size of the download.
So BOINC treats Intel Macs as a new, separate platform. BOINC previously directly supported four platforms: PowerPC Macs (powerpc-apple-darwin), Intel Linux (i686-pc-linux-gnu), Windows (windows-intelx86) and Solaris (sparc-sun-solaris2.7).
We have now added a fifth platform for Intel Macs (i686-apple-darwin).
As a temporary measure, projects can set their servers to deliver a copy of their current PowerPC application (renamed for the new platform) under the new i686-apple-darwin platform. The OS will run it in compatibility mode, emulating a PowerPC. (Apple calls this compatibility mode Rosetta, which of course has nothing to do with the Rosetta BOINC project.)
If you do this, be sure to give your native Intel application a higher version number when you do release it, so that clients will download it.
However, running a PowerPC application in compatibility mode has two significant drawbacks:
It is very easy to add a new platform to your server with the xadd utility. For directions on how to do this, see these web pages: "; show_link("http://boinc.berkeley.edu/platform.php"); show_link("http://boinc.berkeley.edu/tool_xadd.php"); echo "
BOINC supports all PowerPC Macs running OS 10.3.0 or later, and all Intel Macs. (The Intel Macs themselves require OS 10.4.4 or later.)
The easiest way to build your application for these two platforms is to build each one on its native platform. In other words, do your powerpc-apple-darwin build on a PowerPC Mac running OS 10.3.9, and your i686-apple-darwin build on an Intel Mac.
But Apple provides the tools to allow you to cross-compile your application on any Mac (PowerPC or Intel) running OS 10.4 or later. Here is how:
All BOINC software for Power PC Macs must be built using GCC 3.3 and MacOS10.3.9 SDK to assure backward compatibility with OS 10.3. If building a PowerPC application on an Intel Mac, you must also specify '-arch ppc' in the compiler and linker flags.
All BOINC software for Intel Macs must be built using GCC 4.0 and MacOS10.4.u SDK to allow cross-compiling. If building an Intel application on a PowerPC Mac, you must also specify '-arch i386' in the compiler and linker flags.
You can find examples of how to do this for two different kinds of configure / make scripts in the HEAD branch of the BOINC CVS tree at boinc/mac_build/buildcurl.sh and boinc/mac_build/buildjpeg.sh.
The lipo utility is used at the end of each of these scripts to combine the two binaries into a single 'Universal Binary' file. You won't need to do that with you project applications, since you will be distributing them separately under the two platforms. But if you prefer, you can create a Universal Binary and distribute the same file for both i686-apple-darwin and powerpc-apple-darwin platforms.
Note that the BOINC libraries (and any third-party libraries) which you link with your applications must be built with the same configuration as the application itself. Follow the instructions earlier in this document to build the needed libraries.
Additional information on building Unix applications universal can be found here: "; show_link("http://developer.apple.com/documentation/Porting/Conceptual/PortingUnix/compiling/chapter_4_section_3.html"); echo "
and here: "; show_link("http://developer.apple.com/documentation/MacOSX/Conceptual/universal_binary/universal_binary_compiling/chapter_2_section_7.html"); echo "
For information on making your code work with GCC 4: "; show_link("http://developer.apple.com/releasenotes/DeveloperTools/GCC40PortingReleaseNotes/index.html"); echo "
{path}/MakeAppIcon_h {source_file_path}/xxx.icns {dest_file_path}/app_icon.h(The MakeAppIcon_h command-line utility is built by the Mac boinc XCode project in the 'boinc/mac_build/build/' directory.) Add the app_icon.h file to your science application's project.
#include \"app_icon.h\"and call:
setMacIcon(argv[0], MacAppIconData, sizeof(MacAppIconData));