KEMBAR78
Mobile Application Development | PDF | Integrated Development Environment | Command Line Interface
0% found this document useful (0 votes)
262 views18 pages

Mobile Application Development

This document provides an overview of mobile application development for the Symbian OS, specifically focusing on the Series 60 platform. It covers the development process, tools, and SDKs required for building, deploying, and running applications, including the use of emulators for testing. Additionally, it details the structure of project files and the differences between emulators and real devices, emphasizing the importance of selecting the correct SDK version for compatibility.

Uploaded by

api-3832742
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as RTF, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
262 views18 pages

Mobile Application Development

This document provides an overview of mobile application development for the Symbian OS, specifically focusing on the Series 60 platform. It covers the development process, tools, and SDKs required for building, deploying, and running applications, including the use of emulators for testing. Additionally, it details the structure of project files and the differences between emulators and real devices, emphasizing the importance of selecting the correct SDK version for compatibility.

Uploaded by

api-3832742
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as RTF, PDF, TXT or read online on Scribd
You are on page 1/ 18

mobile application development

symbian os
this chapter overviews the process of building, deploying and running an example series
60 application with a graphical user interface (gui). if you have already been involved in
series 60 development, you may want to skip this chapter. chapter 2 builds on the
overview, providing a detailed description of the project files and the development tools
that are used on a regular basis.

we assume that you have installed both a series 60 software development kit (sdk) and
a chosen integrated development environment (ide). both installations are reasonably
easy and are well documented elsewhere. if you do not have the necessary sdk and ide,
see the preface for details of how to obtain them.

topics covered are:

* series 60 c++ sdks—different versions of the sdks that are available and how they
relate to versions of series 60 platform releases, and hence to specific series 60
products.
* development process overview—a high-level description of the process of
specifying, building and running a series 60 project for an emulator or a target device,
plus a guide to the many ide and build options available to developers.
* series 60 emulators—the features and layout of the series 60 emulators, both debug
and release versions. an overview of the similarities and differences between an
emulator and a real series 60 device.
* building for the emulator— how to build the helloworld project for the emulator
using ides from different vendors and also from a pc command prompt.
* running the emulator— each method of starting an emulator and how to locate and
run the example helloworld application_as both release and debug build variants.
* building for a target device—how to build the helloworld example project for a series
60 device as an appropriate arm binary executable.
* deploying on a target device—how to package up the various components of an
application, options for transferring it to a series 60 device and then how to locate and
execute it.

a step-by-step overview of the development process shows you the essential steps. this
is the fast-track guide to using series 60 c++ build tools and various ides. you will see
how to build and run an example "hello world" application with the series 60 emulator
(version 1 and 2), plus how to build, deploy and run the application on a target device. all
the information needed to build and run the helloworld example is provided within this
chapter.

all the project files, source files and deployment information associated with the
examples in this book are available online as noted in the preface. if you have not
already obtained the source materials, you are advised to download and install them—
they will be helpful for reference as you read through this chapter.
chapter 2 gives detailed explanations of the components that make up a typical project
and the key build tools. chapter 3 covers the fundamentals of symbian os and the key
concepts you must understand fully to develop efficient, reliable code for series 60
devices. in chapter 4 the class structure of a gui application is described and a detailed
examination of typical application code is begun.

details on debugging and testing applications are provided in chapter 13.


series 60 c++ software development kits (sdks)

symbian os is widely used in multiple smart phone platforms, such as series 60, series
80 and series 90, three of the ui platforms from nokia, and uiq (the ui platform from uiq
technology).

series 60 sdks are built upon specific versions of symbian os c++ sdks released by
symbian. an sdk contains a wide range of tools, apis, libraries and documentation to
enable you to develop new applications, typically as after-market applications.

as a developer you may need to work with sdks for more than one version of series 60
(or even sdks for different symbian os ui platforms). the most important issue is to select
the correct sdk version for your chosen series 60 product.

