OSGi开发中方便查找的一个小工具

本文介绍了一种在OSGi Bundle的manifest.mf文件中使用Eclipse正则表达式进行高效搜索的方法,解决了因文件格式导致的传统搜索无法跨行匹配的问题,并提供了一个辅助生成特殊搜索字符串的小工具。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    一个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());
  }
 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值