一个OSGi bundle可能会有大量的引入、导出包,这会使它的manifest.mf文件很长,让人看得眼花缭乱,于是我们经常需要在其中查找一些东西,但是由于manifest.mf文件本身的原因,给查找带来一些麻烦,比如下面从manifest.mf的“DynamicImport-Package”中摘取出的一小段(还有很长,但没必要全列在这里了):
, javax.xml.parsers, javax.xml.transform, javax.xml.transform.dom, ja
vax.xml.transform.sax, javax.xml.transform.stream, javax.xml.validati
on, javax.xml.xpath,jp.co.swiftinc.relax.schema, jp.co.swiftinc.relax
.verifier, kaffe.rmi.rmic, org.apache.avalon.framework.logger, org.ap
ache.bcel.classfile, org.apache.bsf, org.apache.env, org.apache.log,
org.apache.tools.ant.launch, org.apache.tools.ant.taskdefs.optional,
若我们要在其中找“apache”,第四行最后和第五行开始实际上有一个“apache”然而,由于它跨在两行,且第五行开头还有一个空格,用eclipse的一般查找是找不到这个的。为什么会这样跨行以至于把一个单词都分在两行呢,是因为这是用bnd做出的一个bundle,bnd做出的manifest.mf就是这个风格。
我们利用eclipse的正则表达式查找来解决这个问题。以上面的例子说,这需要把查找字串由“apache”变成“a/s*p/s*a/s*c/s*h/s*e”,如果要找的串比较长的话,这是比较麻烦的事情。于是我们编了一个java小程序来解决这个问题,该程序从键盘读入要找的字串,自动向中间添加“/s*”,代码如下:
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int i, lenOfStr;
while (true) {
System.out.print("Please input a string in a line:");
String str = in.nextLine();
lenOfStr = str.length();
StringBuffer strBuf = new StringBuffer();
if (lenOfStr > 0) {
for (i = 0; i < lenOfStr - 1; i++) {
strBuf.append(str.charAt(i));
strBuf.append("//s*");
}
strBuf.append(str.charAt(i));
}
System.out.println(strBuf.toString());
}
}