nokia or series 60 licensees release sdks that are suitable for development for a specific
version of series 60 platform. that is to say, each series 60 product is based on a
particular release of the platform, and sdk releases are made to be suitable for
development for a platform version. a particular sdk release may also be suitable for use
with earlier versions of the platform as well. such "backward compatibility" will depend on
the version of the symbian os used as the basis of the release, the apis used by the
application developer and any changes that have occurred in those apis between
platform releases. particular licensees also may introduce additional product-specific
apis to allow developers to access the features that differentiate their series 60 product
from those from other licensees. for example, the siemens sx1 smart phone includes an
fm radio, so the relevant sdk may include "add-on" apis to manipulate the radio. for
maximum compatibility across different licensee products you may want to avoid using
such product-specific apis. you may even choose to limit your use of the general apis to
those that are common and unchanged across a selected range of platform versions.

you will find the key differences between releases of series 60 platform described in
broad detail in the introduction to this book.

more extensive variants of series 60 development platforms are available to licensees,


competence centers, and other software and technology partners to allow them to
develop at the system level, rather than at the application level. this book, however, will
focus on the publicly available sdks.

pc-based platform emulators are provided as part of the sdks so that most development
and testing can be performed without target hardware. series 60 project executables can
be created as debug or release variants for emulators and for target hardware (although
currently some restrictions apply to on-target debugging). additionally, when building for
target devices it is possible to create executable code in various binary formats (for
example, armi, arm4 and thumb, explained later in this chapter). the compilation and
linking process can be performed using command-line tools or from within a variety of
ides. the ides covered here are microsoft visual c++ version 6, metrowerks codewarrior,
and borland c++builder 6 mobile edition and borland c++builderx mobile.

symbian devised a method of specifying development projects in a platform-neutral way.


two universal project files can be created (projectname.mmp and bld.inf), where
projectname is the name of the component or application to be developed (helloworld for
our example project). these two text files can then be used as a starting point for any of
the build options, ides and platform variants.

the bld.inf file specifies the names of all the project component(s) to be built, with each
component specified in its own .mmp file. both types of file are plain text, and often you
will simply have a single .mmp file that defines the application you are creating. if the
project consists of multiple components, such as the application itself and specific
function libraries, then each component would have its own .mmp file. each of the
libraries plus the application would have an .mmp file, and each filename would be listed
in the bld.inf file for the project. the syntax of .mmp and bld.inf files is detailed in chapter
2.

in the helloworld example, there are only two project specification files: bld.inf and
helloworld.mmp. using these two files, any platform-specific project and command files
required can be created.

typically you employ a symbian tool called bldmake, using the two project specification
files as input, to generate a command file called abld.bat. you can then use abld.bat,
from the command prompt, to perform a number of project-related actions. for example,
abld.bat can be used to generate platform- and ide-specific project makefiles. if the
project source code exists, and is complete, abld can be used to build the project for one
or more platforms.

since most development projects are built and run from within an ide, you would usually
create the project files suitable for your chosen ide.

in the case of microsoft visual c++, you use abld at the command line to create the
helloworld.dsp and helloworld.dsw project files. the .dsw file is the workspace file to be
opened from within the ide, and it may reference one or more .dsp files.

for metrowerks codewarrior you can either create the project file from within the ide in
the usual way or import the .mmp file directly into the ide. the import process will create
the codewarrior specific project (helloworld.mcp) file required.

similarly, the borland c++ builder mobile edition ides can perform an equivalent import
task to the metrowerks ide, but by importing the bld.inf file instead of the .mmp file.
borland c++builderx, for example, will create a project file called helloworld.cbx.

opening the ide-specific project file will then allow you to develop, build, run and debug
the application with full ide support.

for developers who prefer working at the command-line level, abld can also be used to
compile and link from a command prompt.
all of the methods for creating the ide (or command-line) specific project files outlined
are described in detail later in this chapter. in addition, figure 1-1 illustrates the use of the
two generic symbian os project files to generate the required platform-specific project
files, either via ide import options or using the symbian tools.

figure 1-1 generation of ide and platform-specific project files from generic symbian files.
using an ide versus command-line tools

