uppercutbuild 0.9.0.346.20100805 → 1.0.0.0.20100806
Sign up to get free protection for your applications and to get access to all the features.
- data/docs/README +7 -2
- data/lib/build.sh +23 -0
- data/lib/build/UppercuT.xml +1 -1
- data/lib/build/analyze.step +78 -77
- data/lib/build/analyzers/gallio.test.step +25 -26
- data/lib/build/analyzers/mbunit2.test.step +25 -28
- data/lib/build/analyzers/moma.step +29 -31
- data/lib/build/analyzers/ncover.step +32 -34
- data/lib/build/analyzers/ndepend.step +19 -12
- data/lib/build/analyzers/nitriq.step +19 -22
- data/lib/build/analyzers/nunit.test.step +37 -37
- data/lib/build/analyzers/test.step +99 -98
- data/lib/build/compile.step +68 -50
- data/lib/build/customize.build +76 -75
- data/lib/build/customizers/item.template +50 -49
- data/lib/build/default.build +171 -167
- data/lib/build/deploymentBuilder.step +103 -102
- data/lib/build/environmentBuilder.step +119 -118
- data/lib/build/gemsBuild.step +113 -112
- data/lib/build/gemsPrepare.step +157 -156
- data/lib/build/generateBuildInfo.step +108 -105
- data/lib/build/ilmerge.build +183 -182
- data/lib/build/open.build +115 -102
- data/lib/build/package.step +234 -233
- data/lib/build/policyChecks.step +81 -80
- data/lib/build/updateAssemblies.build +107 -106
- data/lib/build/uppercut.dll +0 -0
- data/lib/build/uppercut.tasks.dll +0 -0
- data/lib/build/versionBuilder.step +149 -147
- data/lib/build/versioners/git.step +106 -105
- data/lib/build/versioners/hg.step +106 -105
- data/lib/build/versioners/svn.step +112 -111
- data/lib/build/versioners/tfs.step +104 -103
- data/lib/build/zip.build +134 -162
- data/lib/deployment/scripts/database.deploy +37 -36
- data/lib/open.sh +7 -0
- data/lib/settings/UppercuT.config +76 -73
- data/lib/zip.sh +9 -0
- metadata +9 -6
data/lib/build/ilmerge.build
CHANGED
@@ -1,183 +1,184 @@
|
|
1
|
-
<?xml version="1.0" encoding="utf-8" ?>
|
2
|
-
<project name="ILMergeBuilder" default="go">
|
3
|
-
<!-- Project UppercuT - http://projectuppercut.org -->
|
4
|
-
<property name="build.config.settings" value="__NONE__" overwrite="false" />
|
5
|
-
<include buildfile="${build.config.settings}" if="${file::exists(build.config.settings)}" />
|
6
|
-
<property name="
|
7
|
-
<property name="
|
8
|
-
<property name="
|
9
|
-
<property name="
|
10
|
-
<property name="folder.
|
11
|
-
<property name="
|
12
|
-
<property name="
|
13
|
-
<property name="
|
14
|
-
<property name="
|
15
|
-
<property name="
|
16
|
-
<property name="dirs.
|
17
|
-
<property name="
|
18
|
-
<property name="
|
19
|
-
<property name="
|
20
|
-
<property name="
|
21
|
-
<property name="
|
22
|
-
|
23
|
-
|
24
|
-
<property name="dirs.merge.
|
25
|
-
|
26
|
-
|
27
|
-
<property name="
|
28
|
-
<property name="file.
|
29
|
-
|
30
|
-
|
31
|
-
<property name="
|
32
|
-
<property name="args.ilmerge" value="/internalize
|
33
|
-
|
34
|
-
|
35
|
-
<property name="
|
36
|
-
<property name="file.custom.step.
|
37
|
-
<property name="file.custom.step.
|
38
|
-
<property name="
|
39
|
-
<property name="
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
<
|
46
|
-
<call target="
|
47
|
-
<call target="
|
48
|
-
<call target="
|
49
|
-
<call target="
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
<
|
59
|
-
<
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
<
|
70
|
-
<
|
71
|
-
<
|
72
|
-
<
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
<
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
<property name="dirs.merge.
|
84
|
-
<property name="
|
85
|
-
<property name="merge.
|
86
|
-
<property name="
|
87
|
-
<property name="args.ilmerge" value="/internalize
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
<mkdir dir="${dirs.merge.
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
<
|
103
|
-
<
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
<
|
108
|
-
<include name="${dirs.merge.from}
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
<property name="
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
<echo message="
|
123
|
-
<
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
<
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
<
|
160
|
-
<
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
1
|
+
<?xml version="1.0" encoding="utf-8" ?>
|
2
|
+
<project name="ILMergeBuilder" default="go">
|
3
|
+
<!-- Project UppercuT - http://projectuppercut.org -->
|
4
|
+
<property name="build.config.settings" value="__NONE__" overwrite="false" />
|
5
|
+
<include buildfile="${build.config.settings}" if="${file::exists(build.config.settings)}" />
|
6
|
+
<property name="path.separator" value="${string::trim(path::combine(' ', ' '))}" />
|
7
|
+
<property name="file.current.no_extension" value="ilmerge" />
|
8
|
+
<property name="dirs.current" value="${directory::get-parent-directory(project::get-buildfile-path())}" />
|
9
|
+
<property name="path.to.toplevel" value=".." />
|
10
|
+
<property name="folder.build_scripts" value="build" overwrite="false" />
|
11
|
+
<property name="folder.build_scripts_custom" value="build.custom" overwrite="false" />
|
12
|
+
<property name="dirs.build_scripts_custom" value="${dirs.current}${path.separator}${path.to.toplevel}${path.separator}${folder.build_scripts_custom}" />
|
13
|
+
<property name="folder.code_drop" value="code_drop" overwrite="false" />
|
14
|
+
<property name="dirs.drop" value="${dirs.current}${path.separator}${path.to.toplevel}${path.separator}${folder.code_drop}" overwrite="false" />
|
15
|
+
<property name="folder.app.drop" value="${project.name}" overwrite="false" />
|
16
|
+
<property name="dirs.lib" value="${dirs.current}${path.separator}${path.to.toplevel}${path.separator}lib" overwrite="false" />
|
17
|
+
<property name="dirs.ilmerge.folder" value="${dirs.lib}${path.separator}ILMerge" />
|
18
|
+
<property name="app.ilmerge" value="${dirs.ilmerge.folder}${path.separator}ILMerge.exe" overwrite="false" />
|
19
|
+
<property name="dirs.merge.log" value="${dirs.drop}${path.separator}build_artifacts${path.separator}ilmerge" />
|
20
|
+
<property name="log.merge" value="ilmerge.log" />
|
21
|
+
<property name="file.uppercut.assembly" value="uppercut.tasks.dll" />
|
22
|
+
<property name="path.uppercut.assembly" value="${dirs.current}${path.separator}${file.uppercut.assembly}" />
|
23
|
+
|
24
|
+
<property name="dirs.merge.from" value="${dirs.drop}${path.separator}${folder.app.drop}" overwrite="false" />
|
25
|
+
<property name="dirs.merge.to" value="${dirs.drop}${path.separator}merge" overwrite="false" />
|
26
|
+
|
27
|
+
<property name="file.internalize.ignore" value="ilmerge.internalize.ignore.txt" />
|
28
|
+
<property name="path.file.internalize.ignore" value="${dirs.build_scripts_custom}${path.separator}${file.internalize.ignore}" />
|
29
|
+
<property name="file.merge.name" value="__REPLACE__" overwrite="false" />
|
30
|
+
<!-- exe winexe dll -->
|
31
|
+
<property name="merge.target.type" value="__REPLACE__" overwrite="false" />
|
32
|
+
<property name="args.ilmerge" value="/internalize /target:${merge.target.type} /out:${dirs.merge.to}${path.separator}${file.merge.name} /log:${dirs.merge.log}${path.separator}${log.merge} /ndebug /allowDup ${file.merge.name} " />
|
33
|
+
<property name="args.ilmerge" value="/internalize:${path.file.internalize.ignore} /target:${merge.target.type} /out:${dirs.merge.to}${path.separator}${file.merge.name} /log:${dirs.merge.log}${path.separator}${log.merge} /ndebug /allowDup ${file.merge.name} " if="${file::exists(path.file.internalize.ignore)}"/>
|
34
|
+
|
35
|
+
<property name="allow.powershell.unrestricted" value="false" overwrite="false" />
|
36
|
+
<property name="file.custom.step.before" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.pre.build" />
|
37
|
+
<property name="file.custom.step.after" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.post.build" />
|
38
|
+
<property name="file.custom.step.replace" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.replace.build" />
|
39
|
+
<property name="is.replaced" value="false" />
|
40
|
+
<property name="fail.build.on.error" value="true" />
|
41
|
+
|
42
|
+
<target name="go" depends="load_uppercut_assemblies, allow_powershell_unrestricted, run_tasks" />
|
43
|
+
|
44
|
+
<target name="run_tasks">
|
45
|
+
<echo message="Running ${project::get-name()} tasks." />
|
46
|
+
<call target="prepare" if="${target::exists('prepare')}" />
|
47
|
+
<call target="custom_tasks_before" if="${target::exists('custom_tasks_before')}" />
|
48
|
+
<call target="custom_tasks_replace" if="${target::exists('custom_tasks_replace')}" />
|
49
|
+
<call target="run_normal_tasks" if="${not is.replaced}" />
|
50
|
+
<call target="custom_tasks_after" if="${target::exists('custom_tasks_after')}" />
|
51
|
+
</target>
|
52
|
+
|
53
|
+
<target name="run_normal_tasks"
|
54
|
+
depends="set_environment_variables, error_check, get_regular_dlls, run_ilmerge, copy_configs, remove_unneeded_assemblies, copy_from_merge, delete_merge_folder"
|
55
|
+
description="Running ILMerge with UppercuT default.build." />
|
56
|
+
|
57
|
+
<target name="custom_tasks_before">
|
58
|
+
<echo message="Running custom tasks if ${file.custom.step.before} exists." />
|
59
|
+
<nant buildfile="${file.custom.step.before}" inheritall="true" if="${file::exists(file.custom.step.before)}" failonerror="${fail.build.on.error}" />
|
60
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.before + '.ps1')}" failonerror="${fail.build.on.error}">
|
61
|
+
<arg value="${path::get-full-path(file.custom.step.before + '.ps1')}" />
|
62
|
+
</exec>
|
63
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.before + '.rb')}" failonerror="${fail.build.on.error}">
|
64
|
+
<arg value="${path::get-full-path(file.custom.step.before + '.rb')}" />
|
65
|
+
</exec>
|
66
|
+
</target>
|
67
|
+
|
68
|
+
<target name="custom_tasks_replace">
|
69
|
+
<echo message="Running custom tasks instead of normal tasks if ${file.custom.step.replace} exists." />
|
70
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace)}" />
|
71
|
+
<nant buildfile="${file.custom.step.replace}" inheritall="true" if="${file::exists(file.custom.step.replace)}" failonerror="${fail.build.on.error}" />
|
72
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace + '.ps1')}" />
|
73
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.replace + '.ps1')}" failonerror="${fail.build.on.error}" >
|
74
|
+
<arg value="${path::get-full-path(file.custom.step.replace + '.ps1')}" />
|
75
|
+
</exec>
|
76
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace + '.rb')}" />
|
77
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.replace + '.rb')}" failonerror="${fail.build.on.error}" >
|
78
|
+
<arg value="${path::get-full-path(file.custom.step.replace + '.rb')}" />
|
79
|
+
</exec>
|
80
|
+
</target>
|
81
|
+
|
82
|
+
<target name="set_environment_variables">
|
83
|
+
<property name="dirs.merge.from" value="${environment::get-variable('uc.dirs.merge.from')}" if="${environment::variable-exists('uc.dirs.merge.from')}" />
|
84
|
+
<property name="dirs.merge.to" value="${environment::get-variable('uc.dirs.merge.to')}" if="${environment::variable-exists('uc.dirs.merge.to')}" />
|
85
|
+
<property name="file.merge.name" value="${environment::get-variable('uc.file.merge.name')}" if="${environment::variable-exists('uc.file.merge.name')}" />
|
86
|
+
<property name="merge.target.type" value="${environment::get-variable('uc.merge.target.type')}" if="${environment::variable-exists('uc.merge.target.type')}" />
|
87
|
+
<property name="args.ilmerge" value="/internalize /target:${merge.target.type} /out:${dirs.merge.to}${path.separator}${file.merge.name} /log:${dirs.merge.log}${path.separator}${log.merge} /ndebug /allowDup ${file.merge.name} " />
|
88
|
+
<property name="args.ilmerge" value="/internalize:${path.file.internalize.ignore} /target:${merge.target.type} /out:${dirs.merge.to}${path.separator}${file.merge.name} /log:${dirs.merge.log}${path.separator}${log.merge} /ndebug /allowDup ${file.merge.name} " if="${file::exists(path.file.internalize.ignore)}"/>
|
89
|
+
</target>
|
90
|
+
|
91
|
+
<target name="error_check">
|
92
|
+
<fail message="You must pass in the file.merge.name and the merge.target.type through the command line calling this build. Please do that and retry the build. You can also set up an ilmerge.pre.build and set these environment variables: uc.dirs.merge.from, uc.dirs.merge.to, uc.file.merge.name, and uc.merge.target.type"
|
93
|
+
if="${file.merge.name=='__REPLACE__' or merge.target.type=='__REPLACE__'}" />
|
94
|
+
</target>
|
95
|
+
|
96
|
+
<target name="prepare">
|
97
|
+
<mkdir dir="${dirs.merge.log}" />
|
98
|
+
<mkdir dir="${dirs.merge.to}" />
|
99
|
+
</target>
|
100
|
+
|
101
|
+
<target name="get_regular_dlls">
|
102
|
+
<echo message="Getting output dlls based on name in directory ${path::get-full-path(dirs.merge.from)}." />
|
103
|
+
<property name="dll.names" value="" />
|
104
|
+
<foreach item="File" property="dll.filename">
|
105
|
+
<in>
|
106
|
+
<items>
|
107
|
+
<exclude name="${dirs.merge.from}${path.separator}${file.merge.name}" />
|
108
|
+
<include name="${dirs.merge.from}${path.separator}*.dll" />
|
109
|
+
<include name="${dirs.merge.from}${path.separator}*.exe" />
|
110
|
+
</items>
|
111
|
+
</in>
|
112
|
+
<do>
|
113
|
+
<property name="dll.names" value="${dll.names + ' ' + path::get-file-name(dll.filename)}" />
|
114
|
+
</do>
|
115
|
+
</foreach>
|
116
|
+
|
117
|
+
<property name="dlls.regular" value="${dll.names}" />
|
118
|
+
<property name="args.ilmerge" value="${args.ilmerge} ${dlls.regular}" />
|
119
|
+
</target>
|
120
|
+
|
121
|
+
<target name="run_ilmerge">
|
122
|
+
<echo message="Merging the the contents of ${dirs.merge.from} into a single executable - ${dirs.merge.to}${path.separator}${file.merge.name}. This will fail if all dependencies are not resolved."/>
|
123
|
+
<echo message="Running this: ${app.ilmerge} ${args.ilmerge}"/>
|
124
|
+
<exec program="${app.ilmerge}"
|
125
|
+
workingdir="${dirs.merge.from}"
|
126
|
+
commandline="${args.ilmerge}" />
|
127
|
+
</target>
|
128
|
+
|
129
|
+
<target name="copy_configs">
|
130
|
+
<copy todir="${dirs.merge.to}">
|
131
|
+
<fileset basedir="${dirs.merge.from}">
|
132
|
+
<include name="**/*.config" />
|
133
|
+
</fileset>
|
134
|
+
</copy>
|
135
|
+
</target>
|
136
|
+
|
137
|
+
<target name="remove_unneeded_assemblies">
|
138
|
+
<echo message="Removing unneeded assemblies before moving the merged assembly back into ${dirs.merge.from}."/>
|
139
|
+
<delete>
|
140
|
+
<fileset basedir="${dirs.merge.from}" >
|
141
|
+
<include name="*.*" />
|
142
|
+
</fileset>
|
143
|
+
</delete>
|
144
|
+
</target>
|
145
|
+
|
146
|
+
<target name="copy_from_merge">
|
147
|
+
<copy todir="${dirs.merge.from}">
|
148
|
+
<fileset basedir="${dirs.merge.to}">
|
149
|
+
<include name="**/*.*" />
|
150
|
+
</fileset>
|
151
|
+
</copy>
|
152
|
+
</target>
|
153
|
+
|
154
|
+
<target name="delete_merge_folder">
|
155
|
+
<delete dir="${dirs.merge.to}" failonerror="false" />
|
156
|
+
</target>
|
157
|
+
|
158
|
+
<target name="custom_tasks_after">
|
159
|
+
<echo message="Running custom tasks if ${file.custom.step.after} exists." />
|
160
|
+
<nant buildfile="${file.custom.step.after}" inheritall="true" if="${file::exists(file.custom.step.after)}" failonerror="${fail.build.on.error}" />
|
161
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.after + '.ps1')}" failonerror="${fail.build.on.error}" >
|
162
|
+
<arg value="${path::get-full-path(file.custom.step.after + '.ps1')}" />
|
163
|
+
</exec>
|
164
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.after + '.rb')}" failonerror="${fail.build.on.error}" >
|
165
|
+
<arg value="${path::get-full-path(file.custom.step.after + '.rb')}" />
|
166
|
+
</exec>
|
167
|
+
</target>
|
168
|
+
|
169
|
+
<target name="load_uppercut_assemblies">
|
170
|
+
<loadtasks assembly="${path.uppercut.assembly}" if="${file::exists(path.uppercut.assembly)}" />
|
171
|
+
</target>
|
172
|
+
|
173
|
+
<target name="allow_powershell_unrestricted">
|
174
|
+
<!-- powershell 1.0 -->
|
175
|
+
<exec program="powershell.exe" if="${allow.powershell.unrestricted}" failonerror="false">
|
176
|
+
<arg value="set-executionpolicy unrestricted" />
|
177
|
+
</exec>
|
178
|
+
<!-- powershell 2.0 -->
|
179
|
+
<exec program="powershell.exe" if="${allow.powershell.unrestricted}" failonerror="false">
|
180
|
+
<arg value="set-executionpolicy unrestricted -force -scope CurrentUser" />
|
181
|
+
</exec>
|
182
|
+
</target>
|
183
|
+
|
183
184
|
</project>
|
data/lib/build/open.build
CHANGED
@@ -1,103 +1,116 @@
|
|
1
|
-
<?xml version="1.0" encoding="utf-8" ?>
|
2
|
-
<project name="Open" default="go">
|
3
|
-
<!-- Project UppercuT - http://projectuppercut.org -->
|
4
|
-
<!-- DO NOT EDIT THIS FILE - find out more at http://uppercut.pbwiki.com -->
|
5
|
-
<property name="build.config.settings" value="__NONE__" overwrite="false" />
|
6
|
-
<include buildfile="${build.config.settings}" if="${file::exists(build.config.settings)}" />
|
7
|
-
<property name="
|
8
|
-
<property name="
|
9
|
-
<property name="
|
10
|
-
<property name="
|
11
|
-
<property name="folder.
|
12
|
-
<property name="
|
13
|
-
<property name="dirs.
|
14
|
-
<property name="solution
|
15
|
-
<property name="solution.path
|
16
|
-
<property name="
|
17
|
-
<property name="
|
18
|
-
<property name="
|
19
|
-
<property name="
|
20
|
-
<property name="
|
21
|
-
<property name="
|
22
|
-
<property name="file.custom.step.
|
23
|
-
<property name="
|
24
|
-
<property name="
|
25
|
-
|
26
|
-
<
|
27
|
-
|
28
|
-
<target name="run_tasks"
|
29
|
-
|
30
|
-
|
31
|
-
<
|
32
|
-
<call target="
|
33
|
-
<call target="
|
34
|
-
<call target="
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
<
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
<
|
56
|
-
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace
|
57
|
-
<
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
1
|
+
<?xml version="1.0" encoding="utf-8" ?>
|
2
|
+
<project name="Open" default="go">
|
3
|
+
<!-- Project UppercuT - http://projectuppercut.org -->
|
4
|
+
<!-- DO NOT EDIT THIS FILE - find out more at http://uppercut.pbwiki.com -->
|
5
|
+
<property name="build.config.settings" value="__NONE__" overwrite="false" />
|
6
|
+
<include buildfile="${build.config.settings}" if="${file::exists(build.config.settings)}" />
|
7
|
+
<property name="path.separator" value="${string::trim(path::combine(' ', ' '))}" />
|
8
|
+
<property name="file.current.no_extension" value="open" />
|
9
|
+
<property name="dirs.current" value="${directory::get-parent-directory(project::get-buildfile-path())}" />
|
10
|
+
<property name="path.to.toplevel" value=".." />
|
11
|
+
<property name="folder.build_scripts" value="build" overwrite="false" />
|
12
|
+
<property name="folder.build_scripts_custom" value="build.custom" overwrite="false" />
|
13
|
+
<property name="dirs.build_scripts_custom" value="${dirs.current}${path.separator}${path.to.toplevel}${path.separator}${folder.build_scripts_custom}" />
|
14
|
+
<property name="dirs.solution" value="${dirs.current}${path.separator}${path.to.toplevel}${path.separator}${path_to_solution}" />
|
15
|
+
<property name="solution.path" value="${path::get-full-path(dirs.solution)}${path.separator}${project.name}.sln" />
|
16
|
+
<property name="solution.path.full" value="${path::get-full-path(solution.path)}" />
|
17
|
+
<property name="app.visual_studio" value="${environment::get-folder-path('ProgramFiles')}\Common Files\Microsoft Shared\MSEnv\VSLauncher.exe" />
|
18
|
+
<property name="app.monodevelop" value="monodevelop" />
|
19
|
+
<property name="file.uppercut.assembly" value="uppercut.tasks.dll" />
|
20
|
+
<property name="path.uppercut.assembly" value="${dirs.current}${path.separator}${file.uppercut.assembly}" />
|
21
|
+
<property name="allow.powershell.unrestricted" value="false" overwrite="false" />
|
22
|
+
<property name="file.custom.step.before" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.pre.build" />
|
23
|
+
<property name="file.custom.step.after" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.post.build" />
|
24
|
+
<property name="file.custom.step.replace" value="${dirs.build_scripts_custom}${path.separator}${file.current.no_extension}.replace.build" />
|
25
|
+
<property name="is.replaced" value="false" />
|
26
|
+
<property name="fail.build.on.error" value="false" />
|
27
|
+
|
28
|
+
<target name="go" depends="load_uppercut_assemblies, allow_powershell_unrestricted, run_tasks" />
|
29
|
+
|
30
|
+
<target name="run_tasks">
|
31
|
+
<echo message="Running ${project::get-name()} tasks." />
|
32
|
+
<call target="prepare" if="${target::exists('prepare')}" />
|
33
|
+
<call target="custom_tasks_before" if="${target::exists('custom_tasks_before')}" />
|
34
|
+
<call target="custom_tasks_replace" if="${target::exists('custom_tasks_replace')}" />
|
35
|
+
<call target="run_normal_tasks" if="${not is.replaced}" />
|
36
|
+
<call target="custom_tasks_after" if="${target::exists('custom_tasks_after')}" />
|
37
|
+
</target>
|
38
|
+
|
39
|
+
<target name="run_normal_tasks"
|
40
|
+
depends="open_visual_studio"
|
41
|
+
description="Opening Visual Studio." />
|
42
|
+
|
43
|
+
<target name="custom_tasks_before">
|
44
|
+
<echo message="Running custom tasks if ${file.custom.step.before} exists." />
|
45
|
+
<nant buildfile="${file.custom.step.before}" inheritall="true" if="${file::exists(file.custom.step.before)}" failonerror="${fail.build.on.error}" />
|
46
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.before + '.ps1')}" failonerror="${fail.build.on.error}">
|
47
|
+
<arg value="${path::get-full-path(file.custom.step.before + '.ps1')}" />
|
48
|
+
</exec>
|
49
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.before + '.rb')}" failonerror="${fail.build.on.error}">
|
50
|
+
<arg value="${path::get-full-path(file.custom.step.before + '.rb')}" />
|
51
|
+
</exec>
|
52
|
+
</target>
|
53
|
+
|
54
|
+
<target name="custom_tasks_replace">
|
55
|
+
<echo message="Running custom tasks instead of normal tasks if ${file.custom.step.replace} exists." />
|
56
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace)}" />
|
57
|
+
<nant buildfile="${file.custom.step.replace}" inheritall="true" if="${file::exists(file.custom.step.replace)}" failonerror="${fail.build.on.error}" />
|
58
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace + '.ps1')}" />
|
59
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.replace + '.ps1')}" failonerror="${fail.build.on.error}" >
|
60
|
+
<arg value="${path::get-full-path(file.custom.step.replace + '.ps1')}" />
|
61
|
+
</exec>
|
62
|
+
<property name="is.replaced" value="true" if="${file::exists(file.custom.step.replace + '.rb')}" />
|
63
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.replace + '.rb')}" failonerror="${fail.build.on.error}" >
|
64
|
+
<arg value="${path::get-full-path(file.custom.step.replace + '.rb')}" />
|
65
|
+
</exec>
|
66
|
+
</target>
|
67
|
+
|
68
|
+
<target name="open_visual_studio">
|
69
|
+
<if test="${platform::is-unix()}">
|
70
|
+
<echo message="Opening MonoDevelop with solution file ${solution.path.full}."/>
|
71
|
+
<exec
|
72
|
+
spawn="true"
|
73
|
+
program="${app.monodevelop}"
|
74
|
+
commandline="${project.name}.sln"
|
75
|
+
>
|
76
|
+
</exec>
|
77
|
+
</if>
|
78
|
+
<if test="${platform::is-windows()}">
|
79
|
+
<echo message="Opening visual studio with solution file ${solution.path.full}."/>
|
80
|
+
<exec
|
81
|
+
spawn="true"
|
82
|
+
basedir="${dirs.solution}"
|
83
|
+
program="${app.visual_studio}"
|
84
|
+
commandline="${solution.path.full}"
|
85
|
+
>
|
86
|
+
</exec>
|
87
|
+
</if>
|
88
|
+
</target>
|
89
|
+
|
90
|
+
<target name="custom_tasks_after">
|
91
|
+
<echo message="Running custom tasks if ${file.custom.step.after} exists." />
|
92
|
+
<nant buildfile="${file.custom.step.after}" inheritall="true" if="${file::exists(file.custom.step.after)}" failonerror="${fail.build.on.error}" />
|
93
|
+
<exec program="powershell.exe" if="${file::exists(file.custom.step.after + '.ps1')}" failonerror="${fail.build.on.error}" >
|
94
|
+
<arg value="${path::get-full-path(file.custom.step.after + '.ps1')}" />
|
95
|
+
</exec>
|
96
|
+
<exec program="ruby.exe" if="${file::exists(file.custom.step.after + '.rb')}" failonerror="${fail.build.on.error}" >
|
97
|
+
<arg value="${path::get-full-path(file.custom.step.after + '.rb')}" />
|
98
|
+
</exec>
|
99
|
+
</target>
|
100
|
+
|
101
|
+
<target name="load_uppercut_assemblies">
|
102
|
+
<loadtasks assembly="${path.uppercut.assembly}" if="${file::exists(path.uppercut.assembly)}" />
|
103
|
+
</target>
|
104
|
+
|
105
|
+
<target name="allow_powershell_unrestricted">
|
106
|
+
<!-- powershell 1.0 -->
|
107
|
+
<exec program="powershell.exe" if="${allow.powershell.unrestricted}" failonerror="false">
|
108
|
+
<arg value="set-executionpolicy unrestricted" />
|
109
|
+
</exec>
|
110
|
+
<!-- powershell 2.0 -->
|
111
|
+
<exec program="powershell.exe" if="${allow.powershell.unrestricted}" failonerror="false">
|
112
|
+
<arg value="set-executionpolicy unrestricted -force -scope CurrentUser" />
|
113
|
+
</exec>
|
114
|
+
</target>
|
115
|
+
|
103
116
|
</project>
|