Final changes to PMD integration. This code should be ready for a new release.

git-svn-id: https://pmd.svn.sourceforge.net/svnroot/pmd/trunk@682 51baf565-9d33-0410-a72c-fc3788e3496d
This commit is contained in:
David Craine
2002-08-10 00:31:27 +00:00
parent 8fa70b58aa
commit 4ceed2256a
3 changed files with 21 additions and 5 deletions

View File

@ -1,2 +1,2 @@
copy lib\PMDOpenTool.jar %1
copy lib\pmd-0.8.jar %1
rem copy lib\pmd-0.8.jar %1

Binary file not shown.

View File

@ -364,7 +364,8 @@ public class PMDOpenTool {
Tile t = (Tile)iter.next();
resultCount++;
int tileLineCount = cpd.getLineCountFor(t);
CPDMessage msg = CPDMessage.createMessage("Duplicate code set: " + resultCount, t.getImage());
int dupCount = results.getOccurrenceCountFor(t);
CPDMessage msg = CPDMessage.createMessage(String.valueOf(dupCount)+" duplicates in code set: " + resultCount, cpd.getImage(t));
for (Iterator iter2 = results.getOccurrences(t); iter2.hasNext(); ) {
TokenEntry te = (TokenEntry)iter2.next();
msg.addChildMessage(te.getBeginLine(), tileLineCount, te.getTokenSrcID());
@ -373,7 +374,6 @@ public class PMDOpenTool {
}
}
cpdd.close();
}
catch (Exception e) {
Browser.getActiveBrowser().getMessageView().addMessage(cpdCat, e.toString());
@ -459,6 +459,8 @@ class PMDMessage extends Message {
*/
class CPDMessage extends Message {
final static LineMark MARK = new HighlightMark(true);
static Font PARENT_FONT = new Font("SansSerif", Font.BOLD, 12);
static Font CHILD_FONT = new Font("SansSerif", Font.PLAIN, 12);
String filename;
FileNode javaNode = null;
int startline = 0;
@ -498,6 +500,7 @@ class CPDMessage extends Message {
public static CPDMessage createMessage(String msg, String codeBlock) {
CPDMessage cpdm = new CPDMessage(msg, codeBlock);
cpdm.isParent = true;
cpdm.setFont(PARENT_FONT);
return cpdm;
}
@ -508,6 +511,7 @@ class CPDMessage extends Message {
String msg = fileName.substring(fileName.lastIndexOf(sep.charAt(0))+1)+": line: " + String.valueOf(startline);
CPDMessage cpdmsg = new CPDMessage(msg, startline, endline, fileName);
cpdmsg.isParent = false;
cpdmsg.setFont(CHILD_FONT);
childMessages.add(cpdmsg);
}
@ -572,6 +576,7 @@ class CPDMessage extends Message {
class CodeFragmentMessage extends Message {
String codeFragment = null;
static Font CODE_FONT = new Font("Monospaced", Font.ITALIC, 12);
public CodeFragmentMessage(String codeFragment) {
super("View Code");
this.setLazyFetchChildren(true);
@ -579,7 +584,18 @@ class CodeFragmentMessage extends Message {
}
public void fetchChildren(Browser browser) {
browser.getMessageView().addMessage(PMDOpenTool.cpdCat, this, new Message(codeFragment));
BufferedReader reader = new BufferedReader(new StringReader(codeFragment));
try {
String line = reader.readLine();
while (line != null) {
Message msg = new Message(line);
msg.setFont(CODE_FONT);
browser.getMessageView().addMessage(PMDOpenTool.cpdCat, this, msg);
line = reader.readLine();
}
}
catch (Exception e){}
}
}