Skip to content

Commit f6d1349

Browse files
author
Henning Schmiedehausen
committed
remove some of the more weird runtime exception suppression code
1 parent 8904163 commit f6d1349

21 files changed

+54
-139
lines changed

src/main/java/org/productivity/java/syslog4j/Syslog.java

Lines changed: 9 additions & 59 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818
import org.productivity.java.syslog4j.util.OSDetectUtility;
1919
import org.productivity.java.syslog4j.util.SyslogUtility;
2020

21+
import com.google.common.base.Preconditions;
2122
import com.google.common.collect.Maps;
2223

2324
/**
@@ -45,8 +46,6 @@
4546
*/
4647
public final class Syslog
4748
{
48-
private static boolean SUPPRESS_RUNTIME_EXCEPTIONS = false;
49-
5049
protected static final Map<String, SyslogIF> instances = Maps.newHashMap();
5150

5251
/**
@@ -64,42 +63,6 @@ private Syslog() {
6463
//
6564
}
6665

67-
/**
68-
* @return Returns the current version identifier for Syslog4j.
69-
*/
70-
public static final String getVersion() {
71-
return Syslog4jVersion.VERSION;
72-
}
73-
74-
/**
75-
* @param suppress - true to suppress throwing SyslogRuntimeException in many methods of this class, false to throw exceptions (default)
76-
*/
77-
public static void setSuppressRuntimeExceptions(boolean suppress) {
78-
SUPPRESS_RUNTIME_EXCEPTIONS = suppress;
79-
}
80-
81-
/**
82-
* @return Returns whether or not to suppress throwing SyslogRuntimeException in many methods of this class.
83-
*/
84-
public static boolean getSuppressRuntimeExceptions() {
85-
return SUPPRESS_RUNTIME_EXCEPTIONS;
86-
}
87-
88-
/**
89-
* Throws SyslogRuntimeException unless it has been suppressed via setSuppressRuntimeException(boolean).
90-
*
91-
* @param message
92-
* @throws SyslogRuntimeException
93-
*/
94-
private static void throwRuntimeException(String message) throws SyslogRuntimeException {
95-
if (SUPPRESS_RUNTIME_EXCEPTIONS) {
96-
return;
97-
98-
} else {
99-
throw new SyslogRuntimeException(message.toString());
100-
}
101-
}
102-
10366
/**
10467
* Use getInstance(protocol) as the starting point for Syslog4j.
10568
*
@@ -130,8 +93,7 @@ public static final SyslogIF getInstance(String protocol) throws SyslogRuntimeEx
13093
}
13194
}
13295

133-
throwRuntimeException(message.toString());
134-
return null;
96+
throw new SyslogRuntimeException(message.toString());
13597
}
13698
}
13799

@@ -153,27 +115,17 @@ public static final SyslogIF getInstance(String protocol) throws SyslogRuntimeEx
153115
* @return Returns an instance of SyslogIF.
154116
* @throws SyslogRuntimeException
155117
*/
156-
public static final SyslogIF createInstance(String protocol, SyslogConfigIF config) throws SyslogRuntimeException {
157-
158-
if (StringUtils.isBlank(protocol)) {
159-
throwRuntimeException("Instance protocol cannot be null or empty");
160-
return null;
161-
}
162-
163-
if (config == null) {
164-
throwRuntimeException("SyslogConfig cannot be null");
165-
return null;
166-
}
118+
public static final SyslogIF createInstance(String protocol, SyslogConfigIF config) throws SyslogRuntimeException
119+
{
120+
Preconditions.checkArgument(!StringUtils.isBlank(protocol), "Instance protocol cannot be null or empty");
121+
Preconditions.checkArgument(config != null, "SyslogConfig cannot be null");
167122

168123
String syslogProtocol = protocol.toLowerCase();
169124

170125
SyslogIF syslog = null;
171126

172127
synchronized(instances) {
173-
if (instances.containsKey(syslogProtocol)) {
174-
throwRuntimeException("Syslog protocol \"" + protocol + "\" already defined");
175-
return null;
176-
}
128+
Preconditions.checkState(!instances.containsKey(syslogProtocol), "Syslog protocol \"%s\" already defined", protocol);
177129

178130
try {
179131
Class<? extends SyslogIF> syslogClass = config.getSyslogClass();
@@ -295,8 +247,7 @@ public synchronized static final void destroyInstance(String protocol) throws Sy
295247
}
296248

297249
} else {
298-
throwRuntimeException("Cannot destroy protocol \"" + protocol + "\" instance; call shutdown instead");
299-
return;
250+
throw new SyslogRuntimeException("Cannot destroy protocol \"%s\" instance; call shutdown instead", protocol);
300251
}
301252
}
302253

@@ -323,8 +274,7 @@ public synchronized static final void destroyInstance(SyslogIF syslog) throws Sy
323274
}
324275

325276
} else {
326-
throwRuntimeException("Cannot destroy protocol \"" + protocol + "\" instance; call shutdown instead");
327-
return;
277+
throw new SyslogRuntimeException("Cannot destroy protocol \"%s\" instance; call shutdown instead", protocol);
328278
}
329279
}
330280

src/main/java/org/productivity/java/syslog4j/Syslog4jVersion.java

Lines changed: 0 additions & 16 deletions
This file was deleted.

src/main/java/org/productivity/java/syslog4j/SyslogCharSetIF.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package org.productivity.java.syslog4j;
22

3-
import java.io.Serializable;
43
import java.nio.charset.Charset;
54

