ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/i-scream/experimental/agents/Logger.java
Revision: 1.1
Committed: Fri May 4 02:04:35 2001 UTC (23 years, 7 months ago) by ajm
Branch: MAIN
CVS Tags: HEAD
Log Message:
Loads of new framework but far from complete.

The BasicAgent class is as it says, a basic agent, with ability to be run from the command line to fire it into an agentstation.

AgentStations now have support for adding and removing agents and support for multiple listeners.  Also initial support for peer agent stations.  Attempted support at peer -> peer agent transfer, but run into problems.

Still no bytecode transfer, but location and method has been figured out.

The AgentSystem class is now the bootstrap class for an agent station.  It brings up the AgentStation (which is now singleton) and the Logger (also singleton - using standard i-scream logging techniques).  It is possible to specify a peer station that the booting agent station should connect to.

Initial TODO:

	agent class loader
	agent bytecode transfer
	solve peer -> peer problems - possibly by creating extra socket to send agent, but shouldn't really be needed

File Contents

# Content
1 //---PACKAGE DECLARATION---
2 //package uk.org.iscream.core;
3
4 //---IMPORTS---
5 //import uk.org.iscream.util.*;
6
7 /**
8 * Allows classes to send logging information
9 * to an implementation of the LoggerImpl interface.
10 *
11 * @author $Author: tdb1 $
12 * @version $Id: LoggerServant.java,v 1.9 2001/03/14 23:25:29 tdb1 Exp $
13 */
14 class Logger {
15
16 //---FINAL ATTRIBUTES---
17
18 /**
19 * The current CVS revision of this class
20 */
21 public final String REVISION = "$Revision: 1.9 $";
22
23 /**
24 * The verbosity value for the FATAL log message
25 */
26 public static final int FATAL = 0;
27
28 /**
29 * The verbosity value for the ERROR log message
30 */
31 public static final int ERROR = 1;
32
33 /**
34 * The verbosity value for the WARNING log message
35 */
36 public static final int WARNING = 2;
37
38 /**
39 * The verbosity value for the SYSMSG log message
40 */
41 public static final int SYSMSG = 3;
42
43 /**
44 * The verbosity value for the SYSINIT log message
45 */
46 public static final int SYSINIT = 4;
47
48 /**
49 * The verbosity value for the DEBUG log message
50 */
51 public static final int DEBUG = 5;
52
53 /**
54 * An array of names of verbosity levels.
55 * Thus logging messages are now "classed" by the level"
56 * This string is prepended to the "source" of a logging message.
57 */
58 public final static String[] VERBOSITY_NAMES = {"FATAL", "ERROR", "WARNING", "SYSMSG", "SYSINIT", "DEBUG"};
59
60 //---STATIC METHODS---
61
62 /**
63 * Returns a reference to the singleton logger in use
64 *
65 * @throws RuntimeException if not yet initialised
66 */
67 public static Logger getInstance() throws RuntimeException {
68 if (_instance == null) {
69 throw new RuntimeException("Cannot obtain instance to uninitialised Logger");
70 }
71 return _instance;
72 }
73
74 /**
75 * Constructs and returns the singleton Logger class
76 *
77 * @param logger a reference to the LoggerImpl this will use
78 * @param verbosityLevel the system wide verbosity level in use
79 *
80 * @throws RuntimeException if already initialised
81 */
82 public static Logger initialise(LoggerImpl logger, int verbosityLevel) throws RuntimeException {
83 if (_instance != null) {
84 throw new RuntimeException("Already initialised!");
85 }
86 _instance = new Logger(logger, verbosityLevel);
87 return _instance;
88 }
89
90 //---CONSTRUCTORS---
91
92 /**
93 * Creates a new Logger with a given logging implementation
94 * and a given verbosity level.
95 * This is a private method to ensure singleton pattern.
96 *
97 * @param logger a reference to the LoggerImpl this will use
98 * @param verbosityLevel the system wide verbosity level in use
99 */
100 private Logger(LoggerImpl logger, int verbosityLevel) {
101 _logger = logger;
102 _verbosityLevel = verbosityLevel;
103 write(toString(), Logger.SYSINIT, "started");
104 write(toString(), Logger.SYSMSG, "using verbosity " + _verbosityLevel);
105 }
106
107 //---PUBLIC METHODS---
108
109 /**
110 * The write() method takes a source, verbosity level and
111 * message, and formats them using an external line
112 * formatting method. This line is then given to the logger
113 * to be written. Note that checking of the level is carried
114 * out here.
115 *
116 * @param source A string representation of the calling object.
117 * @param verbosity the verbosity of this message
118 * @param message The text to be logged.
119 */
120 public void write(String source, int verbosity, String message) {
121 if (verbosity <= _verbosityLevel) {
122 _logger.write(FormatName.formatLogLine(source, verbosity, message), verbosity);
123 }
124 }
125
126 /**
127 * Overrides the {@link java.lang.Object#toString() Object.toString()}
128 * method to provide clean logging (every class should have this).
129 *
130 * This uses the uk.org.iscream.util.FormatName class
131 * to format the toString()
132 *
133 * @return the name of this class and its CVS revision
134 */
135 public String toString() {
136 return FormatName.getName(
137 _name,
138 getClass().getName(),
139 REVISION);
140 }
141
142 //---PRIVATE/PROTECTED METHODS---
143
144 //---ACCESSOR/MUTATOR METHODS---
145
146 //---ATTRIBUTES---
147
148 /**
149 * The verbosity level of this instance
150 */
151 private int _verbosityLevel;
152
153 /**
154 * The actual Logger used by this instance
155 */
156 private LoggerImpl _logger;
157
158 /**
159 * This is the friendly identifier of the
160 * component this class is running in.
161 * eg, a Filter may be called "filter1",
162 * If this class does not have an owning
163 * component, a name from the configuration
164 * can be placed here. This name could also
165 * be changed to null for utility classes.
166 */
167 private String _name = "Logger";
168
169 //---STATIC ATTRIBUTES---
170
171 /**
172 * Holds the reference to the singleton instance of his class
173 */
174 private static Logger _instance;
175
176 }