`
happmaoo
  • 浏览: 4508204 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

使用XDoclet生成代码

阅读更多
<iframe align="top" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog01.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>
  转EasyJF团队stef_wu的一篇文章!
在最近的一个项目中,使用了hibernate+struts,由于中间没有使用spring来管理bean,所以我使用了DAO+Service来做持久层和业务层。受spring对hibernate的template的封装的影响,我自己实现了一个简单的hibernateTemplate——MHibernateTemplate和调用接口MHibernateCallback。在其中包装了错误拦截等动作。所以我的DAO就不能直接从Myecipse生成了。但由于Domain bean太多,而且DAO中又是简单的代码重复,所以想到了使用代码生成。刚开始想直接在Myeclipse中生成DAO的时候使用自己的模版就可以了,但是在网上找了半天都没有相关的信息。后来模仿easyjtools使用velocity自己做代码生成,但感觉时间不够,所以,就选择了XDoclet。
网上相关的内容不是很多,所以就只有啃En版的XDoclet in Action。由于我的需求很简单,所以只使用了简单的template(就是.xdt)来生成代码,搞了两天,效果还不错。
比如一个model:(这个项目的需求比较奇怪,由于要同步,所以每个对象都必须有一个pkid(包括中间表),2就是每个对象有个dr标志,表示删除(而不是真正的删除))。
package com.my.xdoclet;
/**
*PubComppropergeneratedbyMyEclipse-HibernateTools
*@hasRef
*公司性质
*/
publicclassPubCompproperextends BaseDomain implements java.io.Serializable {
// Fields
/**
*@pkid
*/
private String cproPkid;
//系统类型信息
/**
*@ref.modelname="sytp"
*/
private PubSystype sytp;
//公司性质编码
private String cproCode;
//公司性质名称
private String cproName;
//删除表示
/**
*@del
*/
private String cproDr;
// Constructors
/**defaultconstructor*/
public PubCompproper() {
this.setCproDr("0");
}
// Property accessors
public String getCproPkid() {
returnthis.cproPkid;
}
publicvoid setCproPkid(String cproPkid) {
this.cproPkid = cproPkid;
}
public String getCproCode() {
returnthis.cproCode;
}
publicvoid setCproCode(String cproCode) {
this.cproCode = cproCode;
}
public String getCproName() {
returnthis.cproName;
}
publicvoid setCproName(String cproName) {
this.cproName = cproName;
}
/**
*@returnthesytp
*/
public PubSystype getSytp() {
returnsytp;
}
/**
*@paramsytpthesytptoset
*/
publicvoid setSytp(PubSystype sytp) {
this.sytp = sytp;
}
/**
*@returnthecproDr
*/
public String getCproDr() {
returncproDr;
}
/**
*@paramcproDrthecproDrtoset
*/
publicvoid setCproDr(String cproDr) {
this.cproDr = cproDr;
}
}
其中有一些相关的对象,在DAO中要使用到。
看看模版文件
package com.hycs.bs.client.itf;
import java.util.List;
import <packagename></packagename>.<classname></classname>;
public interface <classname></classname>DAO {
//添加
boolean add(<classname></classname> instance);
<ifhasclasstag tagname="hasRef"></ifhasclasstag>
//添加
boolean add(<classname></classname> instance,<forallfields><ifhasfieldtag tagname="ref.model" paramname="name"> String <fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>pkid</ifhasfieldtag></forallfields>);
//删除
boolean del(String pkid);
//更新
boolean update(<classname></classname> instance);
//列出所有
List list();
List list(boolean withDr);
//得到一个对象
<classname></classname> get(String pkid);
}
这个是interface的模版,其中的模版标签都很简单易懂;
<tagdef namespace="Primitive" handler="com.my.xdoclet.customTags.UpperName"></tagdef>
package com.hycs.bs.client.call;
import com.hycs.bs.sys.MHibernateTemplate;
import com.hycs.util.Constant;
import com.hycs.util.OidHelper;
import com.hycs.bs.sys.HibernateCodeUtil;
import com.hycs.bs.sys.HibernateUtil;
public class <classname></classname>DAOImpl implements <classname></classname>DAO{
private MHibernateTemplate template;
<forallfields></forallfields>
<ifhasfieldtag tagname="ref.model" paramname="name"></ifhasfieldtag>
private final <fieldtype></fieldtype>DAO <fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>dao = new <fieldtype></fieldtype>DAOImpl();
public <classname></classname>DAOImpl(){
this.template=new MHibernateTemplate(HibernateUtil.getSessionFactory());
}
public boolean add(<classname></classname> instance) {
// TODO Auto-generated method stub
// add your code and pkid generhere;
//instance.setCproCode(HibernateCodeUtil.getLastCode("PubCompproper", "cproCode", "cproPkid"));
//instance.setCproPkid(OidHelper.oidSingle());
return this.template.save(instance);
}
<ifhasclasstag tagname="hasRef"></ifhasclasstag>
public boolean add(<classname></classname> instance, <forallfields><ifhasfieldtag tagname="ref.model" paramname="name"> String <fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>pkid</ifhasfieldtag></forallfields>) {
// TODO Auto-generated method stub
<forallfields></forallfields>
<ifhasfieldtag tagname="ref.model" paramname="name"></ifhasfieldtag>
<fieldtype></fieldtype><fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>=this.<fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>dao.get(<fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>pkid);
if(<fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>==null){
return false;
}
instance.set<uppername value='&lt;XDtField:fieldTagValue tagName="ref.model" paramName="name" /&gt;'></uppername>(<fieldtagvalue tagname="ref.model" paramname="name"></fieldtagvalue>);
return this.add(instance);
}
public boolean del(String pkid) {
// TODO Auto-generated method stub
<classname></classname> instance =this.get(pkid);
if(instance==null||instance.get<forallfields><ifhasfieldtag tagname="pkid"><uppername value="&lt;XDtField:fieldName /&gt;"></uppername></ifhasfieldtag></forallfields>==null){
return false;
}
instance.set<forallfields><ifhasfieldtag tagname="del"><uppername value="&lt;XDtField:fieldName /&gt;"></uppername></ifhasfieldtag></forallfields>(Constant.MODEL_DEL);
return this.template.update(instance);
}
public <classname></classname> get(String pkid) {
// TODO Auto-generated method stub
return (<classname></classname>)this.template.get(<classname></classname>.class, pkid);
}
public List list() {
// TODO Auto-generated method stub
return this.list(true);
}
public List list(boolean withDr) {
// TODO Auto-generated method stub
if(withDr){
return HibernateCodeUtil.listWithDr("<classname></classname>","<forallfields><ifhasfieldtag tagname="del"><fieldname></fieldname></ifhasfieldtag></forallfields>" );
}else{
return this.template.getAll(<classname></classname>.class);
}
}
public boolean update(<classname></classname> instance) {
// TODO Auto-generated method stub
<ifhasclasstag tagname="hasRef"></ifhasclasstag>
<classname></classname> temp=this.get(instance.get<forallfields><ifhasfieldtag tagname="pkid"><uppername value="&lt;XDtField:fieldName /&gt;"></uppername></ifhasfieldtag></forallfields>());
<forallfields></forallfields>
<ifhasfieldtag tagname="ref.model" paramname="name"></ifhasfieldtag>
if(instance.get<uppername value='&lt;XDtField:fieldTagValue tagName="ref.model" paramName="name" /&gt;'></uppername>()==null){
instance.set<uppername value='&lt;XDtField:fieldTagValue tagName="ref.model" paramName="name" /&gt;'></uppername>(temp.get<uppername value='&lt;XDtField:fieldTagValue tagName="ref.model" paramName="name" /&gt;'></uppername>());
}
return this.template.update(instance);
}
}
这是个比较复杂的模版了,是DAO的具体实现,
在写这个模版的时候,我遇到了几个问题,
1 就是标签的嵌套,比如<uppername value='&lt;XDtField:fieldTagValue tagName="ref.model" paramName="name" /&gt;'></uppername>,开始内部标签都使用转义符,结果搞不定,网上找没有任何相关的内容,后来直接在外层使用(就象js),搞定。
2 就是对于标签的内容的首字符大写,没有提供这个功能的标签,使用了自定义的:
package com.my.xdoclet.customTags;
import java.util.Properties;
import xdoclet.XDocletTagSupport;
public class UpperName extends XDocletTagSupport {
public String upperName(Properties attribute){
String value=attribute.getProperty("value");
String upper= upper(value);
return upper;
}
private static String upper(String value){
return value.toUpperCase().substring(0,1)+value.substring(1);
}
}
并在模版文件中使用<tagdef namespace="Primitive" handler="com.my.xdoclet.customTags.UpperName"></tagdef>来应用就直接能在模版文件中使用<uppername></uppername>来使用了,
下面是bulid.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<project><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"xdocletExample"</span><span style="FONT-SIZE: 10pt; COLOR: navy">default=</span><span style="FONT-SIZE: 10pt; COLOR: green">"doall"</span><span style="FONT-SIZE: 10pt; COLOR: navy">basedir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"."</span><span style="FONT-SIZE: 10pt; COLOR: navy">&gt;</span></project>
<property><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"xdoclet.lib.dir"</span><span style="FONT-SIZE: 10pt; COLOR: navy">location=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${basedir}/lib"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></property>
<property><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"gen.src.dir"</span><span style="FONT-SIZE: 10pt; COLOR: navy">location=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${basedir}/target"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></property>
<property><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"src.dir"</span><span style="FONT-SIZE: 10pt; COLOR: navy">location=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${basedir}/src"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></property>
<property><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"template.dir"</span><span style="FONT-SIZE: 10pt; COLOR: navy">location=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${basedir}/template"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></property>
<property><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"customtag.dir"</span><span style="FONT-SIZE: 10pt; COLOR: navy">location=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${basedir}/bin"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></property>
id="xdoclet.lib.path">
<fileset><span style="FONT-SIZE: 10pt; COLOR: navy">dir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${xdoclet.lib.dir}"</span><span style="FONT-SIZE: 10pt; COLOR: navy">includes=</span><span style="FONT-SIZE: 10pt; COLOR: green">"*.jar"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></fileset>
<taskdef><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"xdoclet"</span><span style="FONT-SIZE: 10pt; COLOR: navy">classname=</span><span style="FONT-SIZE: 10pt; COLOR: green">"xdoclet.DocletTask"</span><span style="FONT-SIZE: 10pt; COLOR: navy">classpathref=</span><span style="FONT-SIZE: 10pt; COLOR: green">"xdoclet.lib.path"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span><span style="FONT-SIZE: 10pt; COLOR: black"> </span></taskdef>
<target><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"init"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></target>
<target><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"daogener"</span><span style="FONT-SIZE: 10pt; COLOR: navy">depends=</span><span style="FONT-SIZE: 10pt; COLOR: green">"init"</span><span style="FONT-SIZE: 10pt; COLOR: navy">&gt;</span></target>
<xdoclet><span style="FONT-SIZE: 10pt; COLOR: navy">destdir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${gen.src.dir}"</span><span style="FONT-SIZE: 10pt; COLOR: navy">&gt;</span></xdoclet>
<fileset><span style="FONT-SIZE: 10pt; COLOR: navy">dir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${src.dir}"</span><span style="FONT-SIZE: 10pt; COLOR: navy">includes=</span><span style="FONT-SIZE: 10pt; COLOR: green">"**/*.java"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></fileset>
<template><span style="FONT-SIZE: 10pt; COLOR: navy">templateFile=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${template.dir}/daointerface.xdt"</span><span style="FONT-SIZE: 10pt; COLOR: navy">acceptInterfaces=</span><span style="FONT-SIZE: 10pt; COLOR: green">"false"</span><span style="FONT-SIZE: 10pt; COLOR: navy">acceptAbstractClasses=</span><span style="FONT-SIZE: 10pt; COLOR: green">"false"</span><span style="FONT-SIZE: 10pt; COLOR: navy">destinationfile=</span><span style="FONT-SIZE: 10pt; COLOR: green">"{0}DAO.java"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></template>
<target><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"daoimplgener"</span><span style="FONT-SIZE: 10pt; COLOR: navy">depends=</span><span style="FONT-SIZE: 10pt; COLOR: green">"init"</span><span style="FONT-SIZE: 10pt; COLOR: navy">&gt;</span></target>
<xdoclet><span style="FONT-SIZE: 10pt; COLOR: navy">destdir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${gen.src.dir}"</span><span style="FONT-SIZE: 10pt; COLOR: navy">&gt;</span></xdoclet>
<fileset><span style="FONT-SIZE: 10pt; COLOR: navy">dir=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${src.dir}"</span><span style="FONT-SIZE: 10pt; COLOR: navy">includes=</span><span style="FONT-SIZE: 10pt; COLOR: green">"**/*.java"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></fileset>
<template><span style="FONT-SIZE: 10pt; COLOR: navy">templateFile=</span><span style="FONT-SIZE: 10pt; COLOR: green">"${template.dir}/daoimpl.xdt"</span><span style="FONT-SIZE: 10pt; COLOR: navy">acceptInterfaces=</span><span style="FONT-SIZE: 10pt; COLOR: green">"false"</span><span style="FONT-SIZE: 10pt; COLOR: navy">acceptAbstractClasses=</span><span style="FONT-SIZE: 10pt; COLOR: green">"false"</span><span style="FONT-SIZE: 10pt; COLOR: navy">destinationfile=</span><span style="FONT-SIZE: 10pt; COLOR: green">"{0}DAOImpl.java"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></template>
<target><span style="FONT-SIZE: 10pt; COLOR: navy">name=</span><span style="FONT-SIZE: 10pt; COLOR: green">"doall"</span><span style="FONT-SIZE: 10pt; COLOR: navy">depends=</span><span style="FONT-SIZE: 10pt; COLOR: green">"daogener,daoimplgener"</span><span style="FONT-SIZE: 10pt; COLOR: navy">/&gt;</span></target>
build一下:
生成的代码如下:
package com.hycs.bs.client.itf;
import java.util.List;
import com.my.xdoclet.PubCompproper;
public interface PubCompproperDAO {
//添加
boolean add(PubCompproper instance);
//添加
boolean add(PubCompproper instance, String sytppkid);
//删除
boolean del(String pkid);
//更新
boolean update(PubCompproper instance);
//列出所有
List list();
List list(boolean withDr);
//得到一个对象
PubCompproper get(String pkid);
}
这个是接口
package com.hycs.bs.client.call;
import com.hycs.bs.sys.MHibernateTemplate;
import com.hycs.util.Constant;
import com.hycs.util.OidHelper;
import com.hycs.bs.sys.HibernateCodeUtil;
import com.hycs.bs.sys.HibernateUtil;
public class PubCompproperDAOImpl implements PubCompproperDAO{
private MHibernateTemplate template;
private final com.my.xdoclet.PubSystypeDAO sytpdao = new com.my.xdoclet.PubSystypeDAOImpl();
public PubCompproperDAOImpl(){
this.template=new MHibernateTemplate(HibernateUtil.getSessionFactory());
}
public boolean add(PubCompproper instance) {
// TODO Auto-generated method stub
// add your code and pkid generhere;
//instance.setCproCode(HibernateCodeUtil.getLastCode("PubCompproper", "cproCode", "cproPkid"));
//instance.setCproPkid(OidHelper.oidSingle());
return this.template.save(instance);
}
public boolean add(PubCompproper instance,String sytppkid) {
// TODO Auto-generated method stub
com.my.xdoclet.PubSystype sytp=this.sytpdao.get(sytppkid);
if(sytp==null){
return false;
}
instance.setSytp(sytp);
return this.add(instance);
}
public boolean del(String pkid) {
// TODO Auto-generated method stub
PubCompproper instance =this.get(pkid);
if(instance==null||instance.getCproPkid==null){
return false;
}
instance.setCproDr(Constant.MODEL_DEL);
return this.template.update(instance);
}
public PubCompproper get(String pkid) {
// TODO Auto-generated method stub
return (PubCompproper)this.template.get(PubCompproper.class, pkid);
}
public List list() {
// TODO Auto-generated method stub
return this.list(true);
}
public List list(boolean withDr) {
// TODO Auto-generated method stub
if(withDr){
return HibernateCodeUtil.listWithDr("PubCompproper","cproDr" );
}else{
return this.template.getAll(PubCompproper.class);
}
}
public boolean update(PubCompproper instance) {
// TODO Auto-generated method stub
PubCompproper temp=this.get(instance.getCproPkid());
if(instance.getSytp()==null){
instance.setSytp(temp.getSytp());
}
return this.template.update(instance);
}
}
这个是代码。
于是我的工作就很简单了,适用Myeclipse 直接从DataExplor中生成Domain bean和映射文件,改一下关联,在domain中添加必要的XDoclet标记,build,就可以专著于具体的业务了。
但这个代码还有点问题就是当遇到一个类有多个关联对象的时候,在生成的一些方法上,要自己手动增加或者删除一个”,”。这个还要继续学习。
同时XDoclet提供了很好的扩展机制,这个也要继续研究。
再次就是我在想XDoclet中有没有直接使用标签来定义标签的功能,或者在模版内定义变量??
easyjweb使用XDoclet来生成代码也会是很简单而且稳定的。

(注:本文作者,EasyJF开源团队 stef_wu,转载请保留作者声明!)



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1417397


分享到:
评论

相关推荐

    Hibernate使用xdoclet生成映射文件和sql语句

    《使用Hibernate和XDoclet生成映射文件与SQL语句详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,为了实现对象与数据库表之间的映射,我们需要编写XML映射...

    Java通用代码生成实用程序XDoclet(源码包)

    XDoclet 继承了 JavaDoc 引擎的思想,允许根据定制 JavaDoc 标记生成代码和其他文件。当然,XDoclet 也可以访问整个解析树。这样,它就可以访问类、类的包结构和类的方法。 Xdoclet由三个主要组件组成、Xjavadoc...

    xdoclet 生成hbm文件

    本文将详细介绍如何在MyEclipse环境中利用XDoclet生成HBM文件。 首先,确保你的开发环境是Eclipse 3.0.1和MyEclipse 3.8.3。这两个工具集成了对XDoclet的支持,使得生成HBM文件变得简单易行。根据Hibernate ...

    Xdoclet生成*.hbm.xml映射文件

    随着Hibernate的发展,它推荐使用注解(Annotation)直接在Java类上进行ORM配置,取代了Xdoclet生成映射文件的方式。因此,尽管Xdoclet仍有一定的实用性,但在现代开发环境中,直接使用Hibernate注解已成为主流。 ...

    XDOCLET的使用例子

    Eclipse会自动检测源代码中的注释,并在编译期间调用XDoclet生成相应的配置或代码文件,这样可以保持源代码与生成文件的一致性。 **Ant任务** Ant是Apache软件基金会的构建工具,它以XML为基础定义构建过程。在...

    使用xDoclet自动生成Spring的bean的配置文件

    通过在Java类上添加xDoclet特定的注解,我们可以指示xDoclet生成这些配置信息。例如,使用`@Service`、`@Repository`、`@Controller`等注解来标记业务层、数据访问层和控制层的类,xDoclet会根据这些注解生成对应的...

    精通代码生成器XDoclet.doc

    XDoclet 的核心功能是根据以下组合来生成代码的(或者生成其他配置/数据文件):进行特殊标记的 Java 源文件和预先定义的模板。与其他基于模板的代码生成技术相比,XDoclet 具有以下独特优势: * XDoclet 与 Apache...

    Xdoclet生成SessionBean 和 EntityBean代码(初识ejb)

    【Xdoclet生成SessionBean和EntityBean代码(初识ejb)】 Xdoclet是一个强大的文档生成工具,尤其在Java Enterprise Edition(JEE)环境中,它能够自动生成EJB(Enterprise JavaBeans)所需的代码和配置文件,从而...

    可以产生xdoclet 的代码提示doclipse

    5. **生成文件**:使用Doclipse的菜单选项或快捷键,触发XDoclet生成相应的配置文件或文档。 6. **检查与调试**:通过Eclipse的错误视图查看和解决由XDoclet注释引起的任何问题。 **总结:** XDoclet和Doclipse是...

    Ant+XDoclet生成hbm文件

    在使用Ant和XDoclet生成HBM文件的过程中,通常包含以下几个步骤: 1. **配置XDoclet插件**:在Ant的build.xml文件中,我们需要添加一个xdoclet任务。这通常涉及到引入xdoclet的JAR文件作为依赖,并配置任务参数,如...

    Xdoclet入门基础教程

    Xdoclet 是一款 Java 开发工具,允许开发者使用特殊的注释来生成配置文件、文档和其他相关资源。在本教程中,我们将学习 Xdoclet 的基本概念和使用方法。 什么是 Xdoclet? Xdoclet 是一种基于 Java 的工具,用于...

    xdoclet 用于生成*.hbm.xml

    例如,一个简单的使用xdoclet生成.hbm.xml的例子可能如下: ```java /** * @hibernate.class table="User" */ public class User { /** * @hibernate.id generator-class="increment" */ private int id; ...

    xdoclet-src-1.2.1.zip eclipse

    3. **模板**:XDoclet使用FreeMarker模板语言来生成代码。模板文件定义了生成代码的具体结构和内容。研究这些模板,开发者可以定制自己的代码生成规则,以适应特定的项目需求。 4. **Eclipse插件**:虽然xdoclet-...

    XDoclet2辅助开发hibernate3

    XDoclet2是XDoclet的升级版,它基于JavaDoc注解,提供了一种强大的方式来生成代码和配置文件。在Hibernate3的上下文中,XDoclet2可以从类和接口的JavaDoc注释中提取信息,然后自动创建对应的Hibernate配置文件,如...

    xdoclet-1.2.6.jar

    EJBDoclet是早期的一个用于自动生成EJB组件元数据的工具,而XDoclet则进一步扩展了这一概念,使得它能够为多种Java框架自动生成代码和配置文件,极大地提高了开发效率。 XDoclet的核心理念在于通过在Java源代码中...

Global site tag (gtag.js) - Google Analytics