|
大多正式一点的java源代码,在头部都设有头注释信息。我们做的软件项目或者产品代码中,一般也需要设置一些公司信息、作者信息、版权信息等内容。现在的NetBeans或Eclipse等IDE工具都能很好的自动生成这些注视。不过如果要对你的整个项目代码进行批量的头注视修改、替换、维护,又该如何呢?本文用Swing做了一个小工具,来解决这个问题。
以下是JDK的源码的头注释的例子。
1 /*
2 * @(#)Object.java 1.61 03/01/23
3 *
4 * Copyright 2003 Sun Microsystems,... reserved.
5 * SUN PROPRIETARY/CONFIDENTIAL...to license terms.
6 */
7
8 package java.lang;
9
10 public class Object {...}
如果我们有个小工具能把我们项目里所有目录下的Java代码统一设置头注释就好了;比如当版本信息等改变时,只要重新运行一下即可一次性更新。下面我们就来亲自写一个。
思路很简单:
(1)建立一个窗口,用户可以设置一个目录、编写头注释信息;
(2)查找目录下所有子文件,如果是Java文件则处理之,如果是目录则递归处理;
(3)处理Java文件时,打开后,找到package语句或者第一个import语句,作为注释的插入点,插入注释;
(4)将增加了头注释的文件内容写回文件。
(5)本例中判断头注释插入点的逻辑比较简单,只是根据package语句或者第一个import语句来判断注释插入点,尚不严谨(比如原有的头注释中可能不包含这些关键字),仅供参考。
源码如下:
import java.io.*;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
public class HeaderCommentsGenerator {
private static int count = 0;
public static void main(String[] args) {
final JFrame frame = new JFrame("TWaver中文社区之Swing探秘");
JPanel contentPane = (JPanel) frame.getContentPane();
JPanel centerPane = new JPanel(new BorderLayout(10, 10));
centerPane.setBorder(BorderFactory.createEmptyBorder(10, 10, 0, 10));
JPanel pathPane = new JPanel(new BorderLayout());
final JTextField txtPath = new JTextField();
txtPath.setText("lease select your file or path.");
pathPane.add(txtPath, BorderLayout.CENTER);
JButton btnSelectPath = new JButton("Browser");
btnSelectPath.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
JFileChooser chooser = new JFileChooser();
chooser.setFileSelectionMode(JFileChooser.FILES_AND_DIRECTORIES);
int returnVal = chooser.showOpenDialog(frame);
if (returnVal == JFileChooser.APPROVE_OPTION) {
txtPath.setText(chooser.getSelectedFile().getAbsolutePath());
}
}
});
btnSelectPath.setMnemonic('B');
pathPane.add(btnSelectPath, BorderLayout.EAST);
centerPane.add(pathPane, BorderLayout.NORTH);
final JTextArea txtComments = new JTextArea();
txtComments.setText("/*\n"
+ " * Copyright 2003-2004 ABC Software, Inc. All rights reserved.\n"
+ " */");
centerPane.add(new JScrollPane(txtComments), BorderLayout.CENTER);
contentPane.add(centerPane, BorderLayout.CENTER);
JPanel buttonPane = new JPanel(new FlowLayout(FlowLayout.RIGHT, 10, 10));
JButton btnOK = new JButton("Generate!");
btnOK.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
String path = txtPath.getText();
File file = new File(path);
if (!file.exists()) {
JOptionPane.showMessageDialog(frame,
"Path '" + path + "' not exist.",
"Error",
JOptionPane.ERROR_MESSAGE);
} else {
commentFile(file, txtComments.getText());
JOptionPane.showMessageDialog(frame,
"Finish, total " + count + " files are processed.",
"Information",
JOptionPane.INFORMATION_MESSAGE);
}
}
});
btnOK.setMnemonic('G');
JButton btnClose = new JButton("Close");
btnClose.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
System.exit(0);
}
});
btnClose.setMnemonic('C');
buttonPane.add(btnOK);
buttonPane.add(btnClose);
contentPane.add(buttonPane, BorderLayout.SOUTH);
frame.setSize(500, 300);
frame.show();
}
private static void commentFile(File file, String comments) {
if (file != null && file.exists()) {
if (file.isDirectory()) {
String[] children = file.list();
for (int i = 0; i < children.length; i++) {
File child = new File(file.getPath() + System.getProperty("file.separator") + children);
commentFile(child, comments);
}
} else {
if (file.getName().toLowerCase().endsWith(".java")) {
System.out.println(file.getName());
count++;
try {
RandomAccessFile raFile = new RandomAccessFile(file, "rw");
byte[] content = new byte[(int) raFile.length()];
raFile.readFully(content);
String all = new String(content);
all = all.trim();
while (all.startsWith("\n")) {
all = all.substring(1);
}
if (all.indexOf("package") != -1) {
all = all.substring(all.indexOf("package"));
}
if (all.indexOf("import") != -1) {
all = all.substring(all.indexOf("package"));
}
all = comments + "\n" + all;
raFile.close();
FileWriter writer = new FileWriter(file);
writer.write(all);
writer.close();
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
}
}
}
程序运行如下图:
|
|