我最近的许多时间都花在Reeter项目上了。目前我的注意力主要放在内容编写器上,尤其是支持BEA CMS的编写器。正如平常一样,在开发中我不时地发现,在reeterconfig.xml中,这里需要添加一些东西,那里需要移除一些东西。该文件包含了Reeter所有的储存库和feed信息。现在我经常更改它,而且我发现我必须不断地更改XML Beans以反映新的结构。
经过几次重构后,我开始有Shotgun Surgery的感觉了,我不断地对整个代码树做一些小的更改。我考虑了一下,认为我的问题是,随着功能的发展和贬值等等,这种更改在配置文件中是不可避免的。我非常了解当前的设计,并避免仅仅因为看上去很酷就添加一大堆华而不实的特性,但是目前这是人们所关心的一个重要方面,而且我认为这种趋势会加剧。所以我决定求助于XQuery/XPath和XMLBeans的支持。
经过少量的修改之后,所有对配置文档的调用都通过xquery选择语句进行。这种投资物有所值。昨晚我再次修改了配置模式,我只需更新一个包含所有的xquery选择语句的属性文件。现在我可以集中精力实现编写器,然后就可以将其发布了。
下面的代码片断可以说明,如何利用XQuery/Xpath和XMLBeans来支持所生成的对象之间的松散耦合。
Except from ReeterContext.java
ReeterContext是一个单元素类,它负责维护当前运行的配置,并返回它的数据。下面的方法接受一个关键字(针对ResourceBundle),以供对XMLBean执行所需的xquery。
public String queryConfig(String querykey)
{
XmlCursor cursor = _doc.newCursor();
cursor.toFirstChild();
cursor.selectPath(getXQuery(querykey));
cursor.toNextSelection();
return cursor.getTextValue();
}
现在,如果要从配置文档检索一个值,只需如此:
String repositoryType = ctx.queryConfig("repository.type");
而不是使用我以前所使用的紧密耦合方法:
String repositoryType =
_doc.getReeterConfig().getConfig().getDocument().getRespository().getType();