我最近的许多时间都花在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();
闽公网安备 35060202000074号