-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathpom.xml
354 lines (318 loc) · 20.7 KB
/
pom.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
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
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.supermap.idesktop.cross</groupId>
<artifactId>idesktop.cross</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>Assistant</module>
<module>Controls</module>
<module>Core</module>
<module>DataConversion</module>
<module>DataEditor</module>
<module>DataProcess</module>
<module>DataTopology</module>
<module>DataView</module>
<module>Frame</module>
<module>iDesktop</module>
<module>LayoutEditor</module>
<module>LayoutView</module>
<module>LBSClient</module>
<module>MapEditor</module>
<module>MapView</module>
<module>NetServices</module>
<module>RealspaceEditor</module>
<module>RealspaceEffect</module>
<module>RealspaceView</module>
<module>SpatialAnalyst</module>
<module>TabularView</module>
<module>Process</module>
<module>UserExperience</module>
<module>WorkflowView</module>
<module>UserConferenceDemo</module>
</modules>
<properties>
<objects.groupId>com.supermap</objects.groupId>
<objects.version>9.0.0</objects.version>
<bundle.version>1.0.0.qualifier</bundle.version>
</properties>
<!--配置远程仓库地址-->
<repositories>
<repository>
<id>ispeco</id>
<url>http://maven.supermapol.com/</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>ispeco</id>
<url>http://maven.supermapol.com/</url>
</pluginRepository>
</pluginRepositories>
<build>
<!--统一配置子模块的资源打包,不使用 maven-bundle-plugin 的 <Include_Resource> 标签-->
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.png</include>
<include>**/*.gif</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
<pluginManagement>
<plugins>
<!-- maven-compiler-plugin 是默认 compiler,要更改所有 modue 的插件配置,只需要配置 pluginManagement 即可,
无需在 module 里显式配置 compiler plugin。-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
<encoding>utf-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.6</version>
<configuration>
<finalName>${project.name}</finalName>
<!--jar 生成到指定的路径-->
<outputDirectory>${project.basedir}/../bundles/idesktop_bundles/</outputDirectory>
<archive>
<!--使用指定的 manifest 文件-->
<manifestFile>${project.basedir}/src/main/resources/META-INF/MANIFEST.MF</manifestFile>
</archive>
<!--指定打包文件的路径,配置之外的文件不打包,一般不用这个。-->
<!--<includes></includes>-->
</configuration>
</plugin>
<!--maven-bundle-plugin 由于特殊的需求,在 bundles/idesktop_bundles/ 生成了 jar 文件,因此在 clean 的时候需要配置一下清理过程。-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-clean-plugin</artifactId>
<configuration>
<filesets>
<!--核心插件所在路径(Core and Controls and Process and Frame)-->
<fileset>
<directory>${project.basedir}/../bundles/require_bundles/</directory>
<includes>
<include>${project.name}.jar</include>
</includes>
</fileset>
<!--普通插件所在路径-->
<fileset>
<directory>${project.basedir}/../bundles/idesktop_bundles/</directory>
<includes>
<include>${project.name}.jar</include>
</includes>
</fileset>
</filesets>
</configuration>
</plugin>
<!--maven-bundle-plugin 把 bundle 视为可用 classes 的集合,如果有在 src/main/resources/ 之外的非 Java 资源文件,需要自行处理拷贝打包的问题-->
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<version>3.2.0</version>
<extensions>true</extensions>
<!--@formatter:off-->
<!--Packaging = bundle,无需再进行 goal 的绑定。如果 Packaging = jar,则需要绑定 goal 进行 Manifest 文件的生成。-->
<!--<executions>-->
<!--<execution>-->
<!--<id>bundle-package</id>-->
<!--<phase>package</phase>-->
<!--<inherited>true</inherited>-->
<!--<goals>-->
<!--<goal>bundle</goal>-->
<!--</goals>-->
<!--</execution>-->
<!--</executions>-->
<!--@formatter:on-->
<configuration>
<!--
*************************************************************
指定 manifest 文件的生成路径,默认为 ${project.build.outputDirectory}/META-INF。
*************************************************************
-->
<manifestLocation>${project.basedir}/src/main/resources/META-INF</manifestLocation>
<finalName>${project.name}</finalName>
<!--
*************************************************************
生成的 jar 文件所在路径。不显示配置则默认为 project.build.directory,也就是 target。统一默认配置为 bundles/idesktop_bundles/,
以配合 Felix 配置文件 config.properties 的优先级设置,该路径设置 felix.auto.deploy.dir,用以自动发布普通功能性插件。
如有特殊需求则自行配置,如 Core、Controls、Frame 则配置为 bundles/require_bundles/。
*************************************************************
-->
<buildDirectory>${project.basedir}/../bundles/idesktop_bundles/</buildDirectory>
<instructions>
<Manifest-Version>1.0</Manifest-Version>
<!--
*************************************************************
OSGI R4规范这个值只能是2。
*************************************************************
-->
<Bundle-ManifestVersion>2</Bundle-ManifestVersion>
<!--
*************************************************************
不显式配置则默认为 ${pom.name}。
*************************************************************
-->
<Bundle-Name>${project.name}</Bundle-Name>
<!--
*************************************************************
is computed using the shared Maven2OsgiConverter component, which uses the following algorithm:
Get the symbolic name as groupId + "." + artifactId, with the following exceptions:
1. if artifact.getFile is not null and the jar contains a OSGi Manifest with Bundle-SymbolicName property
then that value is returned.
2. if groupId has only one section (no dots) and artifact.getFile is not null then the first package name
with classes is returned. eg. commons-logging:commons-logging -> org.apache.commons.logging.
3. if artifactId is equal to last section of groupId then groupId is returned. eg. org.apache.maven:maven
-> org.apache.maven.
4. if artifactId starts with last section of groupId that portion is removed. eg. org.apache.maven:maven-core
-> org.apache.maven.core The computed symbolic name is also stored in the $(maven-symbolicname) property
in case you want to add attributes or directives to it.
*************************************************************
-->
<!--<Bundle-SymbolicName></Bundle-SymbolicName>-->
<!--
*************************************************************
不显式配置则默认 ${pom.version},按 "MAJOR.MINOR.MICRO.QUALIFIER" 的形式格式化。
Bundle-Version 和 Bundle-SymbolicName 共同作为一个 Bundle 的唯一标识。
*************************************************************
-->
<Bundle-Version>${bundle.version}</Bundle-Version>
<!--
*************************************************************
不显式配置则默认 ${pom.description}。
*************************************************************
-->
<Bundle-Description>${project.description}</Bundle-Description>
<!--########## 该项子模块必须自定义 ##########-->
<!--<Bundle-Activator></Bundle-Activator>-->
<!--
*************************************************************
不显式配置则默认为 ${pom.organization.name}。
*************************************************************
-->
<Bundle-Vendor>${project.organization.name}</Bundle-Vendor>
<!--
*************************************************************
不显式配置则默认为 ${pom.organization.url}。
*************************************************************
-->
<Bundle-DocURL>${project.organization.url}</Bundle-DocURL>
<!--
*************************************************************
打包的资源文件,默认打包 maven 资源目录,也就是 src/main/resources/ 里的内容。
该配置与 maven-resources-plugin 互斥,并且没有 maven-resources-plugin 灵活,同时配置则以 maven-resources-plugin 为准。
建议使用 maven-resources-plugin,也就是 <Resources></Resources> 配置项。
*************************************************************
-->
<!--<Include-Resource>{maven-resources}</Include-Resource>-->
<!--
*************************************************************
1. Requre-Bundle 为导入整个 Bundle,Import-Package 为导入指定的包,Import-Package更为灵活。
2. Import-Package 默认为 *,也就是导入所有引用的包,包括配置的依赖,但这些依赖并非 bundle,不能 Import。
3. Require-Bundle 所导入的整个包,可以重复导出该 Bundle 已导出过的包,但这样会导致 Required Bundle inline,maven-bundle-plugin 还是不够智能。
*************************************************************
-->
<!--<Require-Bundle></Require-Bundle>-->
<!--
*************************************************************
is assumed to be "*", which imports everything referred to by the bundle content, but not contained in the bundle.
Any exported packages are also imported by default, to ensure a consistent class space.
*************************************************************
-->
<Import-Package>
org.osgi.framework,
org.osgi.util.tracker
</Import-Package>
<!--
*************************************************************
不显式配置则默认导出本地源代码里的包,使用 {local-packages} 表示本地包
Export-Package 和 Private-Package 会将所配置的包以内联(inline)的形式打到包里。
由于 OSGI bundle 间依赖的特殊性,类似Controls 对 Core 的非直接依赖会导致的编译时依赖错误。
在 eclipse 或者 IDEA 等均有各自的依赖规则以及编译器处理 jar in jar 的依赖问题,maven-compiler-plugin 没有这样的特性。
两种方案:
1. Core 直接依赖第三方库,并在打包时 inline 第三方库,其他 bundle 均 Require-Bundle Core 或者 Import-Pakcage 使用 Core 导出的 package;
目前采用这个方案。
2. 所有 Bundle 均配置对应第三方库的依赖,打包的时候,将所有的依赖打包到指定的路径,不再 inline 或者 jar in jar。
3. 如果打包的时候有需求打包为 jar in jar 的形式,则使用 _exportcontents + Embed-Dependency 进行灵活处理。
4. 本项目采用依赖 inline 的方式来解决 jar in jar 编译时依赖错误的问题(见备注 1),并默认所有子模块导出本地包,并按需导出第三方依赖包。也即 Core
导出本地包+第三方包,Controls 导出本地包,由此来解决 Controls 重复导出 Core 中包的问题。
5. 本项目默认不导出任何包,子模块按需求自行配置。
6. Export-Package 只会 inline 代码,而相关的一些 properties 等资源文件则不会打到包里,因此需要配合 Embed-Dependency inline=true 使用。
*************************************************************
-->
<Export-Package>!*</Export-Package>
<!--
*************************************************************
1. BND 的 exported 配置,功能与 Exported-Pakcage 一致,只是不处理依赖包的内联(inline),通常与 Embed-Dependency 搭配使用,
避免因为 Exported-Package 的依赖内联,导致与 Embed-Dependency的相同包重复。
2. 由于 Export-Package 会导致被导出的包内联,因此如果 Controls 导出了 Core 里的某些内容,则会导致 Core 的 inline,产生重复,因此可以使用
_exportcontents + Embed-Dependency 来进行更为灵活的处理。
*************************************************************
-->
<!--<_exportcontents></_exportcontents>-->
<!--
*************************************************************
Private-Package 默认为源码里 exported 之外的所有包。exported 的优先级高于 private,如果有相同的配置,则 exported 生效。
*************************************************************
-->
<!--<Private-Package></Private-Package>-->
<!--
*************************************************************
需要注意的是 inline=true,设置这个属性的原因见 <Export-Package> 备注。
*************************************************************
-->
<Embed-Dependency>*;scope=compile|system</Embed-Dependency>
<!--
*************************************************************
指定 Embed 依赖相对包的根目录的路径。
*************************************************************
-->
<Embed-Directory>lib</Embed-Directory>
<!--
*************************************************************
配置 Embed 的依赖传递。
*************************************************************
-->
<Embed-Transitive>true</Embed-Transitive>
<!--
*************************************************************
禁用 Require-Capability,这个属性是 Bundle 运行的环境约束,BND 会根据编译版本以及相关依赖包自动生成,很多时候生成的内容并不是我们想要的。
1. 本项目可以约定为 1.7,即如下的 <Require-Capability> 配置。
2. 本项目也可以直接禁用 Require-Capability,如下使用 <_noee>true</_noee> 配置,默认采用这种方案。
*************************************************************
-->
<!--<Require-Capability>osgi.ee;filter:="(&(osgi.ee=JavaSE)(version=1.7))"</Require-Capability>-->
<_noee>true</_noee>
</instructions>
</configuration>
</plugin>
</plugins>
</pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>