文章转自:http://shareal.blog.163.com/blog/static/27659056201193063914196/
Copyright @ 原创版权所有,免费引用请注明出处。
Eclipse的代码注释模板很丰富,如:user、year、date、time等等,请参考附件。
尽管模板变量如此之多,但是对于复杂多边的实际项目而言,还是不够用,怎么办?自己增加新的呗!
Eclipse配置界面都不支持定制自己的注释模板变量,没办法,改Eclipse源码,
具体怎么改,好像无头苍蝇,百度和谷歌了2天,还是无果,在边搜边摸索的过程中才知道需要修改如下两个架包对应的源码,
org.eclipse.jdt.ui.jar
org.eclipse.text.jar
发现了三个重要的文件:
org.eclipse.jface.text.template.TextTemplateMessageg.properties
org.eclipse.jface.text.templates.GlobalTemplateVariables.java
org.eclipse.jdt.internal.corext.template.java.CodeTemplateContextType.java
1、TextTemplateMessageg.properties里面定义了一些全局模板:
# global variables
GlobalVariables.variable.description.cursor=The cursor position after editing template variables
GlobalVariables.variable.description.dollar=The dollar symbol
GlobalVariables.variable.description.date=Current date
GlobalVariables.variable.description.year=Current year
GlobalVariables.variable.description.time=Current time
GlobalVariables.variable.description.user=User name
GlobalVariables.variable.description.selectedWord= The selected word
GlobalVariables.variable.description.selectedLines= The selected lines
我们可以看到user、year、date、time都在里面。
如果要增加自己的模板变量,就加吧?例如:
GlobalVariables.variable.description.copyright=Copyright all resolved
2、全局模板变量在GlobalTemplateVariables里面,均继承自SimpleTemplateVariableResolver
增加一个对应GlobalVariables.variable.description.copyright的模板变量
/**
* The copyright variable evaluates to the current copyright.
* Added by 博主 2011-10-30
*/
public static class Copyright extends SimpleTemplateVariableResolver
{
/**
* 默认从环境变量中取copyright信息,环境变量可以定义在eclipse.ini的vmargs下面
*/
private static String value = System.getProperty("copyright");
/**
* Creates a new copyright variable
*/
public Copyright()
{
super("copyright", TextTemplateMessages.getString("GlobalVariables.variable.description.copyright")); //$NON-NLS-1$ //$NON-NLS-2$
}
/**
* {@inheritDoc}
*/
protected String resolve(TemplateContext context)
{
if (value != null)
{
return TextTemplateMessages.getString("GlobalVariables.variable.description.copyright");
}
return value; //$NON-NLS-1$
}
}
3、让Eclipse的Reference界面配置code template是支持${copyright}
修改:CodeTemplateContextType,在其构造方法里面增加Copyright实例
public CodeTemplateContextType(String contextName) {
super(contextName);
fIsComment= false;
// global
addResolver(new GlobalTemplateVariables.Dollar());
addResolver(new GlobalTemplateVariables.Date());
addResolver(new GlobalTemplateVariables.Year());
addResolver(new GlobalTemplateVariables.Time());
addResolver(new GlobalTemplateVariables.User());
// Added by 博主 2011-10-30
addResolver(new GlobalTemplateVariables.Copyright());
4、将修改的内容加到 org.eclipse.jdt.ui.jar和org.eclipse.text.jar这两个包中
先退出Eclipse,再使用BeyondCompare之类的比较工具,将修改编译好的calss文件和properties文件覆盖到原有包中,不过如果你动jar的命令行操作,也可以使用jar命令打包。
好了,现在重新启动Eclipse,赶紧到windows-preferences->java-code style->code template界面去体验一下:
新建一个java类,在类名上方按Ctrl+Alt+j就可以出现自己的copyright注释了。
想想很简单。
附录:Eclipse针对java代码模板的内置变量
cursor 将编辑器的光标放在这个位置。 N/A
date 插入当前日期。
dollar 插入货币的文字符号。 $
elemType 尝试猜测具有给定 ID 的这个元素的类型。 MyType
enclosing_method 插入模板被插入其中的那个方法的名称。 method()
enclosing_method_arguments 为包围方法插入参数。 arg1, arg2
enclosing_package 插入当前类的包名。 com.example.ui
enclosing_project 插入包含所编辑的这个类的项目的名称。 myProject
enclosing_type 插入正在编辑的类型(类)的名称。 MyType
exception_variable_name 插入一个异常变量名称,进行最佳猜测。 e, ioe
file 文件的简称。 MyType.java
import 如果尚未导入,那么针对给定类型插入一个导入声明。 import com.example.ui.MyOtherType
importStatic 与 import 相同,只不过是静态导入。 import static com.example.ui.MyOtherType.*
line_selection 将选中的行插入到这里。这对用模板包装行是很有用的。 以选中行作为主体的 do、while 循环
primary_type_name 没有扩展名的文件简称。 MyType
time 插入当前的时间。
todo 注释中的 TODO 标记。 TODO
user 当前用户的名字。 ngood
var 解析为本地变量,如果不只一个,就提供一个列表。 myvar
word_selection 插入当前选中的单词。 N/A
year 将现在的年份插入到代码中。 2010
再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow