Bug 3679
authorJohan Groth <johang@symbian.org>
Fri, 10 Sep 2010 11:29:11 +0100 (2010-09-10)
changeset 1219 0fc9e31020ea
parent 1218 cf7f8806ba43
child 1220 f2fbf395f696
Bug 3679 Moved the copy statement of canonical_system_definition_${sf.spec.sysdef.configurations.list}.xml from generate-layers to sf-zip-logs as generate-layers is not used any longer.
common/build.postbuild.xml
sf-package/build.xml
--- a/common/build.postbuild.xml	Thu Sep 09 13:28:40 2010 +0100
+++ b/common/build.postbuild.xml	Fri Sep 10 11:29:11 2010 +0100
@@ -1,1100 +1,1102 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project name="SF-POSTBUILD" xmlns:hlm="http://www.nokia.com/helium">
-    <target name="sf-postbuild" depends="sf-build-roms">
-        <stopwatch name="sf-postbuild"/>
-        <echo>[SF-POSTBUILD]</echo>
-        
-        <if><istrue value="${sf.relicense.exported.headers}"/>
-        <then>
-            <runtarget target="sf-run-sfl-licence-munging"/>
-        </then>
-        </if>
-        
-        <parallel>
-            <!-- TAG SOURCE CODE -->
-            <if>
-                <istrue value="${sf.spec.tagafterbuild.enable}" />
-                <then>
-                    <echo message="Apply tag to the source code used in this build"/>
-                    <runtarget target="sf-tag-hg-code"/>
-                </then>
-            </if>
-            
-            <!-- Create MD5s -->
-            <if>
-                <istrue value="${sf.spec.md5.enable}"/>
-                <then>
-                    <echo message="INFO Creating MD5s"/>
-                    <runtarget target="sf-run-evalid"/>
-                </then>
-            </if>
-            
-            <!-- Package up the binaries we built -->
-            <if>
-                <istrue value="${sf.spec.package.bin.enable}"/>
-                <then>
-                    <stopwatch name="sf-postbuild packaging binaries"/>
-                    <echo message="INFO Packaging Binaries"/>
-                    <runtarget target="sf-package-binary"/>
-    
-                    <echo message="INFO Validate Zip files"/>
-                    <runtarget target="sf-package-validate"/>
-                    <stopwatch name="sf-postbuild packaging binaries" action="elapsed"/>
-                </then>
-            </if>
-            
-            <!-- run build analysis tools -->
-            <runtarget target="sf-run-analysis"/>
-
-            <if>
-                <istrue value="${sf.spec.publish.enable}"/>
-                <then>
-                    <!-- Generate reports to compare this build to a previous one -->
-                    <runtarget target="sf-compare-to-baseline"/>
-                </then>
-            </if>
-        </parallel>
-        
-        <!-- Generate release_metadata entries for the md5 zips -->
-        <antcall target="sf-zip-content">
-            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name" value="md5-just-metadata" />
-        </antcall>
- 
-        <!-- Launch smoketest -->
-        <if><istrue value="${sf.spec.test.sendpkg.enable}"/>
-            <then>
-                <runtarget target="sf-build-smoketestpkg"/>
-                <runtarget target="sf-send-testpkg"/>
-            </then>
-        </if>
-
-        <!-- Launch BC check -->
-        <if><istrue value="${sf.spec.bccheck.enable}"/>
-            <then>
-                <runtarget target="sf-bc-check"/>
-            </then>
-        </if>
-
-        <!-- Launch package tests -->
-        <if><istrue value="${sf.spec.package.test.enable}"/>
-            <then>
-                <runtarget target="sf-test-package"/>
-            </then>
-        </if>
-
-        <!-- copy log files linked to the generation of roms for REE -->
-        <runtarget target="sf-copy-rom-logs"/>
-
-        <runtarget target="sf-merge-brag"/>
-
-        <!-- Zip up all the logs -->
-        <runtarget target="sf-zip-logs"/>
-        
-        <if>
-            <istrue value="${sf.spec.publish.enable}" />
-            <then>
-                <echo message="Send links to Diamonds"/>
-                <runtarget target="sf-links-to-diamonds"/>
-                <echo message="Send BRAG status information to Diamonds"/>
-                <runtarget target="sf-brag-to-diamonds"/>
-                
-                <echo message="Publish log files and reports to ${sf.spec.publish.rootdir}"/>
-                <runtarget target="sf-publish"/>
-            </then>
-        </if>
-        <stopwatch name="sf-postbuild" action="elapsed"/>
-    </target>
-
-    <target name="sf-tag-hg-code">
-        <!-- To do the tagging, we need to know what tag to use, and who the author is (from hg's perspective) -->
-        <fail message="This target needs to have all the details specified, or to be run interactively so it can query the user">
-            <condition>
-                <and>
-                    <isset property="sf.hudson.executor.number"/>
-                    <not>
-                        <or>
-                            <isset property="sf.tagafterbuild.tag"/>
-                            <isset property="sf.hg.ui.username"/>
-                        </or>
-                    </not>
-                </and>
-            </condition>
-        </fail>
-
-        <!-- Ask the user, interactively, what tag to use -->
-        <input addproperty="sf.tagafterbuild.tag" message="Enter the tag to apply to the code (eg &quot;PDK_1.0.1&quot;):"/>
-        <fail message="No tag supplied">
-            <condition>
-                <length string="${sf.tagafterbuild.tag}" trim="true" length="0"/>
-            </condition>
-        </fail>
-
-        <!-- Now get the username sorted out -->
-        <exec executable="hg" outputproperty="sf.hg.showconfig.ui.username">
-            <arg value="showconfig"/>
-            <arg value="ui.username"/>
-        </exec>
-        <input addproperty="sf.hg.ui.username" message="Enter hg author credentials (eg &quot;Fred Bloggs &lt;fredb@example.org&gt;&quot;) default is" defaultvalue="${sf.hg.showconfig.ui.username}"/>
-        <fail message="No author supplied">
-            <condition>
-                <length string="${sf.hg.ui.username}" trim="true" length="0"/>
-            </condition>
-        </fail>
-
-        <fmpp sourceFile="${sf.common.config.dir}/templates/tag-hg-code.ant.xml.ftl"
-              outputFile="${temp.build.dir}/tag-hg-code.ant.xml">
-            <data expandProperties="yes">
-                ant: antProperties()
-                data: csv(${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}, {separator:','})
-            </data>
-        </fmpp>
-        <ant antfile="${temp.build.dir}/tag-hg-code.ant.xml"/>
-    </target>
-
-    <target name="sf-push-hg-tags">
-        <!-- To do the pushing, we need to have a set of credentials for the developer.symbian.org site -->
-        <fail message="This target needs to have loging credentials specified specified, or to be run interactively so it can query the user">
-            <condition>
-                <and>
-                    <isset property="sf.hudson.executor.number"/>
-                    <not>
-                        <or>
-                            <isset property="sf.symbian.account.username"/>
-                            <isset property="sf.symbian.account.password"/>
-                        </or>
-                    </not>
-                </and>
-            </condition>
-        </fail>
-
-        <input addproperty="sf.symbian.account.username" message="Enter symbian.org username (eg &quot;fredb&quot;)"/>
-        <fail message="No author supplied">
-            <condition>
-                <length string="${sf.hg.ui.username}" trim="true" length="0"/>
-            </condition>
-        </fail>
-
-        <input addproperty="sf.symbian.account.password" message="Enter symbian.org password (eg &quot;unguessable&quot;)">
-            <!-- Ant 1.8 supports secure here, which would be an improvement... -->
-            <handler type="default"/>
-        </input>
-        <fail message="No password supplied">
-            <condition>
-                <length string="${sf.hg.ui.password}" trim="true" length="0"/>
-            </condition>
-        </fail>
-
-        <if>
-            <not>
-                <available file="${build.drive}/tagging" type="dir"/>
-            </not>
-            <then>
-                <!-- No dir with tagged repos in - create them! -->
-                <runtarget target="sf-tag-hg-code"/>
-            </then>
-        </if>
-
-        <fmpp sourceFile="${sf.common.config.dir}/templates/push-hg-tags.ant.xml.ftl"
-              outputFile="${temp.build.dir}/push-hg-tags.ant.xml">
-            <data expandProperties="yes">
-                ant: antProperties()
-                data: csv(${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}, {separator:','})
-            </data>
-        </fmpp>
-        <ant antfile="${temp.build.dir}/push-hg-tags.ant.xml"/>
-    </target>
-
-    <target name="sf-run-evalid" >
-        <delete dir="${build.drive}/output/md5"/>
-        <mkdir  dir="${build.drive}/output/md5"/>
-
-        <parallel>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/include output/md5/epoc32_include.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/s60 output/md5/epoc32_s60.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/localisation output/md5/epoc32_localisation.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -x \.sym$ -x ^armv5/udeb -x ^armv5/urel -x ^winscw/udeb -x ^winscw/urel -g epoc32/release output/md5/epoc32_release.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -x \.sym$ -g epoc32/release/armv5/udeb output/md5/epoc32_release_armv5_udeb.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -x \.sym$ -g epoc32/release/armv5/urel output/md5/epoc32_release_armv5_urel.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -x \.sym$ -g epoc32/release/winscw/udeb output/md5/epoc32_release_winscw_udeb.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -x \.sym$ -g epoc32/release/winscw/urel output/md5/epoc32_release_winscw_urel.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/cshlpcmp_template output/md5/epoc32_cshlpcmp_template.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/data output/md5/epoc32_data.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/engdoc output/md5/epoc32_engdoc.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/engineeringtools output/md5/epoc32_engineeringtools.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/gcc output/md5/epoc32_gcc.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/gcc_mingw output/md5/epoc32_gcc_mingw.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/ksa output/md5/epoc32_ksa.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/rom output/md5/epoc32_rom.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/rombuild output/md5/epoc32_rombuild.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/sbs_config output/md5/epoc32_sbs_config.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/sdk_special output/md5/epoc32_sdk_special.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/stdapis output/md5/epoc32_stdapis.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/stubs output/md5/epoc32_stubs.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/tools output/md5/epoc32_tools.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/wins output/md5/epoc32_wins.md5"/>
-        </exec>
-        <exec executable="cmd" dir="${build.drive}/">
-            <arg value="/c"/>
-            <arg value="evalid -g epoc32/winscw output/md5/epoc32_winscw.md5"/>
-        </exec>
-        </parallel>
-        <!-- package MD5s directly into epoc32/relinfo location so that its usable out-of-the-box -->
-        <mkdir dir="${build.output.dir}/zips/release"/> <!-- Hack to prevent non-existing release dir -->
-        <zip destfile="${build.output.dir}/zips/release/build_md5.zip">
-            <zipfileset dir="${build.drive}/output/md5/" prefix="epoc32/relinfo"/>
-        </zip>
-    </target>    
-    
-    <target name="sf-package-binary" depends="sf-package-postbuild-rnd,sf-merge-manifest">
-        <!-- Warning: Reverting to using the He zipper will also revert to a single zip for the binaries:
-             would need to update the template and possibly the script that populates it -->
-        <!--antcall target="sf-zip-content">
-            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name" value="bin" />
-        </antcall-->
-        <parallel>
-            <sequential>
-                <if>
-                    <isset property="sf.sdk.header.list.file"/>
-                    <then>
-                        <property name="sf.epoc32.exclusions.file" value="${sf.sdk.header.list.file}"/>
-                    </then>
-                </if>
-                <property name="sf.epoc32.exclusions.file" value="nul:"/>
-                <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_epoc32.log">
-                    <arg value="a"/>
-                    <arg value="-t${sf.spec.package.zip.format}"/>
-                    <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/> <!-- rnd content taken from internal hg repos -->
-                    <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                    <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/> <!-- merged list of prebuilt content such as binaries_prebuilt -->
-                    <arg value="-x@${sf.epoc32.exclusions.file}"/>
-                    <arg value="-x!epoc32\gcc"/>
-                    <arg value="-x!epoc32\gcc_mingw"/>
-                    <arg value="-x!epoc32\tools"/>
-                    <arg value="-x!epoc32\data\buildinfo.txt"/>
-                    <!-- Feature database artifacts released as part of the tools zip -->
-                    <arg value="-x!epoc32\data\config\features.dat"/>
-                    <arg value="-x!epoc32\include\featureuids.h"/>
-                    <arg value="-x!epoc32\rom\include\feature.iby"/>
-                    <arg value="-x!epoc32\rom\include\featuredatabase.xml"/>
-                    <arg value="-x!epoc32\data\media"/> <!-- Files created when emulator is used to create comms database - not worth releasing-->
-                    <arg value="-x!epoc32\build"/>
-                    <arg value="-x!epoc32\release\armv5"/>
-                    <arg value="-x!epoc32\release\winscw"/>
-                    <arg value="-xr!*.sym"/>
-                    <arg value="${build.drive}/output/zips/release/binaries_epoc.zip"/>
-                    <arg value="epoc32\"/>
-                </exec>
-            </sequential>
-            
-            <if>
-                <isset property="sf.sdk.header.list.file"/>
-                <then>
-                    <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_sdk.log">
-                        <arg value="a"/>
-                        <arg value="-t${sf.spec.package.zip.format}"/>
-                        <arg value="-i@${sf.sdk.header.list.file}"/>
-                        <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                        <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                        <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                        <arg value="-x!epoc32/include/featureuids.h"/> <!-- This needs to come from the tools zip instead -->
-                        <arg value="${build.drive}/output/zips/release/binaries_epoc_sdk.zip"/>
-                    </exec>
-                    <!-- Check that all the files we want in the SDK are zipped -->
-                    <antcall target="sf-log-to-brag">
-                        <param name="sf.brag.id" value="SDK"/>
-                        <param name="sf.brag.log" value="${build.log.dir}/zip_${build.id}_binaries_sdk.log"/>
-                        <param name="sf.brag.phase" value="Postbuild"/>
-                        <param name="sf.brag.step" value="Package SDK"/>
-                    </antcall>
-                    <!-- Generate release_metadata entries for the SDK zip -->
-                    <antcall target="sf-zip-content">
-                        <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-                        <param name="zip.target.name" value="bin-sdk-just-metadata" />
-                    </antcall>
-                </then>
-            </if>
-            
-            <!-- WinsCW binaries, by udeb/urel/lib -->
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_udeb.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="-xr!*.sym"/>
-                <arg value="-xr!*.lib"/>
-                <arg value="${build.drive}/output/zips/release/binaries_winscw_udeb.zip"/>
-                <arg value="epoc32\release\winscw\udeb"/>
-            </exec>
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_urel.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="-xr!*.sym"/>
-                <arg value="-xr!*.lib"/>
-                <arg value="${build.drive}/output/zips/release/binaries_winscw_urel.zip"/>
-                <arg value="epoc32\release\winscw\urel"/>
-            </exec>
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_lib.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-ir!epoc32/release/winscw/*.lib"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="${build.drive}/output/zips/release/binaries_winscw_lib.zip"/>
-            </exec>
-            
-            <!-- ARMv5 binaries, by udeb/urel/lib -->
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_udeb.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="-xr!*.sym"/>
-                <arg value="${build.drive}/output/zips/release/binaries_armv5_udeb.zip"/>
-                <arg value="epoc32\release\armv5\udeb"/>
-            </exec>
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_urel.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="-xr!*.sym"/>
-                <arg value="${build.drive}/output/zips/release/binaries_armv5_urel.zip"/>
-                <arg value="epoc32\release\armv5\urel"/>
-            </exec>
-            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_lib.log">
-                <arg value="a"/>
-                <arg value="-t${sf.spec.package.zip.format}"/>
-                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
-                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-                <arg value="-xr!*.sym"/>
-                <arg value="-ir!epoc32/release/armv5/_*.bin"/> <!-- include bootloaders in common lib zipfile -->
-                <arg value="${build.drive}/output/zips/release/binaries_armv5_lib.zip"/>
-                <arg value="epoc32\release\armv5\lib"/>
-            </exec>
-        </parallel>
-        
-        <runtarget target="sf-package-tools"/>
-        <runtarget target="sf-package-prebuilt"/>
-        
-        <!-- Generate release_metadata entries for the above zips -->
-        <antcall target="sf-zip-content">
-            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name" value="bin-just-metadata" />
-        </antcall>
-    </target>
-
-    <target name="sf-package-postbuild-rnd" >
-        <antcall target="sf-zip-content">
-            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name" value="rnd-postbuild" />
-        </antcall>
-    </target>
-
-    <target name="sf-package-tools" depends="sf-merge-manifest">
-        <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_tools_epoc32.log">
-            <arg value="a"/>
-            <arg value="-t${sf.spec.package.zip.format}"/>
-            <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
-            <arg value="-x@/output/temp_build_files/manifest_excludelist.txt"/>
-            <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
-            <arg value="${build.drive}/output/zips/release/tools_epoc.zip"/>
-            <arg value="epoc32/tools"/>
-            <arg value="epoc32/gcc"/>
-            <arg value="epoc32/gcc_mingw"/>
-            <arg value="epoc32/data/buildinfo.txt"/>
-            <arg value="epoc32/data/config/features.dat"/>
-            <arg value="epoc32/include/featureuids.h"/>
-            <arg value="epoc32/rom/include/feature.iby"/>
-            <arg value="epoc32/rom/include/featuredatabase.xml"/>
-        </exec>
-        <antcall target="sf-zip-content">
-            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name" value="tools" />
-        </antcall>
-    </target>
-    
-    <target name="sf-package-validate">
-        <exec executable="7z" dir="${build.drive}/output/zips" failonerror="false" output="${build.drive}/output/zips/validate.log">
-            <arg value="t"/>
-            <arg value="*.zip"/>
-        </exec>  
-        <exec executable="7z" dir="${build.drive}/output/zips/release" failonerror="false" output="${build.drive}/output/zips/release/validate.log">
-            <arg value="t"/>
-            <arg value="*.zip"/>
-        </exec>  
-    </target>
-
-    <!-- merge manifests for prebuilt stuff delivered at the start of build process -->
-    <target name="sf-merge-manifest">
-      <echo message="INFO Build drive is ${build.drive} "/>
-      <concat destfile="${build.drive}\output\temp_build_files\manifest_excludelist.txt">
-        <fileset dir="${build.drive}" includes="*manifest*" excludes="manifest_excludelist.txt"/>
-      </concat>
-       
-       <!-- touch file to update/create it in the event that there are no manifest* files available 
-            as 7z will not be happy being given a non-existent file -->  
-      <touch file="${build.drive}\output\temp_build_files\manifest_excludelist.txt"/>
-    </target>
-
-    <target name="sf-package-prebuilt" depends="sf-merge-manifest">
-    <!-- for each prebuilt manifest* file, repackage -->  
-
-      <for param="manifest">
-        <path>
-          <fileset dir="${build.drive}\">
-            <include name="manifest*.txt"/>
-            <exclude name="manifest*restricted*.txt"/> <!-- dont repack restricted content such as testconfigfileparser -->
-          </fileset>
-        </path>
-        <!-- strip manifest_ and .txt extension for matched file -->
-        <sequential>
-        <propertyregex property="manifest.shortname" override="true" input="@{manifest}" regexp="manifest_(\S+)(.txt)" select="\1" global="true"  casesensitive="false"/>
-        <propertyregex property="manifest.fullname"  override="true" input="@{manifest}" regexp="(.*)" select="\1" global="true"  casesensitive="false"/>
-        <propertyregex property="manifest.pkgname"   override="true" input="@{manifest}" regexp="manifest_binaries_(\S+)(.txt)" select="\1" global="true"  casesensitive="false"/>
-
-        <echo message="INFO Packaging ${manifest.fullname} into ${manifest.shortname}.zip"/>
-
-        <exec executable="7za" dir="${build.drive}/" output="${build.drive}/zip_${manifest.shortname}.log">
-            <arg value="a"/>
-            <arg value="-t${sf.spec.package.zip.format}"/>
-            <arg value="-i@${manifest.fullname}"/>
-            <arg value="${build.drive}/output/zips/release/${manifest.shortname}.zip"/> 
-        </exec>
-
-        <!-- merge release metadata -->
-        <antcall target="sf-zip-content">
-            <param name="zip.config.file"  value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-            <param name="zip.target.name"  value="bin-${manifest.pkgname}-metadata" />
-            <param name="sf.spec.job.name" value="${manifest.pkgname}" />
-        </antcall>
-        </sequential>  
-      </for>
-
-    </target>
-    <!-- runs analysis of missing bins and source -->
-    <target name="sf-run-analysis">
-        <stopwatch name="sf-run-analysis"/>
-        <mkdir dir="${build.log.dir}/analysis"/>
-        <parallel>
-          <runtarget target="sf-run-analysis-ant"/>
-          <runtarget target="sf-run-analysis-raptor"/>
-          <runtarget target="sf-run-analysis-yarp"/>
-          <runtarget target="sf-run-analysis-whatlog-summary"/>
-          <runtarget target="sf-run-analysis-missing-files"/>
-        </parallel>
-        <if>
-          <istrue value="${sf.spec.publish.enable}"/>
-            <then>
-            <runtarget target="sf-run-analysis-diamonds"/>
-            </then>
-        </if>
-        <stopwatch name="sf-run-analysis" action="elapsed"/>
-    </target>
-
-    <target name="sf-run-analysis-ant">    
-        <echo message="Running source analysis of ANT output"/>
-        <exec executable="perl" dir="${build.log.dir}" failonerror="false" output="${build.log.dir}/analysis/${build.id}_scan_ant.log">
-            <arg value="${sf.common.config.dir}/tools/analysis/scan_antlogs.pl"/>
-            <arg value="*ant*"/>
-            <arg value="*stderr*"/>  <!-- helium 7 splits output into stderr logs, so use them also -->
-            <arg value="*sbs_error*"/> 
-        </exec>
-    </target>
-
-    <target name="sf-run-analysis-raptor">            
-      <!-- Cook the processed raptor logs to produce something in the right format for the BRAG system -->
-      <mkdir dir="${build.log.dir}/summary/"/>
-      <!-- exec executable="perl" output="${build.log.dir}/summary/sbs_BRAG.xml" logError="yes" failonerror="false">
-        <arg value="${sf.common.config.dir}/tools/brag/sbsToBRAG.pl"/>
-        <arg value="${build.log.dir}/analysis/*_compile_preprocessed.log"/>
-      </exec -->
-      
-      <echo message="Running UH parser on *_compile.log files"/>
-      <apply executable="perl" dir="${build.drive}/utilities/uh_parser" failonerror="false" output="${build.log.dir}/analysis/${build.id}_raptorparse.log" parallel="true">
-        <arg value="uh.pl"/>
-        <arg value="-m"/>
-        <arg value="--basedir=${build.log.dir}"/>
-        <fileset dir="${build.log.dir}">
-          <include name="*_compile.log"/>
-          <include name="*_export.log"/>  <!-- for explicit export step -->
-          <exclude name="*build_check_compile.log"/>
-        </fileset>
-      </apply>
-          
-      <!-- Now iterate through the generated TSVs to sort them and remove duplicates -->
-      <for param="tsv">
-        <path>
-          <fileset dir="${build.log.dir}">
-            <include name="releaseables/**/*.tsv"/>
-          </fileset>
-        </path>
-        <sequential>
-          <exec executable="perl" input="@{tsv}" output="@{tsv}">
-            <arg value="${sf.common.config.dir}/tools/sortUnique.pl"/>
-          </exec>
-        </sequential>
-      </for>
-
-      <!-- Cook the raptor analysis further to produce something in the right format for the BRAG system -->
-      <exec executable="perl" output="${build.log.dir}/summary/Uh_BRAG.xml" logError="yes">
-        <arg value="${sf.common.config.dir}/tools/brag/uh2brag.pl"/>
-        <arg value="--index"/>
-        <arg value="${build.log.dir}/html/index.html"/>
-      </exec>
-      <!-- And copy the XSL so the output can be transformed by a browser -->
-      <copy file="${sf.common.config.dir}/tools/brag/brag.xsl" toDir="${build.log.dir}/summary/"/>
-    </target>
-
-    <target name="sf-run-analysis-yarp">
-      <echo message="Running yarp over *_compile.log files"/>
-      <for param="logfile">
-        <path>
-          <fileset dir="${build.log.dir}">
-            <include name="*_compile.log"/>
-            <exclude name="*build_check_compile.log"/>
-          </fileset>
-        </path>
-        <sequential>
-          <propertyregex override="yes" property="yarpfile"  input="@{logfile}" regexp=".*[\\|\/](.*)_compile\.log" replace="\1_yarp.csv"/>
-          <propertyregex override="yes" property="yarpfile_short"  input="${yarpfile}" regexp="[^_]*_[^_]*_[^_]*_(.+)_[^_]*_yarp\.csv" replace="YARP_\1"/>
-          <echo message="Yarping @{logfile}..."/>
-          <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/analysis/${yarpfile}.log" append="true">
-            <arg value="${sf.common.config.dir}/tools/analysis/yarp.pl"/>
-            <arg value="@{logfile}"/>
-            <arg value="${build.log.dir}/analysis/${yarpfile}"/>
-          </exec>
-          <exec executable="cmd" output="${build.drive}/output/logs/analysis/tmp_yarp_files.csv" append="true">
-            <arg value="/c"/>
-            <arg value="echo"/>
-            <arg value="${yarpfile_short},${sf.spec.publish.networkdrive}\${sf.spec.job.name}\builds\${sf.spec.job.codeline}\${build.id}\logs\analysis\${yarpfile},${build.drive}\output\logs\analysis\${yarpfile}"/>
-          </exec>
-        </sequential>
-      </for>
-      
-      <!-- Cook the yarp analysis further to produce something in the right format for the BRAG system -->
-      <mkdir dir="${build.log.dir}/summary/"/>
-      <!-- exec executable="perl" output="${build.log.dir}/summary/Yarp_BRAG.xml" logError="yes">
-        <arg value="${sf.common.config.dir}/tools/brag/yarpToBRAG.pl"/>
-        <arg value="${build.log.dir}/analysis/*_yarp.csv"/>
-      </exec -->
-      
-      <exec executable="perl" dir="${build.drive}" failonerror="false" outputproperty="sf.job.totalyarperrors">
-        <arg value="${sf.common.config.dir}/tools/analysis/parse_yarp_files.pl"/>
-        <arg value="${build.drive}/output/logs/analysis/tmp_yarp_files.csv"/>
-      </exec>
-      <echo message="Total yarp errors: ${sf.job.totalyarperrors}"/>
-    </target>
-    
-    <target name="sf-run-analysis-whatlog-summary" >
-        <sequential>
-          <parallel>
-            <runtarget target="sf-run-analysis-list"/>
-            <runtarget target="sf-run-analysis-whatlog"/>
-          </parallel>
-          <runtarget target="sf-run-analysis-whatlog-merge" />
-          <parallel>
-            <runtarget target="sf-run-analysis-whatlog-package"/>
-            <runtarget target="sf-run-analysis-whatlog-collisons"/>
-          </parallel>
-        </sequential>
-    </target>
-    
-    <target name="sf-run-analysis-list">    
-        <echo message="Running list analysis"/>
-        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_list_results.log">
-            <arg value="${sf.common.config.dir}/tools/analysis/parselistdirs.pl"/>
-            <arg value="..\"/>
-        </exec>
-    </target>
-
-    <target name="sf-run-analysis-whatlog">    
-        <echo message="Running whatlog analysis"/>
-        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_what_results.csv">
-            <arg value="${sf.common.config.dir}/tools/analysis/parsewhatlog.pl"/>
-            <arg value="..\"/>
-        </exec>
-    </target>
-
-    <target name="sf-run-analysis-whatlog-merge" >        
-        <echo message="Running summary analysis"/>
-        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_summary.log">
-            <arg value="${sf.common.config.dir}/tools/analysis/merge_csv.pl"/>
-            <arg value="${build.id}_what_results.csv"/>
-            <arg value="${build.id}_list_results.log"/>
-            <arg value="${build.drive}/output/zips/release/binaries_epoc_additional.zip"/>
-        </exec>
-    </target>
-    
-    <target name="sf-run-analysis-whatlog-package" >        
-        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_analysecomponents.log">
-            <arg value="${sf.common.config.dir}/tools/analysis/analyse_components.pl"/>
-            <arg value="${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
-            <arg value="${build.id}_what_results.csv_results.csv"/>
-            <arg value="${sf.project.location}/sysdefs/system_model_os.xml"/>
-            <arg value="${sf.project.location}/sysdefs/system_model_s60.xml"/>
-        </exec>
-    </target>
-    
-    <target name="sf-run-analysis-whatlog-collisons" >        
-        <echo message="Running collision analysis"/>
-        <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/analysis/${build.id}_collisions.log">
-            <arg value="${sf.common.config.dir}/tools/analysis/find_collisions.pl"/>
-            <arg value="${build.log.dir}/analysis/${build.id}_what_results.csv"/>
-        </exec>
-    </target>
-    
-    <target name="sf-run-analysis-diamonds">
-      <if>
-        <istrue value="${sf.spec.publish.enable}"/>
-        <then>
-          <echo>[SF-RUN-ANALYSIS-DIAMONDS]</echo>
-          <echo message="Translate \output\logs\html\index.html into a Diamonds file"/>
-          <exec executable="perl" dir="${build.drive}">
-            <arg value="${sf.common.config.dir}/tools/uh2diamonds.pl"/>
-          </exec>
-          <echo message="Send ${build.log.dir}/diamonds_uh.xml to Diamonds"/>
-          <exec executable="python">
-            <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
-            <arg value="-u"/>
-            <arg value="http://${diamonds.host}${diamonds.build.id}"/>
-            <arg value="-f"/>
-            <arg value="${build.log.dir}/diamonds_uh.xml"/>
-          </exec>
-        </then>
-      </if>
-    </target>
-    
-    <target name="sf-links-to-diamonds">
-      <fmpp sourceFile="${sf.common.config.dir}/diamonds/linksForDiamonds.xml.ftl" outputFile="${build.log.dir}/linksForDiamonds.xml">
-        <data expandProperties="yes">
-          ant: antProperties()
-        </data>
-      </fmpp>
-      <!-- Send the data to the server -->
-      <exec executable="python">
-        <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
-        <arg value="-u"/>
-        <arg value="http://${diamonds.host}${diamonds.build.id}"/>
-        <arg value="-f"/>
-        <arg value="${build.log.dir}/linksForDiamonds.xml"/>
-      </exec>
-      
-      <echo message="report&#x0009;Summary,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/summary/_brag.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      <echo message="report&#x0009;Raptor Build Summary,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/html/index.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      <echo message="report&#x0009;Build BOM,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/build_BOM.zip,file${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      <echo message="report&#x0009;Build Logs,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/build_logs.zip,file${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      <if><and><equals arg1="${sf.spec.smoketest.enable}" arg2="true"/><equals arg1="${sf.spec.ats.version}" arg2="ats3"/></and><then>
-        <echo message="report&#x0009;Smoke Test Report,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/ATS3Report.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      </then></if>
-      <if><and><equals arg1="${sf.spec.smoketest.enable}" arg2="true"/><equals arg1="${sf.spec.ats.version}" arg2="ats4"/></and><then>
-        <echo message="report&#x0009;Smoke Test Report,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/simplelogger/testreport.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      </then></if>
-      <if><and><equals arg1="${sf.spec.bccheck.enable}" arg2="true"/><equals arg1="${sf.spec.bccheck.enable.ha}" arg2="true"/></and><then>
-        <echo message="report&#x0009;Binary Compatibility Report (Headerfiles),http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/BC/headers_report.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      </then></if>
-      <if><and><equals arg1="${sf.spec.bccheck.enable}" arg2="true"/><equals arg1="${sf.spec.bccheck.enable.la}" arg2="true"/></and><then>
-        <echo message="report&#x0009;Binary Compatibility Report (Libraries),http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/BC/libraries_report.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      </then></if>
-      <if><equals arg1="${sf.spec.bccheck.enable.dynamic}" arg2="true"/><then>
-        <echo message="report&#x0009;Dynamic BC Test Reports,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/index.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
-      </then></if>
-    </target>
-
-    <target name="sf-merge-brag">
-        <!-- Merge all our bits of XML together -->
-        <exec executable="perl" output="${build.log.dir}/summary/_BRAG.xml" logError="true">
-            <arg value="${sf.common.config.dir}/tools/mergeXML.pl"/>
-            <arg value="--xsl=brag.xsl"/>
-            <arg value="--merge=buildStatus,phase(name),step(name),failures(level)"/>
-            <arg value="${build.log.dir}/summary/*?_BRAG.xml"/>
-        </exec>
-    </target>
-
-    <target name="sf-brag-to-diamonds">
-        <!-- Run XSL transform to create file to send to diamonds -->
-        <java jar="${sf.common.config.dir}/sysdefdowngrade/xalan-j_2_7_1/xalan.jar" fork="true">
-            <arg value="-IN"/>
-            <arg value="${build.log.dir}/summary/_BRAG.xml"/>
-            <arg value="-XSL"/>
-            <arg value="${sf.common.config.dir}/tools/brag/bragForDiamonds.xsl"/>
-            <arg value="-OUT"/>
-            <arg value="${build.log.dir}/diamonds-status.xml"/>
-        </java>
-        <if>
-            <istrue value="${sf.spec.publish.enable}"/>
-            <then>
-                <!-- Make sure that the summary directory is available to display the BRAG link -->
-                <mkdir  dir="${publish.dir}/summary/"/>
-                <copy todir="${publish.dir}/summary/" preservelastmodified="true" failonerror="false">
-                   <fileset dir="${build.log.dir}/summary/"><include name="*.*"/></fileset>
-                </copy>
-
-                <!-- Try to obtain the diamonds ID for this build -->
-                <if>
-                    <not><isset property="diamonds.build.id"/></not>
-                    <then>
-                        <property file="${build.log.dir}/diamonds_build_id.properties"/> <!-- This will fail silently -->
-                    </then>
-                </if>
-                <if>
-                    <isset property="diamonds.build.id"/>
-                    <then>
-                        <!-- Send the data to the server -->
-                        <exec executable="python">
-                            <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
-                            <arg value="-u"/>
-                            <arg value="http://${diamonds.host}${diamonds.build.id}"/>
-                            <arg value="-f"/>
-                            <arg value="${build.log.dir}/diamonds-status.xml"/>
-                        </exec>
-                    </then>
-                    <else>
-                        <echo message="diamonds.build.id is not known - unable to push any build specific information to diamonds server"/>
-                    </else>
-                </if>
-            </then>
-        </if>
-    </target>
-
-    <target name="sf-check-utilities-dir">
-        <available property="sf-utilities-available" file="${build.drive}/utilities" type="dir"/>
-    </target>
-
-    <target name="sf-compare-to-baseline" depends="sf-check-utilities-dir" if="sf-utilities-available">
-        <property name="sf.releasenotes.wiki.txt" value="${build.log.dir}/releaseNotes.wiki.txt"/>
-        <delete file="${sf.releasenotes.wiki.txt}"/>
-        <!-- FCL Usage and Changesets -->
-        <exec executable="perl" dir="${build.drive}" output="${sf.releasenotes.wiki.txt}">
-            <arg value="-I"/>
-            <arg value="${sf.common.config.dir}/tools/lib"/>
-            <arg value="${build.drive}/utilities/releaseAutomation/releaseNotes.pl"/>
-            <arg value="--sources=${build.log.dir}/BOM/sources.csv"/>
-            <arg value="--baseline=${sf.previous.pdk.tag}"/>
-        </exec>
-        <!-- Package Comparison and FCL Usage -->
-        <exec executable="perl" dir="${sf.spec.sourcesync.sourcespecdir}" output="${sf.releasenotes.wiki.txt}" append="true">
-            <arg value="${build.drive}/utilities/releaseAutomation/packageComparison.pl"/>
-            <arg value="--sources=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
-            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model.xml"/>
-            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model_os.xml"/>
-            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model_s60.xml"/>
-            <arg value="--baseline=${sf.previous.pdk.tag}"/>
-        </exec>
-        <!-- Mercurial comparison -->
-        <echo file="${sf.releasenotes.wiki.txt}" append="true">== Mercurial Comparison ==${line.separator}${line.separator}</echo>
-        <if>
-            <isset property="sf.previous.pdk.tag"/>
-            <then>
-                <echo file="${sf.releasenotes.wiki.txt}" append="true">The Mercurial changes from Nokia were delivered as a bulk update based on '''XXXXXXXXXXXXXXXXXXXXXX'''.${line.separator}${line.separator}List of the Mercurial changes (files added/removed/modified) between ${sf.previous.pdk.tag} and PDK '''XXXXX''' - [[Media:XXXX.txt]].${line.separator}${line.separator}A short study of the results concentrating on the added and removed files has identified these significant package changes:${line.separator}${line.separator}</echo>
-                <if>
-                    <istrue value="${sf.spec.sourcesync.archive}"/>
-                    <then>
-                        <echo file="${sf.releasenotes.wiki.txt}" append="true">'''Information cannot be derived as source was synced with archive option'''"${line.separator}${line.separator}</echo>
-                    </then>
-                    <else>
-                        <exec executable="perl" dir="${build.drive}/" output="${sf.releasenotes.wiki.txt}" append="true">
-                            <arg value="${build.drive}/utilities/releaseAutomation/mercurialComparison.pl"/>
-                            <arg value="${build.log.dir}/BOM/build-info.xml"/>
-                            <arg value="${sf.previous.pdk.tag}"/>
-                            <arg value="${build.log.dir}/mercurialComparison.tsv"/>
-                        </exec>
-                    </else>
-                </if>
-            </then>
-            <else>
-                <echo file="${sf.releasenotes.wiki.txt}" append="true">'''Information cannot be provided as the tag for the previous PDK was not provided to the build'''"${line.separator}${line.separator}</echo>
-            </else>
-        </if>
-        
-        <!-- Code churn -->
-        <!-- TODO? -->
-        <fixcrlf file="${sf.releasenotes.wiki.txt}"/>
-    </target>
-
-    <!-- package all logs into zipfile for publishing -->
-    <target name="sf-zip-logs" >
-        <if>
-            <istrue value="${sf.spec.logs.zip.enable}"/>
-            <then>
-                <mkdir dir="${build.output.dir}/zips/release"/> <!-- workaround for when there's no other releaseables, just the logs -->
-                <zip destfile="${build.output.dir}/zips/release/build_logs.zip" basedir="${build.drive}"> 
-                    <include name="output/logs/**"/>
-                    <exclude name="output/logs/BC/**"/>
-                    <exclude name="output/logs/BOM/**"/>
-                    <exclude name="output/logs/deliverables/**"/>
-                    <exclude name="output/logs/releaseables/**"/>
-                </zip>
-                <!-- workaround for the time when when 'sf-run-analysis-raptor' has not been run -->
-                <mkdir dir="${build.drive}/output/logs/releaseables"/>
-                <if>
-                    <available file="${build.drive}/output/logs/package_definitions" type="dir"/>
-                    <then>
-                        <zip destfile="${build.output.dir}/zips/release/build_BOM.zip">
-                            <zipfileset dir="${build.drive}/output/logs/BOM" prefix="build_info/logs/BOM"/>
-                            <zipfileset dir="${build.drive}/output/logs/releaseables" prefix="build_info/logs/releaseables"/>
-                            <zipfileset dir="${build.drive}/output/logs" prefix="build_info/logs/BOM">
-                                <include name="envinfo.txt"/>
-                            </zipfileset>
-                            <zipfileset dir="${build.drive}/output/logs/package_definitions" prefix="build_info/package_definitions"/>
-                        </zip>
-                    </then>
-                    <else>
-                        <zip destfile="${build.output.dir}/zips/release/build_BOM.zip">
-                            <zipfileset dir="${build.drive}/output/logs/BOM" prefix="build_info/logs/BOM"/>
-                            <zipfileset dir="${build.drive}/output/logs/releaseables" prefix="build_info/logs/releaseables"/>
-                            <zipfileset dir="${build.drive}/output/logs" prefix="build_info/logs/BOM">
-                                <include name="envinfo.txt"/>
-                            </zipfileset>
-                        </zip>
-                    </else>
-                </if>
-                <antcall target="sf-zip-content">
-                    <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
-                    <param name="zip.target.name" value="info-just-metadata" />
-                </antcall>
-            </then>
-        </if>
-     </target>
-    
-    <target name="sf-publish" depends="prep-publish">
-        <copy todir="${publish.dir}" preservelastmodified="true" failonerror="false">
-           <fileset dir="${build.output.dir}/zips/release/"><include name="build_*.zip"/></fileset>
-        </copy>
-        <mkdir dir="${publish.dir}/html"/>
-        <copy todir="${publish.dir}/html" preservelastmodified="true" failonerror="false">
-           <fileset dir="${build.log.dir}/html"><include name="*.html"/></fileset>
-        </copy>
-        <mkdir dir="${publish.dir}/BC"/>
-        <copy todir="${publish.dir}/BC" preservelastmodified="true" failonerror="false">
-           <fileset dir="${build.log.dir}/BC/">
-               <include name="BBCResults.xsl"/>
-               <include name="headers_report.xml"/>
-               <include name="libraries_report.xml"/>
-           </fileset>
-        </copy>
-        <mkdir dir="${publish.dir}/ats_reports"/>
-        <copy file="${sf.common.config.dir}/tools/ats/report_dummy.html" tofile="${publish.dir}/ats_reports/index.html" failonerror="false"/>
-    </target>
-
-    <!-- TODO: Make this work for package builds once we have sysmodel story worked out -->
-    <target name="sf-run-analysis-missing-files" if="sf.spec.checkbuild">
-        <runtarget target="sf-check-missing-os-files"/>
-    </target>
-    
-    <target name="sf-check-missing-os-files" depends="sf-compile-options">
-        <hlm:argSet id="sbs.check.tools.var">
-            <hlm:arg name="config" value="${sf.spec.sbs.tools.config}" />
-            <hlm:arg name="run-check" value="true" />
-        </hlm:argSet>
-     
-        <hlm:argSet id="sbs.check.main.var">
-            <hlm:arg name="config" value="${sf.spec.sbs.config}" />
-            <hlm:arg name="run-check" value="true" />
-        </hlm:argSet>     
-        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-            <param name="build.system" value="${sf.spec.build.system}" />
-            <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
-            <param name="build.id" value ="sbs_check"/>
-            <reference refid="sbs.check.tools.var" torefid="sbs.var" />
-            <reference refid="sbs.toolsbuild.options" torefid="sbs.make.options" />
-            <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
-        </antcall> 
-        <if><istrue value="${sf.os.compile.iterate}"/>
-          <then>
-            <for list="${sf.spec.sbs.config}" delimiter="," param="sf.spec.check.splitconfig">
-              <sequential>
-                <echo message="INFO [Iterative check] @{sf.spec.check.splitconfig}"/>
-                <hlm:argSet id="sbs.check.iterate.main.var">
-                    <hlm:arg name="config" value="@{sf.spec.check.splitconfig}" />
-                    <hlm:arg name="run-check" value="true" />
-                </hlm:argSet>     
-  
-                <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-                    <param name="build.system" value="${sf.spec.build.system}" />
-                    <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
-                    <param name="build.id" value ="sbs_check"/>
-                    <reference refid="sbs.check.iterate.main.var" torefid="sbs.var" />
-                    <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
-                    <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
-                </antcall>
-              </sequential>
-            </for>
-          </then>
-          <else>
-          <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-            <param name="build.system" value="${sf.spec.build.system}" />
-            <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
-            <param name="build.id" value ="sbs_check"/>
-            <reference refid="sbs.check.main.var" torefid="sbs.var" />
-            <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
-            <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
-          </antcall>
-        </else>
-      </if> 
-    </target>
-
-    <target name="sf-create-public-PDK" depends="sf-prebuild,sf-run-sfl-licence-munging" >
-        <if>
-            <istrue value="${sf.spec.md5.enable}"/>
-            <then>
-                <echo message="INFO Creating MD5s"/>
-                <runtarget target="sf-run-evalid"/>
-            </then>
-        </if>
-        
-        <!-- Package up the binaries we built -->
-        <if>
-            <istrue value="${sf.spec.package.bin.enable}"/>
-            <then>
-                <echo message="INFO Packaging Binaries"/>
-                <runtarget target="sf-package-binary"/>
-
-                <echo message="INFO Validate Zip files"/>
-                <runtarget target="sf-package-validate"/>
-            </then>
-        </if>
-        <runtarget target="sf-merge-brag"/>
-        <runtarget target="sf-zip-logs"/>
-                
-        <if>
-            <istrue value="${sf.spec.publish.enable}" />
-            <then>
-                <echo message="Send links to Diamonds"/>
-                <runtarget target="sf-links-to-diamonds"/>
-                <echo message="Send BRAG status information to Diamonds"/>
-                <runtarget target="sf-brag-to-diamonds"/>
-                
-                <echo message="Publish log files and reports to ${sf.spec.publish.rootdir}"/>
-                <runtarget target="sf-publish"/>
-            </then>
-        </if>
-    </target>
-
-    <target name="sf-run-sfl-licence-munging" depends="sf-check-utilities-dir" if="sf-utilities-available">    
-        <echo message="Running SFL Licence Munging writing log to ${build.log.dir}"/>
-        <stopwatch name="munge" action="start"/>
-        <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/postbuild_sfl-licence_munging_results.log">
-          <arg value="${build.drive}/utilities/williamr/convert_to_eula.pl"/>
-        </exec>
-        <stopwatch name="munge" action="total"/>
-    </target>
-
-    <target name="sf-copy-rom-logs">
-        <property name="sf.rombuild.dir" value="${build.drive}/epoc32/rom/"/>
-        <!-- copy log files for each variant we have -->
-        <echo message="build.log.dir= ${build.log.dir}"/>
-        <echo message="sf.rombuild.dir= ${sf.rombuild.dir}"/>
-        <echo message="sf.spec.referenceroms.variant= ${sf.spec.referenceroms.variant}"/>
-        
-        <copy todir="${build.log.dir}" preservelastmodified="true" failonerror="false">
-            <fileset dir="${sf.rombuild.dir}/${sf.spec.referenceroms.variant}/"><include name="*ROMBUILD.LOG"/></fileset>
-        </copy>
-        
-        <copy todir="${build.log.dir}" preservelastmodified="true" failonerror="false">
-            <fileset dir="${sf.rombuild.dir}/${sf.spec.referenceroms.variant}/"><include name="*rom.oby"/></fileset>
-        </copy>
-    </target>
-
-    <target name="sf-build-roms">
-        <!-- find out if this is an arm build, if it is, then build roms -->
-        <propertyregex property="sf.is.arm.build"  override="true" input="${sf.spec.sbs.config}" regexp="(arm.*)" replace="true" casesensitive="false"/>
-    
-        <if><isset property="sf.is.arm.build"/> 
-        <then>
-            <mkdir dir="${roms.log.dir}"/>
-            <echo message="INFO Building Syborg MiniGUI stripped ROM"/>
-            <exec executable="cmd" dir="${build.drive}/epoc32/rom" failonerror="false">
-                <arg value="/c"/>
-                <arg value="buildrom syborg minigui-stripped"/>
-            </exec>
-            <if>
-                <!-- is iMaker rom building enabled? -->
-                <istrue value="${sf.spec.referenceroms.createimages.enable}" />
-                <then>
-                    <echo message="INFO Building iMaker configurations"/>
-                    <runtarget target="build-roms"/>
-                </then>
-            </if>
-        </then>
-        </if>        
-    </target>
-    
-</project>
+<?xml version="1.0" encoding="UTF-8"?>
+<project name="SF-POSTBUILD" xmlns:hlm="http://www.nokia.com/helium">
+    <target name="sf-postbuild" depends="sf-build-roms">
+        <stopwatch name="sf-postbuild"/>
+        <echo>[SF-POSTBUILD]</echo>
+        
+        <if><istrue value="${sf.relicense.exported.headers}"/>
+        <then>
+            <runtarget target="sf-run-sfl-licence-munging"/>
+        </then>
+        </if>
+        
+        <parallel>
+            <!-- TAG SOURCE CODE -->
+            <if>
+                <istrue value="${sf.spec.tagafterbuild.enable}" />
+                <then>
+                    <echo message="Apply tag to the source code used in this build"/>
+                    <runtarget target="sf-tag-hg-code"/>
+                </then>
+            </if>
+            
+            <!-- Create MD5s -->
+            <if>
+                <istrue value="${sf.spec.md5.enable}"/>
+                <then>
+                    <echo message="INFO Creating MD5s"/>
+                    <runtarget target="sf-run-evalid"/>
+                </then>
+            </if>
+            
+            <!-- Package up the binaries we built -->
+            <if>
+                <istrue value="${sf.spec.package.bin.enable}"/>
+                <then>
+                    <stopwatch name="sf-postbuild packaging binaries"/>
+                    <echo message="INFO Packaging Binaries"/>
+                    <runtarget target="sf-package-binary"/>
+    
+                    <echo message="INFO Validate Zip files"/>
+                    <runtarget target="sf-package-validate"/>
+                    <stopwatch name="sf-postbuild packaging binaries" action="elapsed"/>
+                </then>
+            </if>
+            
+            <!-- run build analysis tools -->
+            <runtarget target="sf-run-analysis"/>
+
+            <if>
+                <istrue value="${sf.spec.publish.enable}"/>
+                <then>
+                    <!-- Generate reports to compare this build to a previous one -->
+                    <runtarget target="sf-compare-to-baseline"/>
+                </then>
+            </if>
+        </parallel>
+        
+        <!-- Generate release_metadata entries for the md5 zips -->
+        <antcall target="sf-zip-content">
+            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name" value="md5-just-metadata" />
+        </antcall>
+ 
+        <!-- Launch smoketest -->
+        <if><istrue value="${sf.spec.test.sendpkg.enable}"/>
+            <then>
+                <runtarget target="sf-build-smoketestpkg"/>
+                <runtarget target="sf-send-testpkg"/>
+            </then>
+        </if>
+
+        <!-- Launch BC check -->
+        <if><istrue value="${sf.spec.bccheck.enable}"/>
+            <then>
+                <runtarget target="sf-bc-check"/>
+            </then>
+        </if>
+
+        <!-- Launch package tests -->
+        <if><istrue value="${sf.spec.package.test.enable}"/>
+            <then>
+                <runtarget target="sf-test-package"/>
+            </then>
+        </if>
+
+        <!-- copy log files linked to the generation of roms for REE -->
+        <runtarget target="sf-copy-rom-logs"/>
+
+        <runtarget target="sf-merge-brag"/>
+
+        <!-- Zip up all the logs -->
+        <runtarget target="sf-zip-logs"/>
+        
+        <if>
+            <istrue value="${sf.spec.publish.enable}" />
+            <then>
+                <echo message="Send links to Diamonds"/>
+                <runtarget target="sf-links-to-diamonds"/>
+                <echo message="Send BRAG status information to Diamonds"/>
+                <runtarget target="sf-brag-to-diamonds"/>
+                
+                <echo message="Publish log files and reports to ${sf.spec.publish.rootdir}"/>
+                <runtarget target="sf-publish"/>
+            </then>
+        </if>
+        <stopwatch name="sf-postbuild" action="elapsed"/>
+    </target>
+
+    <target name="sf-tag-hg-code">
+        <!-- To do the tagging, we need to know what tag to use, and who the author is (from hg's perspective) -->
+        <fail message="This target needs to have all the details specified, or to be run interactively so it can query the user">
+            <condition>
+                <and>
+                    <isset property="sf.hudson.executor.number"/>
+                    <not>
+                        <or>
+                            <isset property="sf.tagafterbuild.tag"/>
+                            <isset property="sf.hg.ui.username"/>
+                        </or>
+                    </not>
+                </and>
+            </condition>
+        </fail>
+
+        <!-- Ask the user, interactively, what tag to use -->
+        <input addproperty="sf.tagafterbuild.tag" message="Enter the tag to apply to the code (eg &quot;PDK_1.0.1&quot;):"/>
+        <fail message="No tag supplied">
+            <condition>
+                <length string="${sf.tagafterbuild.tag}" trim="true" length="0"/>
+            </condition>
+        </fail>
+
+        <!-- Now get the username sorted out -->
+        <exec executable="hg" outputproperty="sf.hg.showconfig.ui.username">
+            <arg value="showconfig"/>
+            <arg value="ui.username"/>
+        </exec>
+        <input addproperty="sf.hg.ui.username" message="Enter hg author credentials (eg &quot;Fred Bloggs &lt;fredb@example.org&gt;&quot;) default is" defaultvalue="${sf.hg.showconfig.ui.username}"/>
+        <fail message="No author supplied">
+            <condition>
+                <length string="${sf.hg.ui.username}" trim="true" length="0"/>
+            </condition>
+        </fail>
+
+        <fmpp sourceFile="${sf.common.config.dir}/templates/tag-hg-code.ant.xml.ftl"
+              outputFile="${temp.build.dir}/tag-hg-code.ant.xml">
+            <data expandProperties="yes">
+                ant: antProperties()
+                data: csv(${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}, {separator:','})
+            </data>
+        </fmpp>
+        <ant antfile="${temp.build.dir}/tag-hg-code.ant.xml"/>
+    </target>
+
+    <target name="sf-push-hg-tags">
+        <!-- To do the pushing, we need to have a set of credentials for the developer.symbian.org site -->
+        <fail message="This target needs to have loging credentials specified specified, or to be run interactively so it can query the user">
+            <condition>
+                <and>
+                    <isset property="sf.hudson.executor.number"/>
+                    <not>
+                        <or>
+                            <isset property="sf.symbian.account.username"/>
+                            <isset property="sf.symbian.account.password"/>
+                        </or>
+                    </not>
+                </and>
+            </condition>
+        </fail>
+
+        <input addproperty="sf.symbian.account.username" message="Enter symbian.org username (eg &quot;fredb&quot;)"/>
+        <fail message="No author supplied">
+            <condition>
+                <length string="${sf.hg.ui.username}" trim="true" length="0"/>
+            </condition>
+        </fail>
+
+        <input addproperty="sf.symbian.account.password" message="Enter symbian.org password (eg &quot;unguessable&quot;)">
+            <!-- Ant 1.8 supports secure here, which would be an improvement... -->
+            <handler type="default"/>
+        </input>
+        <fail message="No password supplied">
+            <condition>
+                <length string="${sf.hg.ui.password}" trim="true" length="0"/>
+            </condition>
+        </fail>
+
+        <if>
+            <not>
+                <available file="${build.drive}/tagging" type="dir"/>
+            </not>
+            <then>
+                <!-- No dir with tagged repos in - create them! -->
+                <runtarget target="sf-tag-hg-code"/>
+            </then>
+        </if>
+
+        <fmpp sourceFile="${sf.common.config.dir}/templates/push-hg-tags.ant.xml.ftl"
+              outputFile="${temp.build.dir}/push-hg-tags.ant.xml">
+            <data expandProperties="yes">
+                ant: antProperties()
+                data: csv(${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}, {separator:','})
+            </data>
+        </fmpp>
+        <ant antfile="${temp.build.dir}/push-hg-tags.ant.xml"/>
+    </target>
+
+    <target name="sf-run-evalid" >
+        <delete dir="${build.drive}/output/md5"/>
+        <mkdir  dir="${build.drive}/output/md5"/>
+
+        <parallel>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/include output/md5/epoc32_include.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/s60 output/md5/epoc32_s60.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/localisation output/md5/epoc32_localisation.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -x \.sym$ -x ^armv5/udeb -x ^armv5/urel -x ^winscw/udeb -x ^winscw/urel -g epoc32/release output/md5/epoc32_release.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -x \.sym$ -g epoc32/release/armv5/udeb output/md5/epoc32_release_armv5_udeb.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -x \.sym$ -g epoc32/release/armv5/urel output/md5/epoc32_release_armv5_urel.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -x \.sym$ -g epoc32/release/winscw/udeb output/md5/epoc32_release_winscw_udeb.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -x \.sym$ -g epoc32/release/winscw/urel output/md5/epoc32_release_winscw_urel.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/cshlpcmp_template output/md5/epoc32_cshlpcmp_template.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/data output/md5/epoc32_data.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/engdoc output/md5/epoc32_engdoc.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/engineeringtools output/md5/epoc32_engineeringtools.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/gcc output/md5/epoc32_gcc.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/gcc_mingw output/md5/epoc32_gcc_mingw.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/ksa output/md5/epoc32_ksa.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/rom output/md5/epoc32_rom.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/rombuild output/md5/epoc32_rombuild.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/sbs_config output/md5/epoc32_sbs_config.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/sdk_special output/md5/epoc32_sdk_special.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/stdapis output/md5/epoc32_stdapis.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/stubs output/md5/epoc32_stubs.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/tools output/md5/epoc32_tools.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/wins output/md5/epoc32_wins.md5"/>
+        </exec>
+        <exec executable="cmd" dir="${build.drive}/">
+            <arg value="/c"/>
+            <arg value="evalid -g epoc32/winscw output/md5/epoc32_winscw.md5"/>
+        </exec>
+        </parallel>
+        <!-- package MD5s directly into epoc32/relinfo location so that its usable out-of-the-box -->
+        <mkdir dir="${build.output.dir}/zips/release"/> <!-- Hack to prevent non-existing release dir -->
+        <zip destfile="${build.output.dir}/zips/release/build_md5.zip">
+            <zipfileset dir="${build.drive}/output/md5/" prefix="epoc32/relinfo"/>
+        </zip>
+    </target>    
+    
+    <target name="sf-package-binary" depends="sf-package-postbuild-rnd,sf-merge-manifest">
+        <!-- Warning: Reverting to using the He zipper will also revert to a single zip for the binaries:
+             would need to update the template and possibly the script that populates it -->
+        <!--antcall target="sf-zip-content">
+            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name" value="bin" />
+        </antcall-->
+        <parallel>
+            <sequential>
+                <if>
+                    <isset property="sf.sdk.header.list.file"/>
+                    <then>
+                        <property name="sf.epoc32.exclusions.file" value="${sf.sdk.header.list.file}"/>
+                    </then>
+                </if>
+                <property name="sf.epoc32.exclusions.file" value="nul:"/>
+                <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_epoc32.log">
+                    <arg value="a"/>
+                    <arg value="-t${sf.spec.package.zip.format}"/>
+                    <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/> <!-- rnd content taken from internal hg repos -->
+                    <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                    <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/> <!-- merged list of prebuilt content such as binaries_prebuilt -->
+                    <arg value="-x@${sf.epoc32.exclusions.file}"/>
+                    <arg value="-x!epoc32\gcc"/>
+                    <arg value="-x!epoc32\gcc_mingw"/>
+                    <arg value="-x!epoc32\tools"/>
+                    <arg value="-x!epoc32\data\buildinfo.txt"/>
+                    <!-- Feature database artifacts released as part of the tools zip -->
+                    <arg value="-x!epoc32\data\config\features.dat"/>
+                    <arg value="-x!epoc32\include\featureuids.h"/>
+                    <arg value="-x!epoc32\rom\include\feature.iby"/>
+                    <arg value="-x!epoc32\rom\include\featuredatabase.xml"/>
+                    <arg value="-x!epoc32\data\media"/> <!-- Files created when emulator is used to create comms database - not worth releasing-->
+                    <arg value="-x!epoc32\build"/>
+                    <arg value="-x!epoc32\release\armv5"/>
+                    <arg value="-x!epoc32\release\winscw"/>
+                    <arg value="-xr!*.sym"/>
+                    <arg value="${build.drive}/output/zips/release/binaries_epoc.zip"/>
+                    <arg value="epoc32\"/>
+                </exec>
+            </sequential>
+            
+            <if>
+                <isset property="sf.sdk.header.list.file"/>
+                <then>
+                    <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_sdk.log">
+                        <arg value="a"/>
+                        <arg value="-t${sf.spec.package.zip.format}"/>
+                        <arg value="-i@${sf.sdk.header.list.file}"/>
+                        <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                        <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                        <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                        <arg value="-x!epoc32/include/featureuids.h"/> <!-- This needs to come from the tools zip instead -->
+                        <arg value="${build.drive}/output/zips/release/binaries_epoc_sdk.zip"/>
+                    </exec>
+                    <!-- Check that all the files we want in the SDK are zipped -->
+                    <antcall target="sf-log-to-brag">
+                        <param name="sf.brag.id" value="SDK"/>
+                        <param name="sf.brag.log" value="${build.log.dir}/zip_${build.id}_binaries_sdk.log"/>
+                        <param name="sf.brag.phase" value="Postbuild"/>
+                        <param name="sf.brag.step" value="Package SDK"/>
+                    </antcall>
+                    <!-- Generate release_metadata entries for the SDK zip -->
+                    <antcall target="sf-zip-content">
+                        <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+                        <param name="zip.target.name" value="bin-sdk-just-metadata" />
+                    </antcall>
+                </then>
+            </if>
+            
+            <!-- WinsCW binaries, by udeb/urel/lib -->
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_udeb.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="-xr!*.sym"/>
+                <arg value="-xr!*.lib"/>
+                <arg value="${build.drive}/output/zips/release/binaries_winscw_udeb.zip"/>
+                <arg value="epoc32\release\winscw\udeb"/>
+            </exec>
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_urel.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="-xr!*.sym"/>
+                <arg value="-xr!*.lib"/>
+                <arg value="${build.drive}/output/zips/release/binaries_winscw_urel.zip"/>
+                <arg value="epoc32\release\winscw\urel"/>
+            </exec>
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_winscw_lib.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-ir!epoc32/release/winscw/*.lib"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="${build.drive}/output/zips/release/binaries_winscw_lib.zip"/>
+            </exec>
+            
+            <!-- ARMv5 binaries, by udeb/urel/lib -->
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_udeb.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="-xr!*.sym"/>
+                <arg value="${build.drive}/output/zips/release/binaries_armv5_udeb.zip"/>
+                <arg value="epoc32\release\armv5\udeb"/>
+            </exec>
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_urel.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="-xr!*.sym"/>
+                <arg value="${build.drive}/output/zips/release/binaries_armv5_urel.zip"/>
+                <arg value="epoc32\release\armv5\urel"/>
+            </exec>
+            <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_binaries_armv5_lib.log">
+                <arg value="a"/>
+                <arg value="-t${sf.spec.package.zip.format}"/>
+                <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+                <arg value="-x@output/temp_build_files/manifest_excludelist.txt"/>
+                <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+                <arg value="-xr!*.sym"/>
+                <arg value="-ir!epoc32/release/armv5/_*.bin"/> <!-- include bootloaders in common lib zipfile -->
+                <arg value="${build.drive}/output/zips/release/binaries_armv5_lib.zip"/>
+                <arg value="epoc32\release\armv5\lib"/>
+            </exec>
+        </parallel>
+        
+        <runtarget target="sf-package-tools"/>
+        <runtarget target="sf-package-prebuilt"/>
+        
+        <!-- Generate release_metadata entries for the above zips -->
+        <antcall target="sf-zip-content">
+            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name" value="bin-just-metadata" />
+        </antcall>
+    </target>
+
+    <target name="sf-package-postbuild-rnd" >
+        <antcall target="sf-zip-content">
+            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name" value="rnd-postbuild" />
+        </antcall>
+    </target>
+
+    <target name="sf-package-tools" depends="sf-merge-manifest">
+        <exec executable="7za" dir="${build.drive}/" output="${build.log.dir}/zip_${build.id}_tools_epoc32.log">
+            <arg value="a"/>
+            <arg value="-t${sf.spec.package.zip.format}"/>
+            <arg value="-x@${build.log.dir}/rnd_excludefile.txt"/>
+            <arg value="-x@/output/temp_build_files/manifest_excludelist.txt"/>
+            <arg value="-x@${sf.spec.prebuilt.excludelist}"/>
+            <arg value="${build.drive}/output/zips/release/tools_epoc.zip"/>
+            <arg value="epoc32/tools"/>
+            <arg value="epoc32/gcc"/>
+            <arg value="epoc32/gcc_mingw"/>
+            <arg value="epoc32/data/buildinfo.txt"/>
+            <arg value="epoc32/data/config/features.dat"/>
+            <arg value="epoc32/include/featureuids.h"/>
+            <arg value="epoc32/rom/include/feature.iby"/>
+            <arg value="epoc32/rom/include/featuredatabase.xml"/>
+        </exec>
+        <antcall target="sf-zip-content">
+            <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name" value="tools" />
+        </antcall>
+    </target>
+    
+    <target name="sf-package-validate">
+        <exec executable="7z" dir="${build.drive}/output/zips" failonerror="false" output="${build.drive}/output/zips/validate.log">
+            <arg value="t"/>
+            <arg value="*.zip"/>
+        </exec>  
+        <exec executable="7z" dir="${build.drive}/output/zips/release" failonerror="false" output="${build.drive}/output/zips/release/validate.log">
+            <arg value="t"/>
+            <arg value="*.zip"/>
+        </exec>  
+    </target>
+
+    <!-- merge manifests for prebuilt stuff delivered at the start of build process -->
+    <target name="sf-merge-manifest">
+      <echo message="INFO Build drive is ${build.drive} "/>
+      <concat destfile="${build.drive}\output\temp_build_files\manifest_excludelist.txt">
+        <fileset dir="${build.drive}" includes="*manifest*" excludes="manifest_excludelist.txt"/>
+      </concat>
+       
+       <!-- touch file to update/create it in the event that there are no manifest* files available 
+            as 7z will not be happy being given a non-existent file -->  
+      <touch file="${build.drive}\output\temp_build_files\manifest_excludelist.txt"/>
+    </target>
+
+    <target name="sf-package-prebuilt" depends="sf-merge-manifest">
+    <!-- for each prebuilt manifest* file, repackage -->  
+
+      <for param="manifest">
+        <path>
+          <fileset dir="${build.drive}\">
+            <include name="manifest*.txt"/>
+            <exclude name="manifest*restricted*.txt"/> <!-- dont repack restricted content such as testconfigfileparser -->
+          </fileset>
+        </path>
+        <!-- strip manifest_ and .txt extension for matched file -->
+        <sequential>
+        <propertyregex property="manifest.shortname" override="true" input="@{manifest}" regexp="manifest_(\S+)(.txt)" select="\1" global="true"  casesensitive="false"/>
+        <propertyregex property="manifest.fullname"  override="true" input="@{manifest}" regexp="(.*)" select="\1" global="true"  casesensitive="false"/>
+        <propertyregex property="manifest.pkgname"   override="true" input="@{manifest}" regexp="manifest_binaries_(\S+)(.txt)" select="\1" global="true"  casesensitive="false"/>
+
+        <echo message="INFO Packaging ${manifest.fullname} into ${manifest.shortname}.zip"/>
+
+        <exec executable="7za" dir="${build.drive}/" output="${build.drive}/zip_${manifest.shortname}.log">
+            <arg value="a"/>
+            <arg value="-t${sf.spec.package.zip.format}"/>
+            <arg value="-i@${manifest.fullname}"/>
+            <arg value="${build.drive}/output/zips/release/${manifest.shortname}.zip"/> 
+        </exec>
+
+        <!-- merge release metadata -->
+        <antcall target="sf-zip-content">
+            <param name="zip.config.file"  value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+            <param name="zip.target.name"  value="bin-${manifest.pkgname}-metadata" />
+            <param name="sf.spec.job.name" value="${manifest.pkgname}" />
+        </antcall>
+        </sequential>  
+      </for>
+
+    </target>
+    <!-- runs analysis of missing bins and source -->
+    <target name="sf-run-analysis">
+        <stopwatch name="sf-run-analysis"/>
+        <mkdir dir="${build.log.dir}/analysis"/>
+        <parallel>
+          <runtarget target="sf-run-analysis-ant"/>
+          <runtarget target="sf-run-analysis-raptor"/>
+          <runtarget target="sf-run-analysis-yarp"/>
+          <runtarget target="sf-run-analysis-whatlog-summary"/>
+          <runtarget target="sf-run-analysis-missing-files"/>
+        </parallel>
+        <if>
+          <istrue value="${sf.spec.publish.enable}"/>
+            <then>
+            <runtarget target="sf-run-analysis-diamonds"/>
+            </then>
+        </if>
+        <stopwatch name="sf-run-analysis" action="elapsed"/>
+    </target>
+
+    <target name="sf-run-analysis-ant">    
+        <echo message="Running source analysis of ANT output"/>
+        <exec executable="perl" dir="${build.log.dir}" failonerror="false" output="${build.log.dir}/analysis/${build.id}_scan_ant.log">
+            <arg value="${sf.common.config.dir}/tools/analysis/scan_antlogs.pl"/>
+            <arg value="*ant*"/>
+            <arg value="*stderr*"/>  <!-- helium 7 splits output into stderr logs, so use them also -->
+            <arg value="*sbs_error*"/> 
+        </exec>
+    </target>
+
+    <target name="sf-run-analysis-raptor">            
+      <!-- Cook the processed raptor logs to produce something in the right format for the BRAG system -->
+      <mkdir dir="${build.log.dir}/summary/"/>
+      <!-- exec executable="perl" output="${build.log.dir}/summary/sbs_BRAG.xml" logError="yes" failonerror="false">
+        <arg value="${sf.common.config.dir}/tools/brag/sbsToBRAG.pl"/>
+        <arg value="${build.log.dir}/analysis/*_compile_preprocessed.log"/>
+      </exec -->
+      
+      <echo message="Running UH parser on *_compile.log files"/>
+      <apply executable="perl" dir="${build.drive}/utilities/uh_parser" failonerror="false" output="${build.log.dir}/analysis/${build.id}_raptorparse.log" parallel="true">
+        <arg value="uh.pl"/>
+        <arg value="-m"/>
+        <arg value="--basedir=${build.log.dir}"/>
+        <fileset dir="${build.log.dir}">
+          <include name="*_compile.log"/>
+          <include name="*_export.log"/>  <!-- for explicit export step -->
+          <exclude name="*build_check_compile.log"/>
+        </fileset>
+      </apply>
+          
+      <!-- Now iterate through the generated TSVs to sort them and remove duplicates -->
+      <for param="tsv">
+        <path>
+          <fileset dir="${build.log.dir}">
+            <include name="releaseables/**/*.tsv"/>
+          </fileset>
+        </path>
+        <sequential>
+          <exec executable="perl" input="@{tsv}" output="@{tsv}">
+            <arg value="${sf.common.config.dir}/tools/sortUnique.pl"/>
+          </exec>
+        </sequential>
+      </for>
+
+      <!-- Cook the raptor analysis further to produce something in the right format for the BRAG system -->
+      <exec executable="perl" output="${build.log.dir}/summary/Uh_BRAG.xml" logError="yes">
+        <arg value="${sf.common.config.dir}/tools/brag/uh2brag.pl"/>
+        <arg value="--index"/>
+        <arg value="${build.log.dir}/html/index.html"/>
+      </exec>
+      <!-- And copy the XSL so the output can be transformed by a browser -->
+      <copy file="${sf.common.config.dir}/tools/brag/brag.xsl" toDir="${build.log.dir}/summary/"/>
+    </target>
+
+    <target name="sf-run-analysis-yarp">
+      <echo message="Running yarp over *_compile.log files"/>
+      <for param="logfile">
+        <path>
+          <fileset dir="${build.log.dir}">
+            <include name="*_compile.log"/>
+            <exclude name="*build_check_compile.log"/>
+          </fileset>
+        </path>
+        <sequential>
+          <propertyregex override="yes" property="yarpfile"  input="@{logfile}" regexp=".*[\\|\/](.*)_compile\.log" replace="\1_yarp.csv"/>
+          <propertyregex override="yes" property="yarpfile_short"  input="${yarpfile}" regexp="[^_]*_[^_]*_[^_]*_(.+)_[^_]*_yarp\.csv" replace="YARP_\1"/>
+          <echo message="Yarping @{logfile}..."/>
+          <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/analysis/${yarpfile}.log" append="true">
+            <arg value="${sf.common.config.dir}/tools/analysis/yarp.pl"/>
+            <arg value="@{logfile}"/>
+            <arg value="${build.log.dir}/analysis/${yarpfile}"/>
+          </exec>
+          <exec executable="cmd" output="${build.drive}/output/logs/analysis/tmp_yarp_files.csv" append="true">
+            <arg value="/c"/>
+            <arg value="echo"/>
+            <arg value="${yarpfile_short},${sf.spec.publish.networkdrive}\${sf.spec.job.name}\builds\${sf.spec.job.codeline}\${build.id}\logs\analysis\${yarpfile},${build.drive}\output\logs\analysis\${yarpfile}"/>
+          </exec>
+        </sequential>
+      </for>
+      
+      <!-- Cook the yarp analysis further to produce something in the right format for the BRAG system -->
+      <mkdir dir="${build.log.dir}/summary/"/>
+      <!-- exec executable="perl" output="${build.log.dir}/summary/Yarp_BRAG.xml" logError="yes">
+        <arg value="${sf.common.config.dir}/tools/brag/yarpToBRAG.pl"/>
+        <arg value="${build.log.dir}/analysis/*_yarp.csv"/>
+      </exec -->
+      
+      <exec executable="perl" dir="${build.drive}" failonerror="false" outputproperty="sf.job.totalyarperrors">
+        <arg value="${sf.common.config.dir}/tools/analysis/parse_yarp_files.pl"/>
+        <arg value="${build.drive}/output/logs/analysis/tmp_yarp_files.csv"/>
+      </exec>
+      <echo message="Total yarp errors: ${sf.job.totalyarperrors}"/>
+    </target>
+    
+    <target name="sf-run-analysis-whatlog-summary" >
+        <sequential>
+          <parallel>
+            <runtarget target="sf-run-analysis-list"/>
+            <runtarget target="sf-run-analysis-whatlog"/>
+          </parallel>
+          <runtarget target="sf-run-analysis-whatlog-merge" />
+          <parallel>
+            <runtarget target="sf-run-analysis-whatlog-package"/>
+            <runtarget target="sf-run-analysis-whatlog-collisons"/>
+          </parallel>
+        </sequential>
+    </target>
+    
+    <target name="sf-run-analysis-list">    
+        <echo message="Running list analysis"/>
+        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_list_results.log">
+            <arg value="${sf.common.config.dir}/tools/analysis/parselistdirs.pl"/>
+            <arg value="..\"/>
+        </exec>
+    </target>
+
+    <target name="sf-run-analysis-whatlog">    
+        <echo message="Running whatlog analysis"/>
+        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_what_results.csv">
+            <arg value="${sf.common.config.dir}/tools/analysis/parsewhatlog.pl"/>
+            <arg value="..\"/>
+        </exec>
+    </target>
+
+    <target name="sf-run-analysis-whatlog-merge" >        
+        <echo message="Running summary analysis"/>
+        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_summary.log">
+            <arg value="${sf.common.config.dir}/tools/analysis/merge_csv.pl"/>
+            <arg value="${build.id}_what_results.csv"/>
+            <arg value="${build.id}_list_results.log"/>
+            <arg value="${build.drive}/output/zips/release/binaries_epoc_additional.zip"/>
+        </exec>
+    </target>
+    
+    <target name="sf-run-analysis-whatlog-package" >        
+        <exec executable="perl" dir="${build.log.dir}/analysis" failonerror="false" output="${build.log.dir}/analysis/${build.id}_analysecomponents.log">
+            <arg value="${sf.common.config.dir}/tools/analysis/analyse_components.pl"/>
+            <arg value="${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
+            <arg value="${build.id}_what_results.csv_results.csv"/>
+            <arg value="${sf.project.location}/sysdefs/system_model_os.xml"/>
+            <arg value="${sf.project.location}/sysdefs/system_model_s60.xml"/>
+        </exec>
+    </target>
+    
+    <target name="sf-run-analysis-whatlog-collisons" >        
+        <echo message="Running collision analysis"/>
+        <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/analysis/${build.id}_collisions.log">
+            <arg value="${sf.common.config.dir}/tools/analysis/find_collisions.pl"/>
+            <arg value="${build.log.dir}/analysis/${build.id}_what_results.csv"/>
+        </exec>
+    </target>
+    
+    <target name="sf-run-analysis-diamonds">
+      <if>
+        <istrue value="${sf.spec.publish.enable}"/>
+        <then>
+          <echo>[SF-RUN-ANALYSIS-DIAMONDS]</echo>
+          <echo message="Translate \output\logs\html\index.html into a Diamonds file"/>
+          <exec executable="perl" dir="${build.drive}">
+            <arg value="${sf.common.config.dir}/tools/uh2diamonds.pl"/>
+          </exec>
+          <echo message="Send ${build.log.dir}/diamonds_uh.xml to Diamonds"/>
+          <exec executable="python">
+            <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
+            <arg value="-u"/>
+            <arg value="http://${diamonds.host}${diamonds.build.id}"/>
+            <arg value="-f"/>
+            <arg value="${build.log.dir}/diamonds_uh.xml"/>
+          </exec>
+        </then>
+      </if>
+    </target>
+    
+    <target name="sf-links-to-diamonds">
+      <fmpp sourceFile="${sf.common.config.dir}/diamonds/linksForDiamonds.xml.ftl" outputFile="${build.log.dir}/linksForDiamonds.xml">
+        <data expandProperties="yes">
+          ant: antProperties()
+        </data>
+      </fmpp>
+      <!-- Send the data to the server -->
+      <exec executable="python">
+        <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
+        <arg value="-u"/>
+        <arg value="http://${diamonds.host}${diamonds.build.id}"/>
+        <arg value="-f"/>
+        <arg value="${build.log.dir}/linksForDiamonds.xml"/>
+      </exec>
+      
+      <echo message="report&#x0009;Summary,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/summary/_brag.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      <echo message="report&#x0009;Raptor Build Summary,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/html/index.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      <echo message="report&#x0009;Build BOM,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/build_BOM.zip,file${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      <echo message="report&#x0009;Build Logs,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/build_logs.zip,file${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      <if><and><equals arg1="${sf.spec.smoketest.enable}" arg2="true"/><equals arg1="${sf.spec.ats.version}" arg2="ats3"/></and><then>
+        <echo message="report&#x0009;Smoke Test Report,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/ATS3Report.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      </then></if>
+      <if><and><equals arg1="${sf.spec.smoketest.enable}" arg2="true"/><equals arg1="${sf.spec.ats.version}" arg2="ats4"/></and><then>
+        <echo message="report&#x0009;Smoke Test Report,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/simplelogger/testreport.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      </then></if>
+      <if><and><equals arg1="${sf.spec.bccheck.enable}" arg2="true"/><equals arg1="${sf.spec.bccheck.enable.ha}" arg2="true"/></and><then>
+        <echo message="report&#x0009;Binary Compatibility Report (Headerfiles),http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/BC/headers_report.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      </then></if>
+      <if><and><equals arg1="${sf.spec.bccheck.enable}" arg2="true"/><equals arg1="${sf.spec.bccheck.enable.la}" arg2="true"/></and><then>
+        <echo message="report&#x0009;Binary Compatibility Report (Libraries),http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/BC/libraries_report.xml,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      </then></if>
+      <if><equals arg1="${sf.spec.bccheck.enable.dynamic}" arg2="true"/><then>
+        <echo message="report&#x0009;Dynamic BC Test Reports,http://cdn.symbian.org/SF_builds/${sf.spec.job.name}/builds/${sf.spec.job.codeline}/${build.id}/ats_reports/index.html,report${line.separator}" file="${build.log.dir}/bitinfo.txt" append="true"/>
+      </then></if>
+    </target>
+
+    <target name="sf-merge-brag">
+        <!-- Merge all our bits of XML together -->
+        <exec executable="perl" output="${build.log.dir}/summary/_BRAG.xml" logError="true">
+            <arg value="${sf.common.config.dir}/tools/mergeXML.pl"/>
+            <arg value="--xsl=brag.xsl"/>
+            <arg value="--merge=buildStatus,phase(name),step(name),failures(level)"/>
+            <arg value="${build.log.dir}/summary/*?_BRAG.xml"/>
+        </exec>
+    </target>
+
+    <target name="sf-brag-to-diamonds">
+        <!-- Run XSL transform to create file to send to diamonds -->
+        <java jar="${sf.common.config.dir}/sysdefdowngrade/xalan-j_2_7_1/xalan.jar" fork="true">
+            <arg value="-IN"/>
+            <arg value="${build.log.dir}/summary/_BRAG.xml"/>
+            <arg value="-XSL"/>
+            <arg value="${sf.common.config.dir}/tools/brag/bragForDiamonds.xsl"/>
+            <arg value="-OUT"/>
+            <arg value="${build.log.dir}/diamonds-status.xml"/>
+        </java>
+        <if>
+            <istrue value="${sf.spec.publish.enable}"/>
+            <then>
+                <!-- Make sure that the summary directory is available to display the BRAG link -->
+                <mkdir  dir="${publish.dir}/summary/"/>
+                <copy todir="${publish.dir}/summary/" preservelastmodified="true" failonerror="false">
+                   <fileset dir="${build.log.dir}/summary/"><include name="*.*"/></fileset>
+                </copy>
+
+                <!-- Try to obtain the diamonds ID for this build -->
+                <if>
+                    <not><isset property="diamonds.build.id"/></not>
+                    <then>
+                        <property file="${build.log.dir}/diamonds_build_id.properties"/> <!-- This will fail silently -->
+                    </then>
+                </if>
+                <if>
+                    <isset property="diamonds.build.id"/>
+                    <then>
+                        <!-- Send the data to the server -->
+                        <exec executable="python">
+                            <arg value="${sf.common.config.dir}/tools/brag/send_xml_to_diamonds.py"/>
+                            <arg value="-u"/>
+                            <arg value="http://${diamonds.host}${diamonds.build.id}"/>
+                            <arg value="-f"/>
+                            <arg value="${build.log.dir}/diamonds-status.xml"/>
+                        </exec>
+                    </then>
+                    <else>
+                        <echo message="diamonds.build.id is not known - unable to push any build specific information to diamonds server"/>
+                    </else>
+                </if>
+            </then>
+        </if>
+    </target>
+
+    <target name="sf-check-utilities-dir">
+        <available property="sf-utilities-available" file="${build.drive}/utilities" type="dir"/>
+    </target>
+
+    <target name="sf-compare-to-baseline" depends="sf-check-utilities-dir" if="sf-utilities-available">
+        <property name="sf.releasenotes.wiki.txt" value="${build.log.dir}/releaseNotes.wiki.txt"/>
+        <delete file="${sf.releasenotes.wiki.txt}"/>
+        <!-- FCL Usage and Changesets -->
+        <exec executable="perl" dir="${build.drive}" output="${sf.releasenotes.wiki.txt}">
+            <arg value="-I"/>
+            <arg value="${sf.common.config.dir}/tools/lib"/>
+            <arg value="${build.drive}/utilities/releaseAutomation/releaseNotes.pl"/>
+            <arg value="--sources=${build.log.dir}/BOM/sources.csv"/>
+            <arg value="--baseline=${sf.previous.pdk.tag}"/>
+        </exec>
+        <!-- Package Comparison and FCL Usage -->
+        <exec executable="perl" dir="${sf.spec.sourcesync.sourcespecdir}" output="${sf.releasenotes.wiki.txt}" append="true">
+            <arg value="${build.drive}/utilities/releaseAutomation/packageComparison.pl"/>
+            <arg value="--sources=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
+            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model.xml"/>
+            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model_os.xml"/>
+            <arg value="--sysdef=${sf.spec.sourcesync.sourcespecdir}/sysdefs/system_model_s60.xml"/>
+            <arg value="--baseline=${sf.previous.pdk.tag}"/>
+        </exec>
+        <!-- Mercurial comparison -->
+        <echo file="${sf.releasenotes.wiki.txt}" append="true">== Mercurial Comparison ==${line.separator}${line.separator}</echo>
+        <if>
+            <isset property="sf.previous.pdk.tag"/>
+            <then>
+                <echo file="${sf.releasenotes.wiki.txt}" append="true">The Mercurial changes from Nokia were delivered as a bulk update based on '''XXXXXXXXXXXXXXXXXXXXXX'''.${line.separator}${line.separator}List of the Mercurial changes (files added/removed/modified) between ${sf.previous.pdk.tag} and PDK '''XXXXX''' - [[Media:XXXX.txt]].${line.separator}${line.separator}A short study of the results concentrating on the added and removed files has identified these significant package changes:${line.separator}${line.separator}</echo>
+                <if>
+                    <istrue value="${sf.spec.sourcesync.archive}"/>
+                    <then>
+                        <echo file="${sf.releasenotes.wiki.txt}" append="true">'''Information cannot be derived as source was synced with archive option'''"${line.separator}${line.separator}</echo>
+                    </then>
+                    <else>
+                        <exec executable="perl" dir="${build.drive}/" output="${sf.releasenotes.wiki.txt}" append="true">
+                            <arg value="${build.drive}/utilities/releaseAutomation/mercurialComparison.pl"/>
+                            <arg value="${build.log.dir}/BOM/build-info.xml"/>
+                            <arg value="${sf.previous.pdk.tag}"/>
+                            <arg value="${build.log.dir}/mercurialComparison.tsv"/>
+                        </exec>
+                    </else>
+                </if>
+            </then>
+            <else>
+                <echo file="${sf.releasenotes.wiki.txt}" append="true">'''Information cannot be provided as the tag for the previous PDK was not provided to the build'''"${line.separator}${line.separator}</echo>
+            </else>
+        </if>
+        
+        <!-- Code churn -->
+        <!-- TODO? -->
+        <fixcrlf file="${sf.releasenotes.wiki.txt}"/>
+    </target>
+
+    <!-- package all logs into zipfile for publishing -->
+    <target name="sf-zip-logs" >
+        <!-- Moved from generate-layers -->
+        <copy overwrite="true" file="${build.drive}/output/build/canonical_system_definition_${sf.spec.sysdef.configurations.list}.xml" todir="${build.log.dir}/BOM/"/>
+        <if>
+            <istrue value="${sf.spec.logs.zip.enable}"/>
+            <then>
+                <mkdir dir="${build.output.dir}/zips/release"/> <!-- workaround for when there's no other releaseables, just the logs -->
+                <zip destfile="${build.output.dir}/zips/release/build_logs.zip" basedir="${build.drive}"> 
+                    <include name="output/logs/**"/>
+                    <exclude name="output/logs/BC/**"/>
+                    <exclude name="output/logs/BOM/**"/>
+                    <exclude name="output/logs/deliverables/**"/>
+                    <exclude name="output/logs/releaseables/**"/>
+                </zip>
+                <!-- workaround for the time when when 'sf-run-analysis-raptor' has not been run -->
+                <mkdir dir="${build.drive}/output/logs/releaseables"/>
+                <if>
+                    <available file="${build.drive}/output/logs/package_definitions" type="dir"/>
+                    <then>
+                        <zip destfile="${build.output.dir}/zips/release/build_BOM.zip">
+                            <zipfileset dir="${build.drive}/output/logs/BOM" prefix="build_info/logs/BOM"/>
+                            <zipfileset dir="${build.drive}/output/logs/releaseables" prefix="build_info/logs/releaseables"/>
+                            <zipfileset dir="${build.drive}/output/logs" prefix="build_info/logs/BOM">
+                                <include name="envinfo.txt"/>
+                            </zipfileset>
+                            <zipfileset dir="${build.drive}/output/logs/package_definitions" prefix="build_info/package_definitions"/>
+                        </zip>
+                    </then>
+                    <else>
+                        <zip destfile="${build.output.dir}/zips/release/build_BOM.zip">
+                            <zipfileset dir="${build.drive}/output/logs/BOM" prefix="build_info/logs/BOM"/>
+                            <zipfileset dir="${build.drive}/output/logs/releaseables" prefix="build_info/logs/releaseables"/>
+                            <zipfileset dir="${build.drive}/output/logs" prefix="build_info/logs/BOM">
+                                <include name="envinfo.txt"/>
+                            </zipfileset>
+                        </zip>
+                    </else>
+                </if>
+                <antcall target="sf-zip-content">
+                    <param name="zip.config.file" value="${temp.build.dir}/zip.cfg.xml.ftl"/>
+                    <param name="zip.target.name" value="info-just-metadata" />
+                </antcall>
+            </then>
+        </if>
+     </target>
+    
+    <target name="sf-publish" depends="prep-publish">
+        <copy todir="${publish.dir}" preservelastmodified="true" failonerror="false">
+           <fileset dir="${build.output.dir}/zips/release/"><include name="build_*.zip"/></fileset>
+        </copy>
+        <mkdir dir="${publish.dir}/html"/>
+        <copy todir="${publish.dir}/html" preservelastmodified="true" failonerror="false">
+           <fileset dir="${build.log.dir}/html"><include name="*.html"/></fileset>
+        </copy>
+        <mkdir dir="${publish.dir}/BC"/>
+        <copy todir="${publish.dir}/BC" preservelastmodified="true" failonerror="false">
+           <fileset dir="${build.log.dir}/BC/">
+               <include name="BBCResults.xsl"/>
+               <include name="headers_report.xml"/>
+               <include name="libraries_report.xml"/>
+           </fileset>
+        </copy>
+        <mkdir dir="${publish.dir}/ats_reports"/>
+        <copy file="${sf.common.config.dir}/tools/ats/report_dummy.html" tofile="${publish.dir}/ats_reports/index.html" failonerror="false"/>
+    </target>
+
+    <!-- TODO: Make this work for package builds once we have sysmodel story worked out -->
+    <target name="sf-run-analysis-missing-files" if="sf.spec.checkbuild">
+        <runtarget target="sf-check-missing-os-files"/>
+    </target>
+    
+    <target name="sf-check-missing-os-files" depends="sf-compile-options">
+        <hlm:argSet id="sbs.check.tools.var">
+            <hlm:arg name="config" value="${sf.spec.sbs.tools.config}" />
+            <hlm:arg name="run-check" value="true" />
+        </hlm:argSet>
+     
+        <hlm:argSet id="sbs.check.main.var">
+            <hlm:arg name="config" value="${sf.spec.sbs.config}" />
+            <hlm:arg name="run-check" value="true" />
+        </hlm:argSet>     
+        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+            <param name="build.system" value="${sf.spec.build.system}" />
+            <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
+            <param name="build.id" value ="sbs_check"/>
+            <reference refid="sbs.check.tools.var" torefid="sbs.var" />
+            <reference refid="sbs.toolsbuild.options" torefid="sbs.make.options" />
+            <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
+        </antcall> 
+        <if><istrue value="${sf.os.compile.iterate}"/>
+          <then>
+            <for list="${sf.spec.sbs.config}" delimiter="," param="sf.spec.check.splitconfig">
+              <sequential>
+                <echo message="INFO [Iterative check] @{sf.spec.check.splitconfig}"/>
+                <hlm:argSet id="sbs.check.iterate.main.var">
+                    <hlm:arg name="config" value="@{sf.spec.check.splitconfig}" />
+                    <hlm:arg name="run-check" value="true" />
+                </hlm:argSet>     
+  
+                <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+                    <param name="build.system" value="${sf.spec.build.system}" />
+                    <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
+                    <param name="build.id" value ="sbs_check"/>
+                    <reference refid="sbs.check.iterate.main.var" torefid="sbs.var" />
+                    <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
+                    <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
+                </antcall>
+              </sequential>
+            </for>
+          </then>
+          <else>
+          <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+            <param name="build.system" value="${sf.spec.build.system}" />
+            <param name="sysdef.configurations.list" value="${sf.spec.os.sysdef.clean.configurations.list}" />
+            <param name="build.id" value ="sbs_check"/>
+            <reference refid="sbs.check.main.var" torefid="sbs.var" />
+            <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
+            <reference refid="sf.spec.os.system.definition.files" torefid="system.definition.files" />
+          </antcall>
+        </else>
+      </if> 
+    </target>
+
+    <target name="sf-create-public-PDK" depends="sf-prebuild,sf-run-sfl-licence-munging" >
+        <if>
+            <istrue value="${sf.spec.md5.enable}"/>
+            <then>
+                <echo message="INFO Creating MD5s"/>
+                <runtarget target="sf-run-evalid"/>
+            </then>
+        </if>
+        
+        <!-- Package up the binaries we built -->
+        <if>
+            <istrue value="${sf.spec.package.bin.enable}"/>
+            <then>
+                <echo message="INFO Packaging Binaries"/>
+                <runtarget target="sf-package-binary"/>
+
+                <echo message="INFO Validate Zip files"/>
+                <runtarget target="sf-package-validate"/>
+            </then>
+        </if>
+        <runtarget target="sf-merge-brag"/>
+        <runtarget target="sf-zip-logs"/>
+                
+        <if>
+            <istrue value="${sf.spec.publish.enable}" />
+            <then>
+                <echo message="Send links to Diamonds"/>
+                <runtarget target="sf-links-to-diamonds"/>
+                <echo message="Send BRAG status information to Diamonds"/>
+                <runtarget target="sf-brag-to-diamonds"/>
+                
+                <echo message="Publish log files and reports to ${sf.spec.publish.rootdir}"/>
+                <runtarget target="sf-publish"/>
+            </then>
+        </if>
+    </target>
+
+    <target name="sf-run-sfl-licence-munging" depends="sf-check-utilities-dir" if="sf-utilities-available">    
+        <echo message="Running SFL Licence Munging writing log to ${build.log.dir}"/>
+        <stopwatch name="munge" action="start"/>
+        <exec executable="perl" dir="${build.drive}" failonerror="false" output="${build.log.dir}/postbuild_sfl-licence_munging_results.log">
+          <arg value="${build.drive}/utilities/williamr/convert_to_eula.pl"/>
+        </exec>
+        <stopwatch name="munge" action="total"/>
+    </target>
+
+    <target name="sf-copy-rom-logs">
+        <property name="sf.rombuild.dir" value="${build.drive}/epoc32/rom/"/>
+        <!-- copy log files for each variant we have -->
+        <echo message="build.log.dir= ${build.log.dir}"/>
+        <echo message="sf.rombuild.dir= ${sf.rombuild.dir}"/>
+        <echo message="sf.spec.referenceroms.variant= ${sf.spec.referenceroms.variant}"/>
+        
+        <copy todir="${build.log.dir}" preservelastmodified="true" failonerror="false">
+            <fileset dir="${sf.rombuild.dir}/${sf.spec.referenceroms.variant}/"><include name="*ROMBUILD.LOG"/></fileset>
+        </copy>
+        
+        <copy todir="${build.log.dir}" preservelastmodified="true" failonerror="false">
+            <fileset dir="${sf.rombuild.dir}/${sf.spec.referenceroms.variant}/"><include name="*rom.oby"/></fileset>
+        </copy>
+    </target>
+
+    <target name="sf-build-roms">
+        <!-- find out if this is an arm build, if it is, then build roms -->
+        <propertyregex property="sf.is.arm.build"  override="true" input="${sf.spec.sbs.config}" regexp="(arm.*)" replace="true" casesensitive="false"/>
+    
+        <if><isset property="sf.is.arm.build"/> 
+        <then>
+            <mkdir dir="${roms.log.dir}"/>
+            <echo message="INFO Building Syborg MiniGUI stripped ROM"/>
+            <exec executable="cmd" dir="${build.drive}/epoc32/rom" failonerror="false">
+                <arg value="/c"/>
+                <arg value="buildrom syborg minigui-stripped"/>
+            </exec>
+            <if>
+                <!-- is iMaker rom building enabled? -->
+                <istrue value="${sf.spec.referenceroms.createimages.enable}" />
+                <then>
+                    <echo message="INFO Building iMaker configurations"/>
+                    <runtarget target="build-roms"/>
+                </then>
+            </if>
+        </then>
+        </if>        
+    </target>
+    
+</project>
--- a/sf-package/build.xml	Thu Sep 09 13:28:40 2010 +0100
+++ b/sf-package/build.xml	Fri Sep 10 11:29:11 2010 +0100
@@ -1,204 +1,206 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project name="SF-PACKAGE-CONFIG" xmlns:hlm="http://www.nokia.com/helium">
-  <!-- location of this config -->
-  <dirname property="sf.package.config.dir" file="${ant.file.SF-PACKAGE-CONFIG}"/>
-  
-  <!-- import codeline-specific properties -->
-  <import file="${sf.package.config.dir}/${sf.spec.job.codeline}_props.ant.xml" optional="yes"/>
-  
-  <!-- import package properties -->
-  <import file="${sf.package.config.dir}/package_props.ant.xml" />
-  
-  <!-- import common properties/targets/references -->
-  <import file="../common/build.xml" />
-  
-  <!-- import package references -->
-  <import file="${sf.package.config.dir}/package_refs.ant.xml" />
-  
-  <target name="sf-compile">
-  
-    <!-- Check that package_definition is not in v 3.0.0 otherwise transforms it to 2.0.1 -->
-    <echo message="Check that model file is in a version usable by Raptor"/>
-    <exec executable="perl" dir="${sf.common.config.dir}/sysdefdowngrade" failonerror="false" output="${build.log.dir}/sysdefdowngrade.log">
-      <arg value="sysdefdowngrade.pl"/>
-      <arg value="--model=${build.drive}/${sf.spec.systemdefinition.location}"/>
-      <arg value="--sources=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
-    </exec>
-    
-    
-    <!-- helium 7+ should use new sf-package-compile target -->
-    <if>
-        <or>
-          <equals arg1="${helium.version}" arg2="7.0"/>
-          <equals arg1="${last.major.helium.version}" arg2="7.0"/>
-        </or>
-        <then>
-            <runtarget target="sf-package-compile"/>
-        </then>
-        <else>
-            <runtarget target="sf-package-compile-hlm-5"/>
-        </else>
-    </if>
-    
-  </target>
-  
-    
-    
-  <target name="sf-package-compile">
-
-    <!-- build stuff -->
-    <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
-      <sequential>
-      
-      <hlm:sbsinput id="sf.build">
-        <sbsOptions>
-            <arg line="-c @{item.sbs.splitconfig}"/>
-            <arg line="-k" />
-            <arg line="-j ${sf.spec.sbs.numberofjobs}"/>
-            <arg line="-t ${sf.spec.sbs.retry.limit}"/>
-            <arg line="${sf.spec.sbs.options}"/>
-            <arg name="--filters" value="&quot;${sf.spec.sbs.filter.list}&quot;"/>
-            <arg name="--logfile" value="${build.log.dir}/${build.id}_@{item.sbs.splitconfig}_compile.log" />
-            <arg name="--makefile" value="${compile.log.dir}/${build.id}_@{item.sbs.splitconfig}_Makefile" />
-        </sbsOptions>
-      </hlm:sbsinput>
-      
-      <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
-      <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-          <param name="build.system" value="${sf.spec.build.system}" />
-          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
-          <param name="sbs.inputs.list" value="sf.build"/>
-          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
-      </antcall>    
-      </sequential>
-    </for>
-    <!-- build test code -->	
-    <if><istrue value="${sf.spec.package.test.enable}"/>
-        <then>
-            <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
-              <sequential>
-      
-              <hlm:sbsinput id="sf.build">
-                <sbsOptions>
-                    <arg line="-c @{item.sbs.splitconfig}.test"/>
-                    <arg line="-k" />
-                    <arg line="-j ${sf.spec.sbs.numberofjobs}"/>
-                    <arg line="-t ${sf.spec.sbs.retry.limit}"/>
-                    <arg line="${sf.spec.sbs.options}"/>
-                    <arg name="--filters" value="&quot;${sf.spec.sbs.filter.list}&quot;"/>
-                    <arg name="--logfile" value="${build.log.dir}/${build.id}_@{item.sbs.splitconfig}_compile.log" />
-                    <arg name="--makefile" value="${compile.log.dir}/${build.id}_@{item.sbs.splitconfig}_Makefile" />
-                </sbsOptions>
-              </hlm:sbsinput>
-      
-              <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
-              <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-                  <param name="build.system" value="${sf.spec.build.system}" />
-                  <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
-                  <param name="sbs.inputs.list" value="sf.build"/>
-                  <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
-              </antcall>    
-              </sequential>
-           </for>
-         </then>
-    </if>
-    
-    <!-- CHECK -->
-    <exec executable="cmd" dir="${build.drive}/" output="${build.drive}/output\logs\build_check_compile.log">
-      <arg value="/c sbs.bat -s ${build.drive}/output\build\canonical_system_definition_SF.xml -k -c tools2_rel -c winscw -c armv5 -j 32 --check -m ${build.drive}/output\logs\build_check_Makefile"/>
-      <!-- argument of -j option can be parameterized with: ${number.of.threads} -->
-    </exec>
-   
-  </target>
-        
-        
-  <target name="sf-package-compile-hlm-5">
-
-    <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
-      <sequential>
-        <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
-        
-        <!-- Do CLEAN
-        <hlm:argSet id="sbs.iterate.clean.var">
-          <hlm:arg name="config" value="@{item.sbs.splitconfig}" />
-          <hlm:arg name="enable-filter" value="${sf.spec.logs.raptorfilter.enable}" />
-          <hlm:arg name="command" value="CLEAN"/>
-        </hlm:argSet>
-        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-          <param name="build.system" value="${sf.spec.build.system}" />
-          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
-          <reference refid="sbs.iterate.clean.var" torefid="sbs.var" />
-          <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
-          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
-        </antcall>
-        -->
-
-        <!-- Do BUILD -->
-        <hlm:argSet id="sbs.main.iterate.sbs.var">
-          <hlm:arg name="config" value="@{item.sbs.splitconfig}" />
-          <hlm:arg name="enable-filter" value="${sf.spec.logs.raptorfilter.enable}" />
-          <hlm:arg name="retry-limit" value="${sf.spec.sbs.retry.limit}" />
-        </hlm:argSet>
-        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
-          <param name="build.system" value="${sf.spec.build.system}" />
-          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
-          <reference refid="sbs.main.iterate.sbs.var" torefid="sbs.var" />
-          <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
-          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
-        </antcall>                
-      </sequential>
-    </for>
-    
-    <!-- CHECK -->
-    <exec executable="cmd" dir="${build.drive}/" output="${build.drive}/output\logs\build_check_compile.log">
-      <arg value="/c sbs.bat -s ${build.drive}/output\build\canonical_system_definition_SF.xml -k -c tools2_rel -c winscw -c armv5 -j 32 --check -m ${build.drive}/output\logs\build_check_Makefile"/>
-      <!-- argument of -j option can be parameterized with: ${number.of.threads} -->
-    </exec>
-    
-  </target>
-        
-        
-  <target name="sf-test-package">
-
-    <echo message="INFO Preparing package"/>
-    <exec executable="perl" dir="${sf.common.config.dir}/tools/ats/" failonerror="false" output="${build.log.dir}/ATS_${build.id}_prep_package.log">
-        <arg value="hlm_prep_package.pl"/>
-        <arg value="--csv-file=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
-        <arg value="--bld-drive=${build.drive}"/>
-    </exec>
-  
-    <echo message="INFO Building package test drop(s)"/>
-<!--    <runtarget target="ats-test"/> --> <!-- Supported from Helium 9.0.5 onwards -->
-    <echo message="INFO Skipped - Helium 9.0.5+ required"/>
-	
-    <for param="file">
-        <path>
-            <fileset dir="${build.drive}/output/ats" includes="*.zip"/>
-        </path>
-        <sequential>
-            <propertyregex override="yes" property="program"  input="@{file}" regexp="([^\\/\/]*)$" select="\1"/>  						
-            <echo message="INFO Updating package test drop with test info"/>
-            <echo message="************ Test drop name:  ${program} " />
-            <exec executable="perl" dir="${sf.common.config.dir}/tools/ats/" failonerror="false" append="true" output="${build.log.dir}/ATS_${build.id}_packagetest.log">
-                <arg value="ats_specialise_test_drop.pl"/>
-                <arg value="--test-drop-name=${env.COMPUTERNAME}-packagetest-${build.id}_${program}"/> 
-                <arg value="--host-name=${env.COMPUTERNAME}.ad-sfpd.intra"/>
-                <arg value="--src=${build.drive}/output/ats/${program}"/>
-                <arg value="--dest=${sf.spec.test.package.location}\${env.COMPUTERNAME}-packagetest-${build.id}_${program}" />
-                <arg value="--publish=${publish.dir}\ats_reports\${program}"/>
-                <arg value="--ats-version=ats4"/> <!-- Hard-coded ats-version as Test Drop Generator for WINSCW supports only ATS4 -->
-            </exec>
-            <!-- Now ready to send to ATS -->  
-            <echo message="Sending test drop :  ${program} ............" />
-            <antcall target="sf-send-testpkg" inheritAll="false">
-                <param name="sf.spec.test.package.name" value="${env.COMPUTERNAME}-packagetest-${build.id}_${program}"/>
-            </antcall>
-        </sequential>
-    </for>
-
-  </target>
-
-  <target name="ats-emulator-zip"/> <!-- This is to override exisiting Helium target called from ats-test -->
-  
-</project>
-
+<?xml version="1.0" encoding="UTF-8"?>
+<project name="SF-PACKAGE-CONFIG" xmlns:hlm="http://www.nokia.com/helium">
+  <!-- location of this config -->
+  <dirname property="sf.package.config.dir" file="${ant.file.SF-PACKAGE-CONFIG}"/>
+  
+  <!-- import codeline-specific properties -->
+  <import file="${sf.package.config.dir}/${sf.spec.job.codeline}_props.ant.xml" optional="yes"/>
+  
+  <!-- import package properties -->
+  <import file="${sf.package.config.dir}/package_props.ant.xml" />
+  
+  <!-- import common properties/targets/references -->
+  <import file="../common/build.xml" />
+  
+  <!-- import package references -->
+  <import file="${sf.package.config.dir}/package_refs.ant.xml" />
+  
+  <target name="sf-compile">
+  
+    <!-- Check that package_definition is not in v 3.0.0 otherwise transforms it to 2.0.1 -->
+    <echo message="Check that model file is in a version usable by Raptor"/>
+    <exec executable="perl" dir="${sf.common.config.dir}/sysdefdowngrade" failonerror="false" output="${build.log.dir}/sysdefdowngrade.log">
+      <arg value="sysdefdowngrade.pl"/>
+      <arg value="--model=${build.drive}/${sf.spec.systemdefinition.location}"/>
+      <arg value="--sources=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
+    </exec>
+    
+    <!-- Moved from generate-layers -->
+    <copy file="${build.drive}/output/build/canonical_system_definition_${sysdef.configuration}.xml" todir="${build.log.dir}/BOM/"/>
+
+    <!-- helium 7+ should use new sf-package-compile target -->
+    <if>
+        <or>
+          <equals arg1="${helium.version}" arg2="7.0"/>
+          <equals arg1="${last.major.helium.version}" arg2="7.0"/>
+        </or>
+        <then>
+            <runtarget target="sf-package-compile"/>
+        </then>
+        <else>
+            <runtarget target="sf-package-compile-hlm-5"/>
+        </else>
+    </if>
+    
+  </target>
+  
+    
+    
+  <target name="sf-package-compile">
+
+    <!-- build stuff -->
+    <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
+      <sequential>
+      
+      <hlm:sbsinput id="sf.build">
+        <sbsOptions>
+            <arg line="-c @{item.sbs.splitconfig}"/>
+            <arg line="-k" />
+            <arg line="-j ${sf.spec.sbs.numberofjobs}"/>
+            <arg line="-t ${sf.spec.sbs.retry.limit}"/>
+            <arg line="${sf.spec.sbs.options}"/>
+            <arg name="--filters" value="&quot;${sf.spec.sbs.filter.list}&quot;"/>
+            <arg name="--logfile" value="${build.log.dir}/${build.id}_@{item.sbs.splitconfig}_compile.log" />
+            <arg name="--makefile" value="${compile.log.dir}/${build.id}_@{item.sbs.splitconfig}_Makefile" />
+        </sbsOptions>
+      </hlm:sbsinput>
+      
+      <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
+      <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+          <param name="build.system" value="${sf.spec.build.system}" />
+          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
+          <param name="sbs.inputs.list" value="sf.build"/>
+          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
+      </antcall>    
+      </sequential>
+    </for>
+    <!-- build test code -->	
+    <if><istrue value="${sf.spec.package.test.enable}"/>
+        <then>
+            <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
+              <sequential>
+      
+              <hlm:sbsinput id="sf.build">
+                <sbsOptions>
+                    <arg line="-c @{item.sbs.splitconfig}.test"/>
+                    <arg line="-k" />
+                    <arg line="-j ${sf.spec.sbs.numberofjobs}"/>
+                    <arg line="-t ${sf.spec.sbs.retry.limit}"/>
+                    <arg line="${sf.spec.sbs.options}"/>
+                    <arg name="--filters" value="&quot;${sf.spec.sbs.filter.list}&quot;"/>
+                    <arg name="--logfile" value="${build.log.dir}/${build.id}_@{item.sbs.splitconfig}_compile.log" />
+                    <arg name="--makefile" value="${compile.log.dir}/${build.id}_@{item.sbs.splitconfig}_Makefile" />
+                </sbsOptions>
+              </hlm:sbsinput>
+      
+              <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
+              <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+                  <param name="build.system" value="${sf.spec.build.system}" />
+                  <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
+                  <param name="sbs.inputs.list" value="sf.build"/>
+                  <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
+              </antcall>    
+              </sequential>
+           </for>
+         </then>
+    </if>
+    
+    <!-- CHECK -->
+    <exec executable="cmd" dir="${build.drive}/" output="${build.drive}/output\logs\build_check_compile.log">
+      <arg value="/c sbs.bat -s ${build.drive}/output\build\canonical_system_definition_SF.xml -k -c tools2_rel -c winscw -c armv5 -j 32 --check -m ${build.drive}/output\logs\build_check_Makefile"/>
+      <!-- argument of -j option can be parameterized with: ${number.of.threads} -->
+    </exec>
+   
+  </target>
+        
+        
+  <target name="sf-package-compile-hlm-5">
+
+    <for list="${sf.spec.sbs.config}" delimiter="," param="item.sbs.splitconfig">
+      <sequential>
+        <echo message="INFO [Iterative compile] Building target: @{item.sbs.splitconfig}"/>
+        
+        <!-- Do CLEAN
+        <hlm:argSet id="sbs.iterate.clean.var">
+          <hlm:arg name="config" value="@{item.sbs.splitconfig}" />
+          <hlm:arg name="enable-filter" value="${sf.spec.logs.raptorfilter.enable}" />
+          <hlm:arg name="command" value="CLEAN"/>
+        </hlm:argSet>
+        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+          <param name="build.system" value="${sf.spec.build.system}" />
+          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
+          <reference refid="sbs.iterate.clean.var" torefid="sbs.var" />
+          <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
+          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
+        </antcall>
+        -->
+
+        <!-- Do BUILD -->
+        <hlm:argSet id="sbs.main.iterate.sbs.var">
+          <hlm:arg name="config" value="@{item.sbs.splitconfig}" />
+          <hlm:arg name="enable-filter" value="${sf.spec.logs.raptorfilter.enable}" />
+          <hlm:arg name="retry-limit" value="${sf.spec.sbs.retry.limit}" />
+        </hlm:argSet>
+        <antcall target="compile-main" inheritAll="false" inheritRefs="true">
+          <param name="build.system" value="${sf.spec.build.system}" />
+          <param name="sysdef.configurations.list" value="${sf.spec.sysdef.configurations.list}" />
+          <reference refid="sbs.main.iterate.sbs.var" torefid="sbs.var" />
+          <reference refid="sbs.fullbuild.options" torefid="sbs.make.options" />
+          <reference refid="sf.spec.system.definition.files" torefid="system.definition.files" />
+        </antcall>                
+      </sequential>
+    </for>
+    
+    <!-- CHECK -->
+    <exec executable="cmd" dir="${build.drive}/" output="${build.drive}/output\logs\build_check_compile.log">
+      <arg value="/c sbs.bat -s ${build.drive}/output\build\canonical_system_definition_SF.xml -k -c tools2_rel -c winscw -c armv5 -j 32 --check -m ${build.drive}/output\logs\build_check_Makefile"/>
+      <!-- argument of -j option can be parameterized with: ${number.of.threads} -->
+    </exec>
+    
+  </target>
+        
+        
+  <target name="sf-test-package">
+
+    <echo message="INFO Preparing package"/>
+    <exec executable="perl" dir="${sf.common.config.dir}/tools/ats/" failonerror="false" output="${build.log.dir}/ATS_${build.id}_prep_package.log">
+        <arg value="hlm_prep_package.pl"/>
+        <arg value="--csv-file=${sf.spec.sourcesync.sourcespecdir}/${sf.spec.sourcesync.sourcespecfile}"/>
+        <arg value="--bld-drive=${build.drive}"/>
+    </exec>
+  
+    <echo message="INFO Building package test drop(s)"/>
+<!--    <runtarget target="ats-test"/> --> <!-- Supported from Helium 9.0.5 onwards -->
+    <echo message="INFO Skipped - Helium 9.0.5+ required"/>
+	
+    <for param="file">
+        <path>
+            <fileset dir="${build.drive}/output/ats" includes="*.zip"/>
+        </path>
+        <sequential>
+            <propertyregex override="yes" property="program"  input="@{file}" regexp="([^\\/\/]*)$" select="\1"/>  						
+            <echo message="INFO Updating package test drop with test info"/>
+            <echo message="************ Test drop name:  ${program} " />
+            <exec executable="perl" dir="${sf.common.config.dir}/tools/ats/" failonerror="false" append="true" output="${build.log.dir}/ATS_${build.id}_packagetest.log">
+                <arg value="ats_specialise_test_drop.pl"/>
+                <arg value="--test-drop-name=${env.COMPUTERNAME}-packagetest-${build.id}_${program}"/> 
+                <arg value="--host-name=${env.COMPUTERNAME}.ad-sfpd.intra"/>
+                <arg value="--src=${build.drive}/output/ats/${program}"/>
+                <arg value="--dest=${sf.spec.test.package.location}\${env.COMPUTERNAME}-packagetest-${build.id}_${program}" />
+                <arg value="--publish=${publish.dir}\ats_reports\${program}"/>
+                <arg value="--ats-version=ats4"/> <!-- Hard-coded ats-version as Test Drop Generator for WINSCW supports only ATS4 -->
+            </exec>
+            <!-- Now ready to send to ATS -->  
+            <echo message="Sending test drop :  ${program} ............" />
+            <antcall target="sf-send-testpkg" inheritAll="false">
+                <param name="sf.spec.test.package.name" value="${env.COMPUTERNAME}-packagetest-${build.id}_${program}"/>
+            </antcall>
+        </sequential>
+    </for>
+
+  </target>
+
+  <target name="ats-emulator-zip"/> <!-- This is to override exisiting Helium target called from ats-test -->
+  
+</project>
+