doc/api/helium/target-sf-run-analysis-raptor.html
author MattD <mattd@symbian.org>
Fri, 16 Oct 2009 14:57:32 +0100
changeset 684 6d65abb8bba1
parent 627 56a1d97e7c73
permissions -rw-r--r--
sf-run-evalid - minor change to make sure that evalid is run at the root of the build drive, which can stop the MD5s from being generated. (evalid requires dirs to be relative and not absolute)


<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE HTML PUBLIC "-//w3c//dtd xhtml 1.0 strict//en"
      "http://www.w3.org/tr/xhtml1/dtd/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">


<head>
    <meta name="keywords" content="helium"/>
    <meta http-equiv="content-type" content="text/html+xml; charset=iso-8859-1"/>
    <link rel="stylesheet" href="stylesheet.css" type="text/css" />
    <script type="text/javascript">
      var DOCUMENTATION_OPTIONS = {
        URL_ROOT:   '',
        VERSION:    '0'
      };
    </script>
    <script type="text/javascript" src="../_static/jquery.js"></script>

    <script type="text/javascript" src="../_static/interface.js"></script>
    <script type="text/javascript" src="../_static/doctools.js"></script>
    
    <title>Target sf-run-analysis-raptor</title>
</head>


<body>
<!-- ========= start of top navbar ======= -->
<a name="navbar_top"><!-- --></a>
<a href="#skip-navbar_top" title="skip navigation links"></a>
<table border="0" width="100%" cellpadding="1" cellspacing="0" summary="">
<tr>
<td colspan="2" bgcolor="#eeeeff" class="navbarcell1">
<a name="navbar_top_firstrow"><!-- --></a>
<table border="0" cellpadding="0" cellspacing="3" summary="">
  <tr align="center" valign="top">
  <td bgcolor="#ffffff" class="navbarcell1"> &#160;<a href="overview-summary.html"><font class="navbarfont1"><b>overview</b></font>&#160;</a></td>

  <td bgcolor="#ffffff" class="navbarcell1">    <a href="deprecated-list.html"><font class="navbarfont1"><b>deprecated</b></font></a>&#160;</td>
    
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="properties-table.html"><font class="navbarfont1"><b>properties-table</b></font></a>&#160;</td>  
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="index-1.html"><font class="navbarfont1"><b>index</b></font></a>&#160;</td>
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="help.html"><font class="navbarfont1"><b>help</b></font></a>&#160;</td>
  </tr>
</table>
</td>
<td align="right" valign="top" rowspan="3"><em>
<b>Helium API</b></em>

</td>
</tr>

<tr>
<td bgcolor="white" class="navbarcell2"><font size="-2">
&#160;prev&#160;
&#160;next</font></td>
<td bgcolor="white" class="navbarcell2"><font size="-2">
  <a href="index.html?overview-summary.html" target="_top"><b>frames</b></a>  &#160;
&#160;<a href="overview-summary.html" target="_top"><b>no frames</b></a>  &#160;

&#160;<script type="text/javascript">
  <!--
  if(window==top) {
    document.writeln('<a href="allclasses-noframe.html"><b>all classes</b></a>');
  }
  //-->
</script>
<noscript>
  <a href="allclasses-noframe.html"><b>all classes</b></a>
</noscript>


</font></td>
</tr>
</table>
<a name="skip-navbar_top"></a>
<!-- ========= end of top navbar ========= -->
    <hr/>


    
<h2>Target sf-run-analysis-raptor</h2>

<p><b>Location</b></p>
<p>    <tt class="docutils literal"><a href="/d:/maintools/sf-config/common/build.postbuild.xml#L303">d:\maintools\sf-config\common\build.postbuild.xml:303:</a></tt>  
</p>

<p><b>Conditional execution</b></p>        
<p>No conditions on target execution.</p>
<hr/>

<h3>Description</h3>
<p>
</p>
<p/>
<hr/>


