01: /*
02: * Copyright (c) 2001-2007, Jean Tessier
03: * All rights reserved.
04: *
05: * Redistribution and use in source and binary forms, with or without
06: * modification, are permitted provided that the following conditions
07: * are met:
08: *
09: * * Redistributions of source code must retain the above copyright
10: * notice, this list of conditions and the following disclaimer.
11: *
12: * * Redistributions in binary form must reproduce the above copyright
13: * notice, this list of conditions and the following disclaimer in the
14: * documentation and/or other materials provided with the distribution.
15: *
16: * * Neither the name of Jean Tessier nor the names of his contributors
17: * may be used to endorse or promote products derived from this software
18: * without specific prior written permission.
19: *
20: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
24: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31: */
32:
33: package com.jeantessier.dependencyfinder.webwork;
34:
35: import java.io.*;
36:
37: import com.jeantessier.dependencyfinder.*;
38: import com.jeantessier.classreader.*;
39:
40: public class VerboseListener extends VerboseListenerBase {
41: private PrintWriter out;
42:
43: private int classCount = 0;
44:
45: public VerboseListener(PrintWriter out) {
46: this .out = out;
47: }
48:
49: public int getClassCount() {
50: return classCount;
51: }
52:
53: public void print(String s) {
54: out.println(s);
55: }
56:
57: public void beginGroup(LoadEvent event) {
58: super .beginGroup(event);
59:
60: out.println();
61: out.print("\tSearching ");
62: out.print(getCurrentGroup().getName());
63: if (getCurrentGroup().getSize() >= 0) {
64: out.print(" (");
65: out.print(getCurrentGroup().getSize());
66: out.print(" files)");
67: }
68: out.print(" ...");
69: out.println();
70: }
71:
72: public void beginFile(LoadEvent event) {
73: super .beginFile(event);
74:
75: out.print(getRatioIndicator());
76: }
77:
78: public void endClassfile(LoadEvent event) {
79: super .endClassfile(event);
80:
81: classCount++;
82:
83: out.print("\t\tGetting dependencies from ");
84: out.print(event.getClassfile());
85: out.print(" ...");
86: out.println();
87: }
88:
89: public void endFile(LoadEvent event) {
90: super .endFile(event);
91:
92: if (!getVisitedFiles().contains(event.getFilename())) {
93: out.print("\t\t<i>Skipping ");
94: out.print(event.getFilename());
95: out.print(" ...</i>");
96: out.println();
97: }
98: }
99: }
|