Java代碼生成利器之rapid-generate應用三

rapid-generate主要特性介紹:

一. 生成器模板路徑可以引用相關變量
basepackage/ {className}.java,根據該變量生成輸出文件

二. 自動搜索某個目錄所有模板文件,無需配置

三.代碼生成器模板可以引用的相關變量

  1. g.generateByTable(“table_name”) 方法可以引用的變量
table : cn.org.rapid_framework.generator.provider.db.table.model.Table

  2. g.generateByClass(UserInfo.class) 方法可以引用的變量
clazz : cn.org.rapid_framework.generator.provider.java.model.JavaClass

  3. g.generateBySql(“select * from user_info where pwd=:pwd”) 方法可以引用的變量
sql : cn.org.rapid_framework.generator.provider.db.sql.model.Sql

  4.公共變量
  env : 系統環境變量
  System.getProperties() : 直接引用,沒有前綴
  generator.properties 文件中的所有屬性,直接引用,沒有前綴
  gg : 模板控制變量,
  cn.org.rapid_framework.generator.GeneratorControl

四.每個模板有gg變量可以控制自身的自定義配置 (每一個模板都會創建新的gg實例)
如是否生成,是否覆蓋目標文件,甚至是生成其它文件
gg.setIgnoreOutput(true):true {gg.generateFile(outputFile,content)} 在模板中生成其它文件
gg.getProperty(key,defaultValue):proproty, {gg.getInputProperty(key)}: 會彈出一個輸入框,提示用戶輸入值
具體參考: http://code.google.com/p/rapid-framework/wiki/rapid_generator_gg

五.支持生成(gen)及刪除操作(del),即生成的代碼也可以很方便的刪除

六. 自動刪除模板擴展名: .ftl,.vm
舉例: 如你有一個模板 SqlMap.xml.ftl 將變爲 SqlMap.xml
所以你要生成ftl擴展名的文件,應該將文件名從 list.ftl => list.ftl.ftl

七. 模板自動include所有父目錄的:macro.include文件,可以存放公共的macro
示例: 如你的模板爲 com/project/UserDao.java, 將自動include: com/project/macro.include, com/macro.include, macro.include

八. generator.xml (或者generator.properties)配置文件
1.類似ant可以變量引用,引用環境變量使用${env.JAVA_HOME}, 引用System.getProperties()直接引用
2.自動替換generator.properties中的句號(.)爲反斜槓,設置key爲key+”_dir”後綴
示例: pkg=com.company => pkg_dir=com/company

九.自動拷貝二進制文件至輸出目錄
如模板目錄下的 zip,rar,doc文件將會自動拷貝至輸出目錄,不會破壞文件格式 (通過擴展名自動識別)

十. 數據庫表配置,用於自定義生成器模板引用的table變量,配置文件必須存放在classpath: generator_config/table/table_name.xml
(該文件生成器可以生成,自己再自定義修改)

<!--
<數據庫表名 className="類名稱" tableAlias="表的別名">
    <數據庫列名 columnAlias="列的別名"
    javaType="自定義javaType"
    unique="是否唯一性約束" nullable="是否可以爲空" pk="是否主鍵,在表沒有主鍵的情況下,可以指定一個代理主鍵"
    updatable="是否可以更新" insertable="是否插入"    
    enumString="枚舉值,以分號分隔,示例值:M(1,男);F(0,女) 或者是:M(男);F(女)"
    enumClassName="如果枚舉有值,生成的類名稱將是這個,沒有枚舉值,該配置無用.示例值:Sex"
    />
</數據庫表名>
 -->
<user_info className="UserInfo" tableAlias="用戶信息" >
    <username columnAlias="用戶名"
        javaType="String"
        unique="false" nullable="true" pk="false"
        updatable="true" insertable="true"
        enumString="F(1,Female);M(0,Male)" enumClassName="用戶枚舉"
    />
    <password columnAlias="密碼"
        javaType="String"
        unique="false" nullable="true" pk="false"
        updatable="true" insertable="true"
        enumString="" enumClassName="PasswordEnum"
    />
</user_info>
發佈了52 篇原創文章 · 獲贊 12 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章