<h3>Target external Dependency</h3>
<p> 
<table class="docutils" width="50%">
    <tr>
        <th class="head">Name</th>
    </tr>
        <tr>
                    <td>perl</td>
            </tr>
        <tr>
                    <td>perl</td>
            </tr>
        <tr>
                    <td>perl</td>
            </tr>
        <tr>
                    <td>perl</td>
            </tr>
        <tr>
                    <td>perl</td>
            </tr>
        <tr>
                    <td>perl</td>
            </tr>
</table>
</p>


<h3>Property dependencies</h3>


<p> 
<table class="docutils" width="50%">
    <tr>
        <th class="head">Name</th><th class="head">Edit status</th>
    </tr>
    <tr>
        <td colspan="2">User editable properties</td>
    </tr>
    <tr>
        <td colspan="2">Internal properties</td>
    </tr>
                    <tr>
                        <td><a href="property-build.id.html" title="<p>A unique ID for the build.</p>" target="classframe"><tt class="docutils literal">build.id</tt></a></td><td><a href="help.html" title="Help" target="classframe">discouraged</a></td>
                    </tr>
                    <tr>
                        <td><a href="property-build.log.dir.html" title="<p>This is where the build logs are stored.</p>" target="classframe"><tt class="docutils literal">build.log.dir</tt></a></td><td><a href="help.html" title="Help" target="classframe">discouraged</a></td>
                    </tr>
</table>
</p>

<hr/>


<h3>Target dependencies</h3>
<p align="center">
<img src="target-sf-run-analysis-raptor.dot.png" alt="sf-run-analysis-raptor dependencies" usemap="#dependencies"
     style="border-style: none"/>
<map name="dependencies" id="dependencies">
<area shape="rect" id="node1" href="target-sf-run-analysis-raptor.html" title="sf&#45;run&#45;analysis&#45;raptor" alt="" coords="175,5,340,53">
<area shape="rect" id="node2" href="target-sf-run-analysis.html" title="sf&#45;run&#45;analysis" alt="" coords="5,5,125,53">
</map>
</p>
<hr/>


