本文章为原创,欢迎转载,但请给出本文链接,多谢合作。
本文链接:http://blog.csdn.net/epinszteinic/archive/2009/11/18/4827404.aspx
RSyntaxTextArea 是一个很好的编辑器开源包,我正在使用它。
它支持语法高亮显示。
我正在用它作为SQL的编辑器,它现在的SQL语法关键字里,只有一些共通的关键字,
MySQL里的show等等就不是关键字,我的需求就是要自己定义关键字。
RSyntaxTextArea里面,对于SQL语法,使用的是SQLTokenMaker.java这个类(暂时称它为SQL语法分析类)。
RSyntaxTextArea不能很轻松的添加删除关键字,它是使用JFlex来生成语义扫描器的。
(对于JFlex,我并不了解,只是简单学习了一下)
SQLTokenMaker.java就是由JFlex自动生成的。
我们需要做的,就是根据自己的需要,重新生成一个新的SQL语法分析类,然后告诉RSyntaxTextArea使用这个新类就可以。
首先,如何生成SQL语法分析类:
JFlex根据一个.flex文件来生成java类
(所有定义都在.flex文件里,包括生成的java文件的内容也需要写在里面。.flex文件怎么写,在JFlex网站上有介绍)
自己写.flex文件的话,将会相当麻烦...
幸运的是,RSyntaxTextArea已经为我们做好了一个!我们需要做的是把这个.flex文件下载下来,修改一下就可以了。
从它的web的src里去下载:SQLTokenMaker.flex
接下来,要修改这个.flex文件:
打开刚刚下载的SQLTokenMaker.flex,大概是能看懂一部分的。
修改这个文件里面的包名和类名,比如我把包改成pzc.gui,把类名改成PzcSQLTokenMaker(构造方法名也要改)。
在下面找到Keywords部分,添加上自己需要的关键字即可。
然后,要使用JFlex,根据这个.flex文件生成java类:
下载最新JFlex
解压缩,到lib下,看到有JFlex.jar,就是它了!
我的运行的run.bat是这样的:
(注:设置的output_dir是当前目录,因为懒得整别的目录了)
把SQLTokenMaker.flex拷贝到JFlex.jar的目录下,运行run.bat即可。会生成一个PzcSQLTokenMaker.java文件
(如果生成的java文件已经存在了的话,它会把原来的自动备份,文件名的后缀加一个~)
最后,就是在代码里如何使用这个新的SQL语法分析类了:
到此为止,大功告成!!
测试环境: | |
Windows Vista | |
JDK1.5(build 1.5.0_16-b02) | |
jflex-1.4.3 | |
rsyntaxtextarea_1.3.4 |