The introduction of two new Symbian platform target types, STDEXE and STDDLL , was required to enable the specific options for compilers and linkers to generate P.I.P.S. executables.
P.I.P.S. executables are implemented using native Symbian platform executables linked statically to the glue code. The target types STDEXE and STDDLL make symbol information available for lookup by name.
For each new target type the following library files, system files and include paths are included by default . The table below shows the additional libraries and paths for the new target types.
Target Type |
File/Path |
Purpose |
STDEXE |
libcrt0.lib |
Multithreaded 'glue code' library. Provides the E32Main() entry point for a .exe that uses the char main() function. |
STDEXE |
libwcrt0.lib |
Multithreaded 'glue code' library. Provides the E32Main() entry point for a .exe that uses the wide char main() function. |
STDEXE | STDDLL | STDLIB |
euser.lib , backend.lib |
Fundamental libraries that are linked by default for STDEXE s and STDDLL s. |
STDEXE | STDDLL | STDLIB |
\epoc32\include\stdapis |
Location of standard header files for P.I.P.S.. |
The new target types for P.I.P.S. are STDEXE , STDDLL and STDLIB ( STDLIB s are the P.I.P.S. static libraries). For STDLIB s, the user need not annotate source with EXPORT_C or IMPORT_C . All symbols with extern linkage are:
The compiler marks the symbols imported/exported for STDLIB s, while for native Static Libraries the user explicitly needs to specify EXPORT_C / IMPORT_C .
The user should include the new keyword WCHARENTRYPOINT in MMP files to select the Glue code (CRT0) library for the wide char main entry point, libwcrt0.lib . This option is valid only for the STDEXE target type and will be ignored if used with other target types.
With a STDDLL library, functions and data with external linkage are exported by default, without any requirement for the IMPORT_C and EXPORT_C declarations in header or source files. It is important to note that in the Linux world all symbols with external linkage are visible outside a shared object.
When porting C APIs to the Symbian platform, the user should use the new STDDLL target type to indicate to the tool chain that all functions and global data should be exported.
Copyright ©2010 Nokia Corporation and/or its subsidiary(-ies).
All rights
reserved. Unless otherwise stated, these materials are provided under the terms of the Eclipse Public License
v1.0.