buildframework/helium/tools/common/docs.ant.xml
changeset 648 d5a8d436d33b
parent 645 b8d81fa19e7d
--- a/buildframework/helium/tools/common/docs.ant.xml	Wed Oct 13 16:27:55 2010 +0800
+++ b/buildframework/helium/tools/common/docs.ant.xml	Wed Oct 13 16:31:27 2010 +0800
@@ -91,6 +91,7 @@
     @scope private    
     -->    
     <target name="docs-database">
+        <mkdir dir="${basedir}/build"/>
         <hlm:database output="${public.database.file}" scope="public" filesetonly="true">
             <fileset dir=".">
                 <include name="**/*.ant.xml"/>
@@ -117,10 +118,10 @@
             <fileset dir="${doc.temp.dir}/api/helium" includes="*.dot"/>
             <sequential>
                 <echo>Processing dot file: @{dot.file}</echo>
-                <exec executable="dot" dir="${doc.temp.dir}/api/helium">
+                <exec executable="dot" dir="${doc.temp.dir}/api/helium" failonerror="true">
                     <arg line="-Tcmap @{dot.file} -O"/>
                 </exec>
-                <exec executable="dot" dir="${doc.build.dir}/api">
+                <exec executable="dot" dir="${doc.build.dir}/api" failonerror="true">
                     <arg line="-Tpng @{dot.file} -O"/>
                 </exec>
             </sequential>
@@ -168,8 +169,11 @@
 
     
     <!-- Generate API documentation from the source code. -->
-    <target name="apidocs" depends="helium-apidocs"/>
-    
+    <target name="apidocs" depends="helium-apidocs" unless="env.HLM_SUBCON">
+        <exec executable="cmd" osfamily="windows" dir="${helium.dir}/nokia_builder" failonerror="true">
+            <arg line="/C bld doc" />
+        </exec>
+    </target>
     
     <!-- Macro to generate HTML docs from rst. -->
     <macrodef name="rstPrepMacro" uri="http://www.nokia.com/helium">
@@ -232,6 +236,11 @@
                     <patch reverse="true" patchfile="${nokia.python.tools}/sphinxfixsearch.diff" originalfile="${sphinx.lib.dir}/search.py"/>
                 </then>
             </if>
+            <copy todir="@{output}" overwrite="true">
+                <fileset dir="@{src}">
+                    <include name="**/*.zip"/>
+                </fileset>
+            </copy>
         </sequential>
     </macrodef>
     
@@ -261,7 +270,7 @@
             try:
                 rstfile = codecs.open(rstfilename, 'r', 'utf8')
                 rstfile.read()
-            except:
+            except UnicodeError:
                 print rstfilename + ' has invalid unicode'
                 rstfile.close()
                 os.remove(rstfilename)
@@ -313,7 +322,6 @@
             <!-- default doc content is always processed first -->
             <path>
                 <pathelement path="${helium.dir}/doc/default"/>
-                <pathelement path="${helium.dir}/doc/src/manual"/>
             </path>
             <resources refid="textdoc.paths"/>
         </resources>
@@ -331,7 +339,7 @@
             </fileset>
             <sequential>
                 <echo>Building dot file: @{dot.file}</echo>
-                <exec executable="dot">
+                <exec executable="dot" failonerror="true">
                     <arg line="-Tpng @{dot.file} -O"/>
                 </exec>
             </sequential>
@@ -375,6 +383,40 @@
     
     
     <!-- generate all the user documentation for helium -->
-    <target name="docs" depends="clean-docs,apidocs,textdocs"/>
+    <target name="docs" depends="clean-docs,apidocs,textdocs,docs-check-links"/>
 
+    <!-- Check links in docs -->
+    <target name="docs-check-links">
+        <hlm:python failonerror="true">
+<![CDATA[
+import os
+error = ''
+for root, dirs, files in os.walk(r'${doc.build.dir}', topdown=False):
+    for fname in files:
+        if '.htm' in fname:
+            filename = os.path.abspath(os.path.join(root, fname))
+            f = open(filename)
+            for line in f:
+                if ' src="' in line:
+                    line1 = line.split('src="')[1]
+                    line1 = line1.split('"')[0]
+                    os.chdir(root)
+                    if line1 and not os.path.exists(line1) and not ':' in line1 and not '$' in line1:
+                        error = error + filename + ' has a broken link ' + line1 + '\n'
+                if ' href="' in line:
+                    line = line.split('href="')[1]
+                    line = line.split('"')[0]
+                    if '#' in line:
+                        line = line.split('#')[0]
+                    if '?' in line:
+                        line = line.split('?')[0]
+                    os.chdir(root)
+                    if line and not os.path.exists(line) and not ':' in line and not '&' in line:
+                        error = error + filename + ' has a broken link ' + line + '\n'
+            f.close()
+if error != '':
+    raise Exception(error)
+]]>
+        </hlm:python>
+    </target>
 </project>