Xdoclet 基本概念
我们可以在 java 代码中使用类似于 javadoc 的注释,来表达更多的内容。这些额外的注释,通过使用 xdoclet 工具,我们可以将它们转换为我们需要的各种配置文件。先看一个简单的例子:
比如有一个 java 文件的源代码如下:
/** * @hibernate.class * table="T_Party" */ public class Party {
/** * @hibernate.id * generator-class="native" */ private int id;
/** * @hibernate.many-to-one * column="parentid" */ private Party parent;
/** * @hibernate.set * @hibernate.key * column = "parentid" * @hibernate.one-to-many * class = "com.bjsxt.oa.model.Party" */ private Set children;
/** * @hibernate.property * column="thename" */ private String name;
/** * @hibernate.property */ private String sn;
/** * @hibernate.property */ private String description;
/** * * @return */ public Set getChildren() { return children; } public void setChildren(Set children) { this.children = children; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; }
/** */ public int getId() { return id; } public void setId(int id) { this.id = id; }
public String getName() { return name; } public void setName(String name) { this.name = name; } public Party getParent() { return parent; } public void setParent(Party parent) { this.parent = parent; } public String getSn() { return sn; } public void setSn(String sn) { this.sn = sn; } }
|
通过 xdoclet ,我们可以得到关于这个类的 Hibernate 映射文件,如下:
<? xml version = "1.0" encoding = "ISO-8859-1" ?> <! DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >
< hibernate-mapping > < class table = "T_Party" name = "com.bjsxt.oa.model.Party" > < id name = "id" > < generator class = "native" /> </ id > < many-to-one column = "parentid" name = "parent" /> < set name = "children" > < key column = "parentid" /> < one-to-many class = "com.bjsxt.oa.model.Party" /> </ set > < property name = "name" column = "thename" /> < property name = "sn" /> < property name = "description" /> </ class > </ hibernate-mapping >
|
如何开始使用 Xdoclet ?
Xdoclet 不是单独可以运行的工具(不像 Ant 工具),它可以与其它工具一起配合运行,如 Ant 。我们下面的例子就是基于 Ant 和 xdoclet 的。
1、 首先需要保证 ant 是可用的
2、 下载并解压 xdoclet 的包(我们现在使用的是 xdoclet2 ,具体版本是 xdoclet-plugins-1.0.3 )。
3、 在 ant 构建工具中定义 xdoclet 任务,并使用:
<?xml version="1.0" encoding="GBK"?> <project name= "OA 系统构建脚本 " default= " 生成 Hibernate 配置文件 " basedir= "." >
<property name= "src.dir" value= "${basedir}/src" /> <property name= "build.dir" value= "${basedir}/bin" /> <property name= "webapp.dir" value= "${basedir}/src/webapp" /> <property name= "xdoclet.home" value= "D:/opensources/xdoclet/xdoclet-plugins-1.0.3" />
<!-- Build classpath --> <path id= "xdoclet.task.classpath" > <fileset dir= "${xdoclet.home}/lib" > <include name= "**/*.jar" /> </fileset> <fileset dir= "${xdoclet.home}/plugins" > <include name= "**/*.jar" /> </fileset> </path> <taskdef name= "xdoclet" classname= "org.xdoclet.ant.XDocletTask" classpathref= "xdoclet.task.classpath" />
<target name= " 生成 Hibernate 配置文件 " > <xdoclet> <fileset dir= "${src.dir}/com/bjsxt/oa/model" > <include name= "**/*.java" /> </fileset> <component classname= "org.xdoclet.plugin.hibernate.HibernateConfigPlugin" destdir= "${src.dir}" version= "3.0" hbm2ddlauto= "update" jdbcurl= "jdbc:mysql://127.0.0.1/oa_200706" jdbcdriver= "com.mysql.jdbc.Driver" jdbcusername= "root" jdbcpassword= "mysql" dialect= "org.hibernate.dialect.MySQLDialect" showsql= "true" /> </xdoclet> </target> <target name= " 生成 hibernate 映射文件 " > <xdoclet> <fileset dir= "${src.dir}/com/bjsxt/oa/model" > <include name= "**/*.java" /> </fileset> <component classname= "org.xdoclet.plugin.hibernate.HibernateMappingPlugin" version= "3.0" destdir= "${src.dir}" /> </xdoclet> </target> </project>
|
以上就是一个完整的可运行的 ant 构建脚本。我们努力来理解这个文件把:
1 、 <property> 标签定义一些变量,这些变量可以通过 ${ 变量名 } 的方式引用
2 、 <path> 标签定义了类路径
3 、 <taskdef> 标签定义了 xdoclet 任务(因为 ant 本身肯定是不包含 xdoclet 任务的)
4 、我们在下面的两个 <target> 中,使用了 <xdoclet> 标签,这个标签正是我们自己定义的。
Xdoclet 可以干什么?
Xdoclet 实际上就是一个自动代码生成的工具,它可以生成各种各样的代码或配置文件(如果你很清楚 xdoclet ,你也可以对它进行扩展)。在默认的情况下, xdoclet 已经给我们提供了很多的解决方案。这些解决方案叫做 plugin ,即插件。在 xdoclet 的官方网站上: http://xdoclet.codehaus.org ,我们可以获得关于它支持的所有的 plugin 的情况。
Xdoclet 通过 plugin 来支持代码的自动生成。我们要使用 xdoclet ,可以将它定义为 ant 的一个任务(如上所述)。然后就可以使用 xdoclet 了。在 <xdoclet> 标签内部使用 xdoclet 。由于 xdoclet 通常用来对源文件进行扫描,并读取源文件中的注释,然后再根据这些注释生成相应的配置文件,所以,通常我们需要定义让 xdoclet 扫描哪些源代码文件。对于这个需要,我们通过 <fileset> 标签来满足!
通过 <component> 标签,我们可以来使用 xdoclet 的众多 plugin 。上述例子,我们使用了 xdoclet 对 hibernate 支持的 plugin 。
具体如何使用这些 plugin ,请参考这些 plugin 的使用手册!!