the different options currently available to you for working with series 60 development
projects are summarized in table 1-1. more options are becoming available all the time
from symbian, nokia and the development tool vendors borland and metrowerks.
however, it is likely that the microsoft development tools, though currently viable and still
widely used, will no longer be supported in the not-too-distant future.

there are currently considerable differences between the capabilities of the various ides
from microsoft, borland and metrowerks. development to enhance the latter two
development environments is ongoing. emcc software ltd uses ides from all three
vendors as the basis of its development activities. we also use the command-line tools
every day—not because we want to but because we currently have to. this is primarily
for building for target devices and for automating overnight builds. the c++builderx and
codewarrior ides can now build for target devices—but not all essential build operations
are covered by some variants of the ides.

at the time of writing, the easiest and most generic starting point for any new series 60
project is to define a pair of bld.inf and .mmp project files. at emcc software, these files
are used for generation of any ide-specific project files and for use during any command-
line builds needed. this approach is taken throughout the book. it is also the approach
currently adopted by every single example project provided by both symbian and nokia
in their sdks and in the documentation they supply. using an ide exclusively is not
currently possible on a day-to-day basis. things will change before very much longer, but
these are the current facts of life for symbian os and series 60 developers.

table 1-1 pc-based development options summarized


option description
command line building

using the symbian os tools combined with compilation and linking using the microsoft
visual c++ compiler/linker for emulator builds invoked from a command line. emulator
can also be invoked from the command line. source-level debugging on the pc emulator
requires working from within an ide.

the gnu c++ cross compiler and linker used for arm target device builds invoked from the
command line.
microsoft visual c++ ide

compilation and linking using the microsoft visual c++ compiler/linker for emulator builds
from within the ide.

the gnu c++ cross compiler and linker used for arm target device builds invoked from a
command prompt.
borland c++ ide
two ide options are currently available; both use the borland c++ compiler and linker for
emulator builds from within an ide.

the gnu c++ cross compiler and linker used for arm target device builds invoked from the
command line.
metrowerks codewarrior c++ ide

using the metrowerks compiler and linker for emulator builds from within the ide.

the gnu cross compiler and linker for arm target device builds, either invoked from the
command line or directly from within the codewarrior ide.

through the rest of this chapter, the helloworld example project is used to illustrate all the
steps involved in the development, debugging, and deployment process for the series 60
emulator.

all of the other files required for the example application are provided—for example, the
header (.h), source (.cpp) and user interface resource (.rss) files.

you can test the application using the series 60 emulator, either started from within an
ide or run from a command prompt. however, debugging an application on the emulator
must be performed from within an ide.

after developing, running, testing or debugging an application on the emulator you


typically will want to build and run it on a target device. so you will then be shown how to
build the example application for a target device, how to deploy it and then run it on
target series 60 hardware.

series 60 emulators

development, debugging and initial testing of series 60 applications is usually carried out
on a pc-hosted emulator that provides a microsoft windows-based implementation of a
series 60 device. in most cases you will discover that the emulator-based development
process closely mimics the operation of an application running on a real device; so that
the majority of your development work can take place even before hardware is available.
the exact appearance of the emulator may vary from the figures provided and will
depend on the target platform you are working with, the version of series 60 you are
using, and the selected ide. for example, the fascia bitmap may have been changed to
closely resemble a particular series 60 device from a licensee. in addition, buttons and
other interaction elements may be moved or added to emulate the configuration of a
manufacturer's actual device. also, the applications available on the emulator will
depend on the platform version and the device manufacturer's preferences.

some differences between an emulator and a real device cannot be overcome. real
series 60 devices will have hardware accessories such as cameras and other features
such as vibration feedback. thus, at some point, hardware will be necessary for
development and testing. in addition, pc-based emulators do not accurately mimic issue
of precise timing, application performance and memory management.
for pc-based development, the edit/compile/build cycle is based on a microsoft windows-
hosted development toolset. however, instead of linking and building against win32 or
mfc libraries, developers link and build against the headers and pc-format libraries
installed by the series 60 sdk. the resulting windows-format binary executable is then run
under the pc-hosted emulator.

