欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ruby生成java文件的工具

程序员文章站 2022-07-15 11:24:36
...
java开发的很多代码都是可以通过工具来生成的,虽然eclipse在这方面有些帮助,但其能力还是太有限,在本人学习ruby期间发现使用ruby来写个自动化的生成工具确实是个很不错的主意。由于公司使用的oracle+ibatis的持久层开发,所以本人开始的时间只是想生成一下ibatis的sqlmap的XML文件就可以了,但后来一想,其实service、dao、controller甚至JSP都可以完成大部分的有效生成。但即便如此,这个工具的代码量还是很小的,几乎是相当的容易。
由于本人主要是做JAVA的,所以ruby这个东西过段时间就忘了,可能再到以后再要想搞这么个工具,又得从头再来,所以决定把大体思路写下来。
其中涉及到的东西主要有几下几个:
1.读取配置文件。由于windows下的tcl/tk非常的难用(是本人目前用过的最难用的API之一),所以觉得还是用配置文件算了。XML不错,但结构有点复杂,所以本人使用的是yaml格式配置文件,感觉其与json有点相似。大体格式如下:
#tnsnames.ora, yaml要求冒号后面要有空格,仅用于测试数据库
tns : ORCL181
table : PAY_WAY_COL
domain_pack: com 

由于yaml是ruby标准库自带的,所以不需要再安装gem,只要在使用时用require引入即可。
2.连接数据库组件。连接oracle时,除了需要dbi以外,还需要oci8这个gem,因此这个得自己手动安装。
3.将ruby程序打包成exe文件,这个需要个叫exerb的组件,其用法可见下面文章:
http://jimmykuu.iteye.com/blog/51526
4.生成java需要的技术。生成xml文件是可以使用rexml,这个在本人以前的博客中也讲过,生成java文件时,除了可以使用普通的puts "xxxx"输出到文件以外,还可以使用erb模版技术,本人也两种都试了下,感觉erb模版方法可能更好一些。

除了上面这些问题外,就剩下写代码了,下面贴出生成文件的主要结构代码:
=begin
dao service controller domain sqlmap ...
=end
$LOAD_PATH.unshift(File.dirname(__FILE__)) unless $LOAD_PATH.include?(File.dirname(__FILE__))

require 'dbi'
require 'oci8'
require "yaml"

require "sqlmap"
require "domain"
require "dao_service"
require "xml_service"
require "controller"
require "bean_util"
require "list"
require "form_jsp"

class CrudModel

	def initialize(tns,table,dpack,crud_pack,author)
		@tns = tns
		@table=table
		@clazz=BeanUtils.class_name(table)
		@name=BeanUtils.bean_name(table)
		#domain package
		@dpack=dpack
		#service dao controller package
		@crud_pack=crud_pack
		@author=author
		
		DBI.connect("DBI:OCI8:#{@tns}","qaa","qaajkwin") do |dbh|
			#查询表的主键
			rs_id = dbh.execute("select ucc.column_name as ID from user_cons_columns ucc, user_constraints uc
					where ucc.constraint_name = uc.constraint_name
					and uc.constraint_type = 'P' and uc.table_name = upper('#{@table}')")
			
			@primary_key = rs_id.fetch_hash["ID"]
			@id=BeanUtils.field_to_attr(@primary_key)
			
			#获取表的基本信息
			rs = dbh.execute("select * from "+@table)
			rs_seq = dbh.execute("select count(*) as seqcount from all_sequences 
				where sequence_name='#{@table}_SEQUENCE'")
		
			sqlmap = SqlMapXml.new(rs_seq,rs,@table,@clazz,@name,@dpack,@primary_key,@id)
			sqlmap.write()

			domain = Domain.new(rs,@table,@clazz,@dpack)
			domain.write()
	
			dao_service = DaoService.new(@clazz,@name,@dpack,@crud_pack,@author)
			dao_service.write()
			
			xml_service = XmlService.new(@clazz,@name,@crud_pack)
			xml_service.write()
	
			controller = Controller.new(@clazz,@name,@id,@dpack,@crud_pack,@author)
			controller.write()
			
			#获取表的列注释
			rs_comments = dbh.execute("select column_name as columnName,comments 
				from user_col_comments where table_name=upper('#{@table}')")
			
			column_comment = Hash.new
			while(column = rs_comments.fetch_hash) do
				column_comment.store(column["COLUMNNAME"],column["COMMENTS"])
			end
			
			#ListView.new(column_comment,@clazz,@name,@id,@dpack).write()
			
			FormJsp.new(column_comment,@name,@id).write()

		end
	end

end

config = YAML.load_file("database.yaml")
CrudModel.new(config["tns"],config["table"],config["domain_pack"],config["crud_pack"],config["author"])



这个文件是生成java代码的主文件,具体的生成代码在相关的模块里面,总体来说,用ruby在做自动生成工具相当的方便,而且ruby本身的设计也相当的优秀。虽然本人以前也学过一段时间的rails,可惜只做过例子,并没有做出什么有实际帮助的东西来。但个人对ruby与rails评价还是很高的,都是些很不错的东西,希望以后能再有机会用到它们。
另外,本人开发使用的scite这个工具。