Retired Document
Important: This document may not represent best practices for current development. Links to downloads and other resources may no longer be valid.
Build System
This chapter discusses the Project Builder build system, which determines how applications are built. Project Builder uses the Jam software build tool as its build engine. Jam allows Project Builder to easily manage dependencies between a project’s elements. It can also take advantage of computers with two or more central processing units (CPUs).
Build Settings
Build settings are similar to Java properties: They store values that Project Builder uses to build products. Project Builder facilitates configuring some build settings through specialized panes (see Target Information Panes). However, you can set the value of any build setting directly through expert panes. Expert panes show the configuration build settings as a list of key-value pairs. Through these panes you can set the values of build settings for which the more user-friendly specialized panes do not provide a user interface.
The following tables list some of the build settings you may have to use in your projects. Build Settings Reference has a complete list of Java-related settings. See the Project Builder release notes for a complete list of all settings.
Table 2-1 lists build settings that identify a project and tell Project Builder where to put temporary files generated during product building.
Build setting | Description |
---|---|
| Name of the project. For example, |
| Base location for built products. For example, |
| Base location for the temporary files generated by a project’s targets. For example, |
| Base location for built products. It’s set to |
Table 2-2 lists build settings that determine where files are placed when you use pbxbuild
to install a product.
Build setting | Description |
---|---|
| Base location for the installed product. For example, |
| Location of the installed product. For example |
| Fully qualified path for the installed product. By default, it concatenates |
Table 2-3 lists build settings that identify a target and tell Project Builder where to put the files it generates.
Build setting | Description |
---|---|
| Name of the target. For example, |
| The action being performed on a target. Its possible values are |
| Location for a target’s temporary files. For example, |
Table 2-4 lists build settings used to call javac
or jikes
to compile Java source files.
Build setting | Description |
---|---|
| Base location for Java class files. For example, |
| Defines the Java virtual machine version that |
Table 2-5 lists the build setting that defines the archive of Java class files and the creation of the application package.
Build setting | Description |
---|---|
| Path (relative to the project’s root directory) to a manifest file to use when archiving Java class files into a JAR file. For example, |
Targets
Project Builder targets represent a product, such as an application or a framework. A project can produce more than one product. For example, a project can contain Java source files, which are compiled into Java class files by javac
, and Objective-C source files, which are compiled into object files by gcc
. Such a project must contain at least two targets, one that compiles the Java sources files and another that compiles the Objective-C source files. The build settings introduced in Build Settings are what Project Builder uses to determine how to build a product.
Each target has its own set of build setting values; they are autonomous entities within a project. However, you can tell Project Builder that a target depends on one or more additional targets. That way you can guarantee, for example, that when target A needs files produced by target B, target B is executed before target A. In addition, if there’s a problem with target B, target A doesn’t get executed.
In addition, Project Builder provides the ability to add aggregate targets to a project. An aggregate target contains no product-building instructions; instead, it groups other targets. The operations you perform on aggregate targets are carried out on all the targets they enclose.
Each target can contain some or all of the following types of elements:
Build settings The group of build settings that control the build system.
Information property list entries Application package–specific information, such as type, version, icon, and so on.
Build phases Types of tasks to perform on a set of a project’s files, such as compile, link, archive, copy, and so on. See Build Phases for more information.
For more information on targets, see Project Builder Help.
Target Information Panes
Target information panes group information about how a product is built. They contain a user-friendly view of the values of certain build settings. These information panes are grouped in three major groups: Summary, Settings and Info.plist Entries.
Target Summary
The Summary pane shows summary information for a project, including its name, type, and developer comments; it’s shown in Figure 2-1.
data:image/s3,"s3://crabby-images/53a61/53a61088a1bbb6ec79560d6f22a132320c41f1cd" alt="Target Summary pane of the target editor in Project Builder"
Table 2-6 describes the elements of the Target Summary pane.
Element label | Description | Corresponding build setting |
---|---|---|
Product type | Indicates the type of project. Can be Application, Tool, Framework, and so on. | None. |
Base product name | Name of the generated product file without an extension. |
|
Comments | Developer comments about the target. | None. |
Build Settings
The Build Settings pane groups views of the build settings of a project. It includes two views: Simple View and Expert View. The Simple View provides a easy-to-use user interface to various build settings. The Expert View lists all the build settings. You can use this view when the other views don’t provide a way of configuring a particular build setting.
General Settings
The General Settings pane, depicted in Figure 2-2, shows information that pertains to the entire project. Table 2-7 describes its elements.
data:image/s3,"s3://crabby-images/0da60/0da6070d87bdfe5d0eb3f03906e60dbe3d653da0" alt="General Settings pane of the target editor in Project Builder"
Element label | Description | Corresponding build setting |
---|---|---|
Product type | Indicates the type of project. Can be Application, Tool, Framework, and so on. | None. |
Product name | Name of the generated product file without an extension. |
|
Installation Settings
The Installation Settings pane, depicted in Figure 2-3, shows installation information for the selected target. Table 2-8 describes its elements.
data:image/s3,"s3://crabby-images/cf08d/cf08dcb854ce578d6d3783e9670ebc226809dfdc" alt="Installation Settings pane of the target editor in Project Builder"
Element label | Description | Corresponding build setting |
---|---|---|
None | When selected, the product doesn’t get installed. | None. |
Path | When selected, the product gets installed in the directory entered in the text input field. |
|
Search Paths
The Search Paths pane, depicted in Figure 2-4, determines the places Project Builder searches for frameworks, libraries, Java classes, and headers (in the case of a JNI application) to build the selected target. Table 2-9 describes its elements.
data:image/s3,"s3://crabby-images/d7345/d73454810d370ba7397f1e8156878df8ab96a0f5" alt="Search Paths pane of the target editor in Project Builder"
Element label | Description | Corresponding build setting |
---|---|---|
Headers | Search paths for Objective-C header files. |
|
Frameworks | Search paths for frameworks. |
|
Libraries | Search paths for libraries. |
|
Java Classes | Search paths for Java class files or JAR files. |
|
Java Compiler Settings
The Java Compiler Settings pane, depicted in Figure 2-5, determines some compiler settings for the selected target. Table 2-10 describes its elements.
data:image/s3,"s3://crabby-images/5e163/5e163dde93183dfcfb811c27c87729e78c02b9ae" alt="Java Compiler Settings pane of the target editor in Project Builder"
Element label | Description | Corresponding build setting |
---|---|---|
Java Compiler | Determines the compiler to use to compile Java source files. The options are |
|
Disable warnings | When selected, the compiler doesn’t produce warnings. |
|
Show usage of deprecated API | When selected, the compiler warns about deprecated API use. |
|
Generate debugging symbols | When selected, the compiler generates debugging symbols. |
|
Target VM version | The virtual machine version the compiler is to produce Java class files for. |
|
Source file encoding | Specifies the character encoding used in all the Java source files that are to be compiled. |
|
Other Java Compiler Flags | Additional compiler options. |
|
Java Archive Settings
The Java Archive Settings pane, depicted in Figure 2-6, determines how Java class files in the selected target are archived. Table 2-11 describes its elements.
data:image/s3,"s3://crabby-images/3f651/3f651e3cbe386125ef19e224bc63a7e226f90be6" alt="Java Archive Settings pane of the target editor in Project Builder"
Element label | Description | Corresponding build setting |
---|---|---|
Product type | Determines whether Java class files are archived in a JAR file. |
|
Compress | When unselected, the Java class files are stored in the JAR file, but are not compressed. |
|
Archive file extension | The extension to use for the JAR file. The options are |
|
Manifest file | Name of the supplemental manifest file. |
|
Information Property List Entries
Information property lists (Info.plist
files) contain information an application can access at runtime. This is similar to Java’s system properties. Information property lists, however, specify Mac OS X–specific application details, such as the application type and its icon. In addition, some Java-specific settings are also stored there; for example, the Java VM version that Mac OS X uses to run the application.
The following sections describe the simple views of information property list entries. See Mac OS X Developer Release Notes: Information Property List at http://developer.apple.com/releasenotes/index.html for more information about information property lists.
Basic Information
The Basic Information pane, depicted in Figure 2-7, encapsulates identification information about the application package. Table 2-12 describes its elements.
data:image/s3,"s3://crabby-images/31f8e/31f8e289a7a7ebb85a04ad22c6dddf26301171b3" alt="Basic Information pane of the target editor in Project Builder"
Element label | Description | Corresponding Info.plist entry |
---|---|---|
Executable | Name of the file containing the application’s executable code. |
|
Identifier | Package-style name (for example, |
|
Type | Four-letter type indicator for the bundle. For example, |
|
Signature | Four-letter creator code for the bundle. |
|
Version | Version number for the bundle. For example, |
|
Display Information
The Display Information pane, depicted in Figure 2-8, encapsulates display information about the application package file. Table 2-13 describes its elements.
data:image/s3,"s3://crabby-images/3ec60/3ec603b3224b74ba26fcce8b8677c96c1955d3fe" alt="Display Information pane of the target editor in Project Builder"
Element label | Description | Corresponding Info.plist entry |
---|---|---|
Display name | In application packages, localized name that is displayed in the menu bar. |
|
Get-Info string | Localized string that appears in Info windows or the Inspector in the Finder. |
|
Short version | Localized string with bundle-version information. This is the string displayed in Info windows or the Inspector in the Finder when |
|
Application Icon
The Application Icon pane, depicted in Figure 2-9, identifies the icon file to be used for the application package’s icon, which is the icon the Finder displays to the user. Table 2-14 describes its elements.
data:image/s3,"s3://crabby-images/15e49/15e49acba6c86197be933aa713687d58db24346c" alt="Application Icon pane of the target editor in Project Builder"
Element label | Description | Corresponding Info.plist entry |
---|---|---|
Icon file | Name of the icon file for the bundle. |
|
Cocoa Java–Specific
The Cocoa Java–Specific pane, depicted in Figure 2-10, contains information specific for Cocoa applications written in Java. Table 2-15 describes its elements.
data:image/s3,"s3://crabby-images/2d74d/2d74dd797fb328c233063feaaa11c70c06a1f712" alt="Cocoa Java–Specific pane of the target editor in Project Builder"
Elements label | Description | Corresponding Info.plist entry |
---|---|---|
Needs Java | When selected, indicates that a Cocoa application needs to instantiate a Java virtual machine. |
|
Root Directory | The directory where the application’s JAR files are stored in the application bundle. For example, |
|
Path | List of JAR files contained in the root directory. |
|
Pure Java–Specific
The Pure Java Specific pane, depicted in Figure 2-11, contains settings that are specific to Pure Java. Table 2-16 describes its elements.
data:image/s3,"s3://crabby-images/278f2/278f226b77d4e231f7fff6454d78dac2ad27a387" alt="Pure Java–Specific pane of the target editor in Project Builder"
Element label | Description | Corresponding Info.plist entry |
---|---|---|
Main Class | Fully qualified name of an application’s main class. |
|
Class Path | List of paths to Java class files of JAR files the application uses. |
|
Place JFrame menu bars at top of screen | When selected, the application’s menu bar follows Mac OS X style: It’s placed at the top of the screen instead of within each application window. |
|
Growbox intrudes | When selected, the resize control is part of the window pane. When unselected, a white band is added to the bottom of the window, so that the resize control doesn’t intrude in the windows’ content. |
|
Set cwd to Contents/Resources/Java subdirectory | When selected, the application’s working directory is set to the bundle’s |
|
Anti-alias text | Toggles text anti-aliasing. |
|
Live resizing | Toggles live resizing of windows. |
|
Target VM Version | Version of the Java runtime the application requires. For example, |
|
Additional VM Options | Command-line options to add to the java invocation. For example, |
|
Additional Properties | Additional Java system properties, which you can access through |
|
Build Styles
During development, you may want to include debugging information in Java class files, but would rather not include it in the final version of those files. For example, the JAVA_COMPILER_DEBUGGING_SYMBOLS
build setting determines whether debugging symbols are added to class files. So, a project could have a target called MyAppDebug
that sets that build setting to YES
and a target called MyApp
that sets it to NO
. However, when you need to set another build setting that affects the building of the application, you would have to make the change in two targets instead of one. To solve this situation, Project Builder includes build styles.
Build styles contain build setting configurations that override target build settings. So, instead of having two targets to produce an application, one for debugging and another for your customers, a project would contain one target that builds both types of products and a couple of build styles, one called Development and another named Deployment. The Development build style would contain the JAVA_COMPILER_DEBUGGING_SYMBOLS = YES
build configuration, while the Deployment build style would have JAVA_COMPILER_DEBUGGING_SYMBOLS = NO
.
To add a build style to a project, choose Project > New Build Style and name it. Then add the build settings that the build style is to override. For example, the build style shown in Figure 2-12 tells javac
to optimize code for execution time.
data:image/s3,"s3://crabby-images/0ccaa/0ccaa23cf117f6c4218afeabf34585952a269020" alt="Build style definition"
Build Phases
Build phases define concrete tasks that Project Builder performs to build a product. These are the build phases you use in Java application projects:
Sources Compiles the selected Java source files using
javac
and puts the generated class files in$TEMP_DIR/JavaClasses
. It uses theJavaFileList
file in the target’s build directory (theTEMP_DIR
build setting).Java Resource Files Copies the selected Java resource files, the
Dancestrings.string
file for example, to$TEMP_DIR/JavaClasses
.Bundle Resources Copies the selected bundle resource files, such as the icon file, to the resulting bundle’s
Resources
directory.Frameworks & Libraries Links the class files generated in the Sources build phase with the selected frameworks and libraries, and archives the result in a JAR file (when the
JAVA_ARCHIVE_CLASSES
build setting is set toYES
).Shell Script Files Executes a custom shell script. The value of every build setting is accessible in the script using the format
$BUILD_SETTING
,$(BUILD_SETTING)
, or${BUILD_SETTING}
. Therefore, you can use shell script phases to perform tasks that the other type of build phases do not support. Further, you can insert shell script phases between other build phases to confirm the value of a build setting.Copy Files Copies the files indicated in the build phase to a specified location. To select the files to copy, drag them from the Files list into the Files list.
Figure 2-13 is an example of inserting a shell script phase to confirm the value of a build setting. It shows a script that displays the value of the JAVA_COMPILER_FLAGS
build setting. Figure 2-14 shows the script’s output.
data:image/s3,"s3://crabby-images/a2cd8/a2cd81edb569318040ca5b62bf805eb0e959366c" alt="Build-setting display script"
data:image/s3,"s3://crabby-images/3f156/3f1564e80a0df86eabede6cb7060ad453b22bc2b" alt="Output of a build-setting display script"
Copyright © 2003 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2003-10-10