during development, the project file for the specific ide manages all linking and building
details. it also ensures that all outputs from the build, and other required resources, such
as application resource files, are built into the appropriate location for running or
debugging under the emulator.

referring to figure 1-2, the series 60 display is logically divided into three areas: status
pane, main pane and control pane. (see the "series 60 ui style guide" provided with the
series 60 sdk documentation for a comprehensive description of user interface elements
and standards.)

the status pane is the graduated (blue, on the emulator) bar near the top of the screen
plus the area above it. the main pane is the middle section of the screen between the
status pane and the soft key labels at the bottom of the screen. the control pane is the
area immediately below the main pane and includes the soft key labels.

the status pane may display information for the current application, as well as general
information about the device status, such as the signal strength and battery charge. it is
visible in most situations, but sometimes it may be hidden. many games, for example,
will use the whole screen.
figure 1-2 series 60 emulator.

the main pane is the principal area of the screen where an application can display its
data. typically, this area, also referred to as the client rectangle, is fully occupied by an
application's data display.

the control pane occupies the bottom part of the screen and displays the labels
associated with the two soft keys and a scroll indicator when required. like the status
pane, the control pane can also be hidden at times. in such situations it is within series
60 style guidelines to have the user assume the availability of the options menu (the
default label for the left soft key), even though it may not be visible. (see the "nokia
series 60 games ui style guide" provided with the series 60 sdk documentation.)

the two buttons below the control pane are the left and right soft keys and are used to
select the currently associated options menu or labeled action. the four-way navigation
key will scroll up, down, left, right, or will select if pressed (clicked) in the center.

you can interact with the emulator via the pc mouse or cursor keys for navigation around
the objects on the display. it is possible to use mouse clicks to select folders and other
displayed objects directly rather than via clicking on the four-way navigation key (on the
emulator only). for data entry the pc keyboard can be used, or you may click on the
twelve-way keypad on the emulator fascia. therefore the interaction with the emulator is
close to, but not exactly the same as, using a real series 60 device_there is no pen input
on a real device, so all movement and selection is through cursor (joystick) navigation.
building for the emulator

since series 60 applications can be built from a command prompt or from within an ide,
we have detailed both methods here. we'll start by building the project to run under the
pc-hosted emulator (that is, for an x86 instruction set) using the c++ compiler supplied
with the ide. we almost always use a debug build, so that symbolic debug information
and memory-leak checking are available (checking for memory dynamically allocated on
the heap that is not released correctly).

building from the command line

open a command prompt and change to the drive/folder that contains your series 60 sdk.
navigate to the folder where the project definition (helloworld.mmp) and component
description (bld.inf) files are located—for example:

\symbian\series602_0\emccsoft\helloworld\group

for a series 60 2.x project

or

\symbian\6.1\series60\emccsoft\helloworld\group

for a series 60 1.x project

and type:

bldmake bldfiles

after a second or two this command completes without any visual output. it uses the
bld.inf and helloworld.mmp files to generate a new file: abld.bat. this command file is
always generated in place, as required. unlike the bld.inf and .mmp files, abld.bat is not
portable between different ides and should never be edited by hand.

to compile and link the project, type:

abld build wins udeb //for visual c++


abld build winsb udeb //for borland c++
abld build winscw udeb //for codewarrior

the abld command will build the project (in other words, compile and link) for the series
60 emulator (the wins, winscw or winsb variant) with debugging (udeb—unicode debug)
information included in the binary executable.
building from an ide

projects, such as our example helloworld application, normally are built and run from
within an ide, so we need to create ide-specific project files from the bld.inf and
helloworld.mmp files. for visual c++ this must be performed from the command line,
using tools supplied by symbian. for borland and codewarrior this is optional, since both
ides can import either the bld.inf or .mmp file, respectively, to create the ide project files.

when working from the command prompt it may be necessary to create the abld.bat file
if it does not exist already, or recreate it if the .mmp file or bld.inf file has changed. at a
command prompt you create the abld command file by typing:

bldmake bldfiles

building using microsoft visual c++ide

open a command prompt and navigate to the drive/project folder for the helloworld
project and then type:

abld makefile vc6

this will create project and workspace files (helloworld.dsp and .dsw files) suitable for
microsoft visual c++. they will be located under the \epoc32\build sub-folder structure;
the complete path will depend on the location of your sdk, for example:

\epoc32\build\emccsoft\helloworld\helloworld\wins

by opening the workspace file (helloworld.dsw) in visual c++, you can compile or link the
application, either by pressing f7 or via the ide menu option, build|build helloworld.app.

building using borland c++ide builder 6

if you are using borland c++builder 6 mobile edition, which is based on c++builder 6
personal edition with the mobile plug-in, you can simply import the bld.inf file for the
helloworld project into the ide. use the file|new|other menu option. then select the mobile
tab in the resulting dialog: import mobile application. browse to the location of the
component description (bld.inf) file and open it.

use ctrl+f9, or project|make from the menu, to build. to build and run, use f9 or run|run
from the menu. note that f9 or run|run will cause a project rebuild each time! to just run
the emulator, use tools|mobile build tools|run emulator. you may be prompted to save a
number of project-related files, for example, borland project (.bpr), borland project group
(.bpg) files. these files will be saved in the same folder as your bld.inf file.

it is also possible to execute individual abld commands and run other sdk tools such as
aifbuilder and sisar from the tools|mobile build tools menu. these tools are described in
chapter 2.

building using borland c++builderx

when using any of the commercial c++builderx products, you can simply import the
bld.inf file for the helloworld project into the ide.

use file|new and click the mobile c++ tab in the object gallery. select import symbian c++
project. select the correct series 60 sdk from the drop-down list, browse to the location of
the project bld.inf file. press the next tab, give the project a name, press the finish tab
and the project will open. press ctrl+f9 or select project|make project. to run, press f9, or
select run|run project or use the toolbar tab to make and run the project.

building using codewarrior ide

if you are using metrowerks codewarrior for symbian (personal v2.5, other editions may
vary slightly), you can simply import the helloworld.mmp file using the ide menu option,
file|import project from .mmp file.

this runs a project conversion wizard. select the sdk to use with this project, select (or
browse to) the .mmp file, and select a platform of winscw (or all by leaving it blank). the
build variant will default to udeb. use f7 or project|make from the menu to build the
project.

the codewarrior project files (.mcp, .xml, .resources and .pref files) are created
automatically in the same directory as the helloworld.mmp file.

alternatively you can create a codewarrior ide project from the command line. to do this,
run bldmake bldfiles as described; then, to generate a codewarrior ide project, use:

abld makefile cw_ide

this creates an importable project file helloworld.xml in the directory:

\epoc32\build\emccsoft\helloworld\helloworld\winscw

you can now use codewarrior to import this file and to generate a native project (.mcp)
file. choose the file|import project menu option, select the helloworld.xml file, and choose
a name for the project (such as helloworld again). codewarrior will now generate and
load the project, which you can build, run, debug and so on, using the normal ide
commands.
running the emulator

in a series 60 sdk two versions of the emulator executable are available: a version built
containing symbolic debugging information, and another built as a release variant. the
release emulator is limited to evaluation and demonstration of applications—it starts up
considerably quicker because of the absence of the debugging information.

both versions are called epoc.exe, but they are located in their own subdirectories. the
name epoc is historical—it was the name of the operating system prior to symbian os.

in normal development activities, it is usual to use the debug variant of the emulator.
depending on your choice of ide, you may be able to run the debug version normally or
in "debug mode." to be able to run the same "debug emulator" in two modes may seem
a little confusing at first.

sometimes you may want to start the emulator, locate the application and run it (as
described later) simply for testing purposes. if a serious error occurs, the emulator and
application will shut down in a controlled way.

other times you may want to put a breakpoint in your code at a specific point where you
think a problem exists, and then have the ide run the emulator in "debug mode." you
then locate the application and run it as before. suitable interaction with your application
will cause the breakpoint in the code to be reached. at that point, the source code will be
displayed in the ide along with all of the symbolic debug information associated with the
application. then you can use the debugging features of the ide to step through sections
of code, in a controlled manner. all the while you are able to view the application source
code, data, call stack and other debug-related information displayed by the ide to assist
you in tracking down errors in code or logic.

the appearance of a typical series 60 emulator is shown in figure 1-3. debugging an


application under an emulator using the microsoft visual c++ ide is illustrated in figure 1-
4.
emulator executable locations

for a series 60 1.2 sdk the release build emulator is typically located under the following:

for visual c++

\symbian\6.1\series60\epoc32\release\wins\urel\epoc.exe

for borland c++

\symbian\6.1\series60\epoc32\release\winsb\urel\epoc.exe

for codewarrior

\symbian\6.1\series60\epoc32\release\winscw\urel\epoc.exe

(full size image)


figure 1-3 applications grid and list views of series 60 platform 1.2 debug emulator.

(full size image)

figure 1-4 the helloworld application on the emulator in debug mode under the microsoft
visual c++ ide.

the debug build emulator is typically located under:

for visual c++

\symbian\6.1\series60\epoc32\release\wins\udeb\epoc.exe

for borland c++

\symbian\6.1\series60\epoc32\release\winsb\udeb\epoc.exe

for codewarrior

\symbian\6.1\series60\epoc32\release\winscw\udeb\epoc.exe

the exact paths will depend on the options you choose during the installation of the sdk.
in the case of the series 60 2.x sdk the paths to the emulator will be very similar—for
example:
\symbian\series602_0\epoc32\release\wins\udeb\epoc.exe.

figure 1-3 shows the series 60 1.2 emulator. it starts up showing the applications main
menu as either a grid view or a list view.

the series 60 2.0 emulator starts with a mock-up of the phone application, and you have
to navigate to the applications menu by pressing the applications button shown in figure
1-3. whatever version of series 60 platform you are using, always specify the debug
(udeb) version of the emulator executable as the default for development projects—for
example:

\epoc32\release\wins\udeb\epoc.exe.

emulator debug mode

when running the application in debug mode under the emulator, the source code,
function call stack, variable information and so on are shown as soon as the breakpoint
in the code is reached, as shown in figure 1-4. the emulator window itself may disappear
(it is minimized) if the application code is not at a point where user input is required.
running the emulator from a command prompt

to run the debug emulator from the command line, open a command prompt, change to
the folder in your series 60 sdk where the epoc.exe application is located (for example,
\symbian\6.1\series60\epoc32\release\wins\udeb) and type the following:

epoc

this will start the debug emulator and you can then locate and run your application, but
not in debug mode. to debug an application you need to run the emulator in debugging
mode and this can only be done from within an ide. to run the release emulators enter
the following:

epoc -rel

running the emulator from the visual c++ide

from within the visual c++ ide you can start the debug version of the emulator by
pressing ctrl+f5, or from the menu use build|execute epoc.exe. this will run the emulator
in non-debug mode. alternatively, you can use f5 or select build|start debug|go from the
menu to run the emulator in debug mode.

the first time you run the emulator for a visual c++ project, a dialog will appear asking
you to supply the name of the executable. navigate to epoc.exe in the folder
\epoc32\release\wins\udeb in the root of your sdk.
running the emulator from the borland c++builder 6 and c++builderx ides

you can start the debug version of the emulator using the tools|mobile build tools menu
option, then select run emulator. alternatively you can use the run|run menu option (f9),
but it will cause a project rebuild each time—this can be a lengthy and time-consuming
process! using this option, you will need to cancel the build dialog ("compiling") before
the emulator will start up.
if you are running the emulator from c++builderx, use the run|debug project menu option
or press shift+f9. if you wish to rebuild the project and start the emulator, select run|run
project or press f9.
running the emulator from the codewarrior ide

select the project|run menu option or press ctrl+f5 to run the emulator. press f5 or use
the project|debug menu option to run the emulator in debug mode.

locating and running the application

navigate to, and select the helloworld application by clicking on the image of the cursor
keys on the emulator fascia bitmap, or by using the pc keyboard cursor (arrow) keys.
click on the selection button (in the middle of the cursor controls) to start the application.

tip: applications that do not have their own specific icon (as specified in an .aif file,
detailed in chapter 2) will be given a default icon, which looks like a piece of a jigsaw
puzzle, by the system.

under some sdk/ides (for example, versions of borland and codewarrior), the application
you have built may be located in a folder called "other" rather than on the main desktop.
if so, navigate to and select the other folder and then open it by clicking on the selection
button. navigate to and select the helloworld application and click on the selection button
to invoke the application.

the helloworld application will run and should appear as shown in figure 1-5.

figure 1-5 the "hello world" application.


debugging the application

alternatively, you could run the application on the emulator from within an ide in
debugging mode—the procedure will vary depending on the ide in use. typically you
would first set a breakpoint at an appropriate point in the source code.

start the emulator in debugging mode. since it is the application (essentially a dynamic
link library—dll) that will be debugged, not the emulator itself, navigate to and run the
application as described earlier in "locating and running the application." the application
will start up, and then execution will stop at the breakpoint you set earlier. you can the
use the facilities of your chosen ide to step through the execution of the application
source code.
further ide help

further explanation of the various ide functions is beyond the scope of this chapter, so for
more details refer to the ide help information, available through the help menu option.

for microsoft visual c++ this is accessed through the help|contents menu option,
provided you installed msdn with your ide.

for borland c++builder 6 this is accessed through the help menu option. you will find a
separate help|borland c++ mobile edition help page as well as the standard borland help
files. for c++builderx, select help|help topics and choose mobile development.

for metrowerks codewarrior there is a help|online manuals menu option that contains lots
of valuable information on working with symbian os.

additional specific ide information can be obtained online—for example, for visual c++
information go to
http://msdn.microsoft.com/
for borland c++ go to http://bdn.borland.com/
and for codewarrior go to http://www.metro-werks.com/mw/develop/wireless/

building for a series 60 device based on an arm processor on a pc requires the use of a
suitable pc-hosted cross compiler (for example, the gnu gcc c++ compiler, as supplied
with the series 60 sdk) to build the executables in a suitable arm binary format.

when building the project for a series 60 device you would typically use a release build,
since that is what you would do to create a final, deliverable application.

to build for target hardware, open a command prompt window and navigate to the group
directory for the gui helloworld project, then enter the following commands:

bldmake bldfiles
abld build armi urel //for visual c++ and codewarrior

or

abld build armib urel //for borland c++


this will cause abld to invoke the build (cross-compilation and linking) system to produce
an armi (arm interworking) release (urel—unicode release) build of the application for
execution on a target device using the gcc tool chain.

there are currently three build variants for arm based devices—armi, arm4 and thumb.
armi executables will work with the other two build variants. typically you should build the
armi binary executable variant for compatibility with the maximum number of real
devices. arm4 builds give maximum performance at the expense of increased code size.
thumb builds will reduce the code size at the expense of a slight reduction in execution
speed.

the build steps actually include c++ compilation, linking, resource compilation, and
production of the application information (.aif) file—the file that contains the application
icon and other specific details.

when building for a target device a symbian os-specific tool called petran is automatically
invoked behind the scenes. petran translates helloworld.app into a form suitable for
loading at runtime by the symbian os executable loader.

if you are using the codewarrior ide to build for a series 60 device, use project|set default
target either to select the required target (for example, armi urel) or to choose build all,
and then build with project|make.

with c++builder x, you need to select the project|properties menu item and then select
the symbian settings tab. from this dialog you can change the platform and build options
to armi and urel, respectively.

note: at the time of writing armi was the only target platform option available.

pressing ctrl+f9 will make the project, creating the installation package (.sis) as part of
the project; installation packages are described in the next section.

the executable and data files (helloworld.app, helloworld.rsc and helloworld.aif) will now
be located in a folder such as \epoc32\release\armi\urel.

for testing on a series 60 device, all of these files have to be transferred to a device and
located in a folder called \system\apps\helloworld\.

file transfer to a device can be performed by copying to a memory card, or via a usb
cable, if the series 60 device manufacturer has included appropriate support in their
product. typically though, the file transfer is performed by packaging all the application
files into a special installation file. the next section describes how this is achieved.

deploying on a target device

applications are delivered to target hardware in the form of a symbian installation system
(.sis) file. a .sis file is a single compressed archive file, containing all of the files required
for installation, plus optional information about the installation process. the symbian
installation system provides a simple and consistent user interface for installing
applications, data or configuration information onto devices based on symbian os.
developers (or end users) install components, packaged in .sis files.

production of .sis files can be performed using the interactive sisar tool provided with the
series 60 sdk. sisar packages all the application files into one .sis file for ease of
installation onto target hardware. alternative methods for producing installation files are
described in chapter 2.

everything required to make an installation (.sis) file is provided with the example
helloworld project—under the \install folder. in this example project we will use a special
installation package source file called helloworld.pkg and a tool from symbian called
makesis.exe.

building a sis install file

after building the arm1 release version of the helloworld application, as described above,
you need to package up the application components into an installation package (.sis)
file. open a command prompt and navigate to the sdk folder for the helloworld project.
change to the \install folder, then build the .sis file by typing:

makesis helloworld.pkg

a successful build will produce an output message such as "created helloworld.sis". the
installation package (.sis) file will have been created in the \install folder. now you need
to transfer it to the device, as described in the next section.
sis file installation

you may choose among three potential installation options, depending on the device you
are using, and other facilities available to you—for example, whether you have access to
a pc with infrared or bluetooth capability, or access to appropriate software based on
symbian connect (nokia pc suite, for example, or a branded equivalent provided by the
device manufacturer):

* installation through the invocation of a .sis file located on a pc, with subsequent
application installation on to the series 60 device through an infrared or bluetooth
session between the pc and the target device, established via software such as symbian
connect.
* installation by transfer of a .sis file through obex (object exchange), over infrared or
bluetooth, from another device such as a pc, symbian os phone or any obex-enabled
device. this process will be managed via the messaging application, which intercepts the
file attached to the message—when you open up the message, it will automatically start
the application installation process on the phone.
* alternatively, .sis files can be sent as email attachments. application installation is
again managed via the messaging application on the phone. when you open the
message, it will automatically start the installer.

the first two options depend on establishing a connection between your development pc
and the series 60 device. the device manufacturer typically supplies suitable
communications software and you will need to refer to the specific instructions supplied
with the connection software.

after installation a much-reduced version of the .sis file remains on the series 60 device
to control the uninstallation of the application, if required, using the application
"manager." this reduced .sis file contains only the information required to uninstall the
application and is typically very much smaller than the original file.

often the original .sis file may still exist on the device, if it was delivered as a message
attachment and the original message has not been deleted from the messaging
application's inbox folder.

running on a target device

transfer the helloworld.sis file provided to the target hardware, using one of the methods
described above. after the transfer you will be offered the chance to install the
application on the device. to run the application follow the procedure outlined in "locating
and running the application" earlier in this chapter. you will be reassured to find that
locating and running the application on a target device is identical to the process on the
emulator—with one small difference: the application will not be located in an "other"
folder.

summary

this chapter has described the whole process of building, deploying and running a simple
gui application on the series 60 emulator and on a real target device. the skills you have
gained here will be used on a daily basis as you continue to develop for series 60.

in the next chapter, you will build on this knowledge and look in detail at the creation of a
simple series 60 application. you will learn about the composition of project files,
examine application information files and understand how to produce installation
package files. some key additional sdk tools that are used on a regular basis will also be
described.

this is a sample chapter from developing series 60 applications: a guide for symbian os
c++ developers written by leigh edwards and richard baker for addison-wesley
professional. reprinted with permission.

---------------------------------------------------------------------------------------------------------------------

You might also like