Eclipse 3.3.0的插件版本问题

Eclipse 3.3.0的插件版本问题
    最近同事被一个问题困恼了很久,让我帮忙看下 , 问题是这样的,我们的平台是基于 Eclipse RCP 3.3.0 ,将每个功能模块作为一个插件工程,系统提供了基于 Http 的自动更新插件的功能,要求在插件更新完成后将旧版本删除掉 ( 我们自己写的版本比较方法 ) ,本来一切运行正常,但是负责部署的同事将插件系统的版本号升级成 4 段,比如以前的版本组成是“ 主版本号 . 次版本号 . 内部版本号 现在发展到 主版本号.次版本号 . 内部版本号 . 构建版本号” 比如将 "3.0.0100" 升级到 "3.0.0100.1", 这时候自动删除旧插件的功能就运行的不正常,比如插件中有个主插件版本号为 3.0.0100.9 启动后可以删除版本号为 "3.0.0100.8" 的插件,而 "3.0.0100.11" 的插件却无法删除 "3.0.0100.9" 的插件。

   其实这和OSGI的版本机制有关系,Eclipse内部插件版本标记和比较是通过"org.eclipse.osgi.*"插件中的Version.java完成的,Version 中的字段major表示主版本号、minor表示次版本号、micro表示微型版本号(内部版本号),这三个字段的类型都是int型的,而Version中的qualifier用来表示构建版本号,类型是字符串,当时如果第四位构建版本号如果是纯数字的话,Eclipse会自动格式化一下,再进行比较,比如比较08和10,格式之后变成8 vs 10,通过字符串的compare方法会得到8比10大7,当然它就会认为"oss.client_ 1.1.1 .08"的版本要比"oss.client_1.1.1.10"高,这可能是Eclipse 3.3.0 版本的一个Bug,我在Eclipse 3.3.2中没有发现这个问题,在Eclipse 3.4 3.5也已经修复好了,如果你使用的是Eclipse 3.3.0并且也有这样的需求的话要小心了。

你可能感兴趣的:(Eclipse 3.3.0的插件版本问题)