<h3>Source code</h3>
<pre>
    &lt;target name=&quot;sf-run-analysis-raptor&quot;&gt;            
      &lt;echo message=&quot;Preprocessing *_compile.log files&quot;/&gt;
      &lt;delete file=&quot;${build.log.dir}/analysis/${build.id}_preprocess.log&quot;/&gt;
      &lt;for param=&quot;logfile&quot;&gt;
        &lt;path&gt;
          &lt;fileset dir=&quot;${build.log.dir}&quot;&gt;
            &lt;include name=&quot;*_compile.log&quot;/&gt;
            &lt;exclude name=&quot;*build_check_compile.log&quot;/&gt;
          &lt;/fileset&gt;
        &lt;/path&gt;
        &lt;sequential&gt;
          &lt;propertyregex override=&quot;yes&quot; property=&quot;preprocessedlogfile&quot; input=&quot;@{logfile}&quot; regexp=&quot;.*[\\/](.*)_compile\.log&quot; replace=&quot;\1_compile_preprocessed.log&quot;/&gt;
          &lt;echo message=&quot;Preprocessing @{logfile}...&quot;/&gt;
          &lt;exec executable=&quot;perl&quot; dir=&quot;${sf.common.config.dir}/tools/raptor&quot; failonerror=&quot;false&quot; input=&quot;@{logfile}&quot; output=&quot;${build.log.dir}/analysis/${preprocessedlogfile}&quot; errorProperty=&quot;@{logfile}&quot;&gt;
            &lt;arg value=&quot;${sf.common.config.dir}/tools/raptor/preprocess_log.pl&quot;/&gt;
          &lt;/exec&gt;
	  &lt;echo file=&quot;${build.log.dir}/analysis/${build.id}_preprocess.log&quot; append=&quot;true&quot; message=&quot;${@{logfile}}${line.separator}&quot;/&gt;
        &lt;/sequential&gt;
      &lt;/for&gt;
      
      &lt;echo message=&quot;Extracting whatlog information from *whatlog*_compile_preprocessed.log files&quot;/&gt;
      &lt;for param=&quot;whatlogfile&quot;&gt;
        &lt;path&gt;
          &lt;fileset dir=&quot;${build.log.dir}/analysis&quot;&gt;
            &lt;include name=&quot;*whatlog*_compile_preprocessed.log&quot;/&gt;
          &lt;/fileset&gt;
        &lt;/path&gt;
        &lt;sequential&gt;
          &lt;echo message=&quot;Extracting whatlog info from @{whatlogfile}...&quot;/&gt;
          &lt;exec executable=&quot;perl&quot; dir=&quot;${sf.common.config.dir}/tools/raptor&quot; failonerror=&quot;false&quot; output=&quot;${build.log.dir}/analysis/${build.id}_whatlog.log&quot; append=&quot;true&quot;&gt;
            &lt;arg value=&quot;${sf.common.config.dir}/tools/raptor/parse.pl&quot;/&gt;
            &lt;arg value=&quot;--releaseable&quot;/&gt;
            &lt;arg value=&quot;--log=@{whatlogfile}&quot;/&gt;
            &lt;arg value=&quot;--basedir=${build.log.dir}&quot;/&gt;
            &lt;arg value=&quot;--append&quot;/&gt;
          &lt;/exec&gt;
        &lt;/sequential&gt;
      &lt;/for&gt;
      
      &lt;echo message=&quot;Extracting error information from *_compile_preprocessed.log files&quot;/&gt;
      &lt;for param=&quot;raptorlogfile&quot;&gt;
        &lt;path&gt;
          &lt;fileset dir=&quot;${build.log.dir}/analysis&quot;&gt;
            &lt;include name=&quot;*_compile_preprocessed.log&quot;/&gt;
          &lt;/fileset&gt;
        &lt;/path&gt;
        &lt;sequential&gt;
          &lt;echo message=&quot;Extracting error info from @{raptorlogfile}...&quot;/&gt;
          &lt;propertyregex override=&quot;yes&quot; property=&quot;raptorconfig&quot; input=&quot;@{raptorlogfile}&quot; regexp=&quot;.*[\\/].*__(.*)\.whatlog_(single|multiple)_thread.*&quot; replace=&quot;\1&quot; casesensitive=&quot;false&quot; defaultValue=&quot;noconfig&quot;/&gt;
          &lt;exec executable=&quot;perl&quot; dir=&quot;${sf.common.config.dir}/tools/raptor&quot; failonerror=&quot;false&quot; output=&quot;${build.log.dir}/analysis/${build.id}_raptorparse.log&quot; append=&quot;true&quot;&gt;
            &lt;arg value=&quot;${sf.common.config.dir}/tools/raptor/parse.pl&quot;/&gt;
            &lt;arg value=&quot;--error&quot;/&gt;
            &lt;arg value=&quot;--warning&quot;/&gt;
            &lt;arg value=&quot;--unreciped&quot;/&gt;
            &lt;arg value=&quot;--recipe&quot;/&gt;
            &lt;arg value=&quot;--config=${raptorconfig}&quot;/&gt;
            &lt;arg value=&quot;--log=@{raptorlogfile}&quot;/&gt;
            &lt;arg value=&quot;--basedir=${build.log.dir}/raptorbits&quot;/&gt;
          &lt;/exec&gt;
        &lt;/sequential&gt;
      &lt;/for&gt;
      
      &lt;echo message=&quot;Summarizing Raptor data&quot;/&gt;
      &lt;exec executable=&quot;perl&quot; dir=&quot;${sf.common.config.dir}/tools/raptor&quot; failonerror=&quot;false&quot; output=&quot;${build.log.dir}/analysis/${build.id}_raptorparse.log&quot; append=&quot;true&quot;&gt;
        &lt;arg value=&quot;${sf.common.config.dir}/tools/raptor/summarize.pl&quot;/&gt;
        &lt;arg value=&quot;--raptorbitsdir=${build.log.dir}/raptorbits&quot;/&gt;
        &lt;arg value=&quot;--outputdir=${build.log.dir}&quot;/&gt;
      &lt;/exec&gt;
          
      &lt;!-- Now iterate through the generated TSVs to sort them and remove duplicates --&gt;
      &lt;for param=&quot;tsv&quot;&gt;
        &lt;path&gt;
          &lt;fileset dir=&quot;${build.log.dir}&quot;&gt;
            &lt;include name=&quot;releaseables/**/*.tsv&quot;/&gt;
          &lt;/fileset&gt;
        &lt;/path&gt;
        &lt;sequential&gt;
          &lt;exec executable=&quot;perl&quot; input=&quot;@{tsv}&quot; output=&quot;@{tsv}&quot;&gt;
            &lt;arg value=&quot;${sf.common.config.dir}/tools/sortUnique.pl&quot;/&gt;
          &lt;/exec&gt;
        &lt;/sequential&gt;
      &lt;/for&gt;

      &lt;!-- Cook the raptor analysis further to produce something in the right format for the BRAG system --&gt;
      &lt;exec executable=&quot;perl&quot; output=&quot;${build.log.dir}/summary/Raptor_BRAG.xml&quot; logError=&quot;yes&quot;&gt;
        &lt;arg value=&quot;${sf.common.config.dir}/tools/brag/raptorToBRAG.pl&quot;/&gt;
        &lt;arg value=&quot;--raptorsummary&quot;/&gt;
        &lt;arg value=&quot;${build.log.dir}/raptorbits/summary.csv&quot;/&gt;
      &lt;/exec&gt;
      &lt;!-- And copy the XSL so the output can be transformed by a browser --&gt;
      &lt;copy file=&quot;${sf.common.config.dir}/tools/brag/brag.xsl&quot; toDir=&quot;${build.log.dir}/summary/&quot;/&gt;
    &lt;/target&gt;
