[11] | 1 | <?xml version="1.0" encoding="UTF-8"?> |
---|
| 2 | <!-- You may freely edit this file. See commented blocks below for --> |
---|
| 3 | <!-- some examples of how to customize the build. --> |
---|
| 4 | <!-- (If you delete it and reopen the project it will be recreated.) --> |
---|
| 5 | <!-- By default, only the Clean and Build commands use this build script. --> |
---|
| 6 | <!-- Commands such as Run, Debug, and Test only use this build script if --> |
---|
| 7 | <!-- the Compile on Save feature is turned off for the project. --> |
---|
| 8 | <!-- You can turn off the Compile on Save (or Deploy on Save) setting --> |
---|
| 9 | <!-- in the project's Project Properties dialog box.--> |
---|
| 10 | <project name="fmgVen" default="default" basedir="."> |
---|
| 11 | <description>Builds, tests, and runs the project fmgVen.</description> |
---|
| 12 | <import file="nbproject/build-impl.xml"/> |
---|
| 13 | <!-- |
---|
| 14 | |
---|
| 15 | There exist several targets which are by default empty and which can be |
---|
| 16 | used for execution of your tasks. These targets are usually executed |
---|
| 17 | before and after some main targets. They are: |
---|
| 18 | |
---|
| 19 | -pre-init: called before initialization of project properties |
---|
| 20 | -post-init: called after initialization of project properties |
---|
| 21 | -pre-compile: called before javac compilation |
---|
| 22 | -post-compile: called after javac compilation |
---|
| 23 | -pre-compile-single: called before javac compilation of single file |
---|
| 24 | -post-compile-single: called after javac compilation of single file |
---|
| 25 | -pre-compile-test: called before javac compilation of JUnit tests |
---|
| 26 | -post-compile-test: called after javac compilation of JUnit tests |
---|
| 27 | -pre-compile-test-single: called before javac compilation of single JUnit test |
---|
| 28 | -post-compile-test-single: called after javac compilation of single JUunit test |
---|
| 29 | -pre-jar: called before JAR building |
---|
| 30 | -post-jar: called after JAR building |
---|
| 31 | -post-clean: called after cleaning build products |
---|
| 32 | |
---|
| 33 | (Targets beginning with '-' are not intended to be called on their own.) |
---|
| 34 | |
---|
| 35 | Example of inserting an obfuscator after compilation could look like this: |
---|
| 36 | |
---|
| 37 | <target name="-post-compile"> |
---|
| 38 | <obfuscate> |
---|
| 39 | <fileset dir="${build.classes.dir}"/> |
---|
| 40 | </obfuscate> |
---|
| 41 | </target> |
---|
| 42 | |
---|
| 43 | For list of available properties check the imported |
---|
| 44 | nbproject/build-impl.xml file. |
---|
| 45 | |
---|
| 46 | |
---|
| 47 | Another way to customize the build is by overriding existing main targets. |
---|
| 48 | The targets of interest are: |
---|
| 49 | |
---|
| 50 | -init-macrodef-javac: defines macro for javac compilation |
---|
| 51 | -init-macrodef-junit: defines macro for junit execution |
---|
| 52 | -init-macrodef-debug: defines macro for class debugging |
---|
| 53 | -init-macrodef-java: defines macro for class execution |
---|
| 54 | -do-jar-with-manifest: JAR building (if you are using a manifest) |
---|
| 55 | -do-jar-without-manifest: JAR building (if you are not using a manifest) |
---|
| 56 | run: execution of project |
---|
| 57 | -javadoc-build: Javadoc generation |
---|
| 58 | test-report: JUnit report generation |
---|
| 59 | |
---|
| 60 | An example of overriding the target for project execution could look like this: |
---|
| 61 | |
---|
| 62 | <target name="run" depends="fmgVen-impl.jar"> |
---|
| 63 | <exec dir="bin" executable="launcher.exe"> |
---|
| 64 | <arg file="${dist.jar}"/> |
---|
| 65 | </exec> |
---|
| 66 | </target> |
---|
| 67 | |
---|
| 68 | Notice that the overridden target depends on the jar target and not only on |
---|
| 69 | the compile target as the regular run target does. Again, for a list of available |
---|
| 70 | properties which you can use, check the target you are overriding in the |
---|
| 71 | nbproject/build-impl.xml file. |
---|
| 72 | |
---|
| 73 | --> |
---|
[34] | 74 | |
---|
| 75 | <!-- we use extra ant tasks such as propertyregex and if --> |
---|
| 76 | <taskdef classpath="etc/lib/ant-contrib-1.0b2.jar" resource="net/sf/antcontrib/antcontrib.properties"/> |
---|
| 77 | |
---|
| 78 | <!--put version info i.e. SVN revision, date ve and Hudson build number (if exists) to the manifest. Important: svn must be in the path to get the revision info. You can test this by writing svn in the command line. --> |
---|
| 79 | <target name="put-version-info"> |
---|
| 80 | |
---|
| 81 | <!-- get the BUILD_NUMBER value from environment or parameters (comes from hudson) and put it to build.number property, put -none- if it doesn't exist--> |
---|
| 82 | <property environment="env" /> |
---|
| 83 | <if> |
---|
| 84 | <isset property="env.BUILD_NUMBER" /> |
---|
| 85 | <then> |
---|
| 86 | <property name="build.number" value="${env.BUILD_NUMBER}" /> |
---|
| 87 | </then> |
---|
| 88 | <elseif> |
---|
| 89 | <isset property="BUILD_NUMBER" /> |
---|
| 90 | <then> |
---|
| 91 | <property name="build.number" value="${BUILD_NUMBER}" /> |
---|
| 92 | </then> |
---|
| 93 | </elseif> |
---|
| 94 | <else> |
---|
| 95 | <property name="build.number" value="-none-" /> |
---|
| 96 | </else> |
---|
| 97 | </if> |
---|
| 98 | |
---|
| 99 | <!-- get the info from svn and put it to svninfoprop property --> |
---|
| 100 | <exec executable="svn" outputproperty="svninfoprop"> |
---|
| 101 | <arg line="info"/> |
---|
| 102 | </exec> |
---|
| 103 | |
---|
| 104 | <!-- get the revision number --> |
---|
| 105 | <propertyregex property="revision.number" input="${svninfoprop}" select="\1"> |
---|
| 106 | <regexp pattern="Revision: ([0-9]*)"/> |
---|
| 107 | </propertyregex> |
---|
| 108 | <!-- get the last commit date --> |
---|
| 109 | <propertyregex property="revision.date" input="${svninfoprop}" select="\1"> |
---|
| 110 | <regexp pattern="Last Changed Date: (.*)\+"/> |
---|
| 111 | </propertyregex> |
---|
| 112 | |
---|
| 113 | <!-- copy manifest.mf template to build folder --> |
---|
| 114 | <copy file="etc/manifest-template.mf" tofile="build/manifest.mf" /> |
---|
| 115 | |
---|
| 116 | <!-- write the values to build/manifest.mf --> |
---|
| 117 | <replaceregexp file="build/manifest.mf" encoding="UTF-8"> |
---|
| 118 | <regexp pattern="Revision:([0-9]*)"/> |
---|
| 119 | <substitution expression="Revision: ${revision.number}"/> |
---|
| 120 | </replaceregexp> |
---|
| 121 | <replaceregexp file="build/manifest.mf" encoding="UTF-8"> |
---|
| 122 | <regexp pattern="Date:(.*)"/> |
---|
| 123 | <substitution expression="Date: ${revision.date}"/> |
---|
| 124 | </replaceregexp> |
---|
| 125 | <condition property="build.number" value="${build.number}" else="-none-"> |
---|
| 126 | <isset property="build.number"/> |
---|
| 127 | </condition> |
---|
| 128 | <replaceregexp file="build/manifest.mf" encoding="UTF-8"> |
---|
| 129 | <regexp pattern="Build:(.*)"/> |
---|
| 130 | <substitution expression="Build: ${build.number}"/> |
---|
| 131 | </replaceregexp> |
---|
| 132 | |
---|
| 133 | <echo message="Revision: ${revision.number} Date: ${revision.date} Build: ${build.number}"/> |
---|
| 134 | </target> |
---|
| 135 | |
---|
| 136 | <target name="-pre-jar"> |
---|
| 137 | <!-- put the version info --> |
---|
| 138 | <antcall target="put-version-info"/> |
---|
| 139 | </target> |
---|
[11] | 140 | </project> |
---|