65
/**
@@ -14,7 +13,7 @@
1413
* @author &lt;syslog4j@productivity.org&gt;
1514
* @version $Id: SyslogCharSetIF.java,v 1.3 2008/11/07 15:15:41 cvs Exp $
1615
*/
17-
public interface SyslogCharSetIF extends Serializable
16+
public interface SyslogCharSetIF
1817
{
1918
Charset getCharSet();
2019

src/main/java/org/productivity/java/syslog4j/SyslogMain.java

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -126,10 +126,6 @@ public static void main(String[] args, boolean shutdown) throws Exception {
126126
if (CALL_SYSTEM_EXIT_ON_FAILURE) { System.exit(1); } else { return; }
127127
}
128128

129-
if (!options.quiet) {
130-
System.out.println("Syslog " + Syslog.getVersion());
131-
}
132-
133129
if (!Syslog.exists(options.protocol)) {
134130
usage("Protocol \"" + options.protocol + "\" not supported");
135131
if (CALL_SYSTEM_EXIT_ON_FAILURE) { System.exit(1); } else { return; }

src/main/java/org/productivity/java/syslog4j/SyslogMessageIF.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package org.productivity.java.syslog4j;
22

3-
import java.io.Serializable;
43

54
/**
65
* SyslogMessageIF provides a common interface for all Syslog4j event implementations.
@@ -12,6 +11,6 @@
1211
* @author &lt;syslog4j@productivity.org&gt;
1312
* @version $Id: SyslogMessageIF.java,v 1.1 2008/11/10 04:38:37 cvs Exp $
1413
*/
15-
public interface SyslogMessageIF extends Serializable {
14+
public interface SyslogMessageIF {
1615
public String createMessage();
1716
}

src/main/java/org/productivity/java/syslog4j/SyslogMessageProcessorIF.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package org.productivity.java.syslog4j;
22

3-
import java.io.Serializable;
43

54
/**
65
* SyslogMessageProcessorIF provides an extensible interface for writing custom
@@ -13,7 +12,7 @@
1312
* @author &lt;syslog4j@productivity.org&gt;
1413
* @version $Id: SyslogMessageProcessorIF.java,v 1.4 2010/11/28 04:15:18 cvs Exp $
1514
*/
16-
public interface SyslogMessageProcessorIF extends Serializable {
15+
public interface SyslogMessageProcessorIF {
1716
public String createSyslogHeader(SyslogFacility facility, SyslogLevel level, String localName, boolean sendLocalTimestamp, boolean sendLocalName);
1817

1918
public byte[] createPacketData(byte[] header, byte[] message, int start, int length);

src/main/java/org/productivity/java/syslog4j/SyslogPoolConfigIF.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package org.productivity.java.syslog4j;
22

3-
import java.io.Serializable;
43

54
/**
65
* SyslogPoolConfigIF is an interface which provides configuration support
@@ -13,7 +12,7 @@
1312
* @author &lt;syslog4j@productivity.org&gt;
1413
* @version $Id: SyslogPoolConfigIF.java,v 1.2 2009/03/29 17:38:58 cvs Exp $
1514
*/
16-
public interface SyslogPoolConfigIF extends Serializable {
15+
public interface SyslogPoolConfigIF {
1716
public int getMaxActive();
1817
public void setMaxActive(int maxActive);
1918

src/main/java/org/productivity/java/syslog4j/SyslogRuntimeException.java

Lines changed: 10 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -11,12 +11,17 @@
1111
* @author &lt;syslog4j@productivity.org&gt;
1212
* @version $Id: SyslogRuntimeException.java,v 1.3 2008/11/13 14:48:36 cvs Exp $
1313
*/
14-
public class SyslogRuntimeException extends RuntimeException {
15-
public SyslogRuntimeException(String arg0) {
16-
super(arg0);
14+
public class SyslogRuntimeException extends RuntimeException
15+
{
16+
public SyslogRuntimeException(String format, Object ... args) {
17+
super(String.format(format, args));
1718
}
1819

19-
public SyslogRuntimeException(Throwable arg0) {
20-
super(arg0);
20+
public SyslogRuntimeException(Throwable t) {
21+
super(t);
22+
}
23+
24+
public SyslogRuntimeException(Throwable t, String format, Object ... args) {
25+
super(String.format(format, args), t);
2126
}
2227
}

src/main/java/org/productivity/java/syslog4j/impl/AbstractSyslogWriter.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,5 @@
11
package org.productivity.java.syslog4j.impl;
22

3-
import java.io.Serializable;
43
import java.util.List;
54

65
import org.productivity.java.syslog4j.SyslogLevel;
@@ -23,7 +22,7 @@
2322
* @author &lt;syslog4j@productivity.org&gt;
2423
* @version $Id: AbstractSyslogWriter.java,v 1.9 2010/10/25 03:50:25 cvs Exp $
2524
*/
26-
public abstract class AbstractSyslogWriter implements Runnable, Serializable {
25+
public abstract class AbstractSyslogWriter implements Runnable {
2726
protected AbstractSyslog syslog = null;
2827

2928
protected List<byte []> queuedMessages = null;

src/main/java/org/productivity/java/syslog4j/impl/backlog/NullSyslogBackLogHandler.java

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,18 +18,22 @@
1818
public class NullSyslogBackLogHandler implements SyslogBackLogHandlerIF {
1919
public static final NullSyslogBackLogHandler INSTANCE = new NullSyslogBackLogHandler();
2020

21+
@Override
2122
public void initialize() {
2223
//
2324
}
2425

26+
@Override
2527
public void down(SyslogIF syslog, String reason) {
2628
//
2729
}
2830

31+
@Override
2932
public void up(SyslogIF syslog) {
3033
//
3134
}
3235

36+
@Override
3337
public void log(SyslogIF syslog, SyslogLevel level, String message, String reason) {
3438
//
3539
}

0 commit comments

Comments
 (0)