</pre>


    <hr/>
<!-- ========= start of top navbar ======= -->
<a name="navbar_top"><!-- --></a>
<a href="#skip-navbar_top" title="skip navigation links"></a>
<table border="0" width="100%" cellpadding="1" cellspacing="0" summary="">
<tr>
<td colspan="2" bgcolor="#eeeeff" class="navbarcell1">
<a name="navbar_top_firstrow"><!-- --></a>
<table border="0" cellpadding="0" cellspacing="3" summary="">
  <tr align="center" valign="top">
  <td bgcolor="#ffffff" class="navbarcell1"> &#160;<a href="overview-summary.html"><font class="navbarfont1"><b>overview</b></font>&#160;</a></td>

  <td bgcolor="#ffffff" class="navbarcell1">    <a href="deprecated-list.html"><font class="navbarfont1"><b>deprecated</b></font></a>&#160;</td>
    
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="properties-table.html"><font class="navbarfont1"><b>properties-table</b></font></a>&#160;</td>  
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="index-1.html"><font class="navbarfont1"><b>index</b></font></a>&#160;</td>
  <td bgcolor="#eeeeff" class="navbarcell1">    <a href="help.html"><font class="navbarfont1"><b>help</b></font></a>&#160;</td>
  </tr>
</table>
</td>
<td align="right" valign="top" rowspan="3"><em>
<b>Helium API</b></em>

</td>
</tr>

<tr>
<td bgcolor="white" class="navbarcell2"><font size="-2">
&#160;prev&#160;
&#160;next</font></td>
<td bgcolor="white" class="navbarcell2"><font size="-2">
  <a href="index.html?overview-summary.html" target="_top"><b>frames</b></a>  &#160;
&#160;<a href="overview-summary.html" target="_top"><b>no frames</b></a>  &#160;

&#160;<script type="text/javascript">
  <!--
  if(window==top) {
    document.writeln('<a href="allclasses-noframe.html"><b>all classes</b></a>');
  }
  //-->
</script>
<noscript>
  <a href="allclasses-noframe.html"><b>all classes</b></a>
</noscript>


</font></td>
</tr>
</table>
<a name="skip-navbar_top"></a>
<!-- ========= end of top navbar ========= -->
    <font size="-2">Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. License: http://www.eclipse.org/legal/epl-v10.html</font>
 </body>

</html>