Skip to content

Commit dd2dac1

Browse files
maarztctrueden
authored andcommitted
Encapsulate log message info in LogMessage class
1 parent 501e2c8 commit dd2dac1

File tree

1 file changed

+115
-0
lines changed

1 file changed

+115
-0
lines changed
Lines changed: 115 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,115 @@
1+
/*
2+
* #%L
3+
* SciJava Common shared library for SciJava software.
4+
* %%
5+
* Copyright (C) 2009 - 2017 Board of Regents of the University of
6+
* Wisconsin-Madison, Broad Institute of MIT and Harvard, and Max Planck
7+
* Institute of Molecular Cell Biology and Genetics.
8+
* %%
9+
* Redistribution and use in source and binary forms, with or without
10+
* modification, are permitted provided that the following conditions are met:
11+
*
12+
* 1. Redistributions of source code must retain the above copyright notice,
13+
* this list of conditions and the following disclaimer.
14+
* 2. Redistributions in binary form must reproduce the above copyright notice,
15+
* this list of conditions and the following disclaimer in the documentation
16+
* and/or other materials provided with the distribution.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28+
* POSSIBILITY OF SUCH DAMAGE.
29+
* #L%
30+
*/
31+
32+
package org.scijava.log;
33+
34+
import java.util.Collection;
35+
import java.util.Collections;
36+
import java.util.Date;
37+
import java.util.LinkedList;
38+
39+
/**
40+
* LogMessage represents a log message.
41+
*
42+
* @author Matthias Arzt
43+
*/
44+
public class LogMessage {
45+
46+
private final int level;
47+
private final String message;
48+
private final Throwable throwable;
49+
private final Date time;
50+
51+
private Collection<Object> attachments;
52+
53+
public LogMessage(int level, Object message,
54+
Throwable throwable)
55+
{
56+
this.attachments = null;
57+
this.level = level;
58+
this.message = message == null ? null : message.toString();
59+
this.throwable = throwable;
60+
this.time = new Date();
61+
}
62+
63+
public LogMessage(int level, Object msg) {
64+
this(level, msg, null);
65+
}
66+
67+
/**
68+
* Log level of the message.
69+
*
70+
* @see LogLevel
71+
*/
72+
public int level() {
73+
return level;
74+
}
75+
76+
/** The content of this log message. */
77+
public String text() {
78+
return message;
79+
}
80+
81+
/** Exception associated with the log message. */
82+
public Throwable throwable() {
83+
return throwable;
84+
}
85+
86+
/** Time of the creation of the log message. */
87+
public Date time() {
88+
return time;
89+
}
90+
91+
/**
92+
* Collection of objects that have been attached to this message with
93+
* {@link #attach(Object)}.
94+
*/
95+
public Collection<Object> attachments() {
96+
return Collections.unmodifiableCollection(attachments);
97+
}
98+
99+
/**
100+
* Attach object to this log message. This can be used to attach additional
101+
* information to the log message.
102+
*/
103+
public void attach(Object value) {
104+
if (attachments == null) attachments = new LinkedList<>();
105+
attachments.add(value);
106+
}
107+
108+
// -- Object methods --
109+
110+
@Override
111+
public String toString() {
112+
return "LogMessage {" + level + ", " + message + ", " + throwable + "}";
113+
}
114+
115+
}

0 commit comments

Comments
 (0)