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 | --> |
---|
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> |
---|
140 | </project> |
---|