From bcc7a3761ce5801d747653f6f97b094c9ccdbb45 Mon Sep 17 00:00:00 2001 From: Björn Hagemeister Date: Wed, 12 Nov 2014 15:01:39 +0100 Subject: Added class for reading proxy setting from proxy configuration file. Added class utils for some necessary tools, used in ProxyConfiguration. --- src/main/java/org/openslx/util/Util.java | 74 ++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 src/main/java/org/openslx/util/Util.java (limited to 'src/main/java/org/openslx/util') diff --git a/src/main/java/org/openslx/util/Util.java b/src/main/java/org/openslx/util/Util.java new file mode 100644 index 0000000..9f98007 --- /dev/null +++ b/src/main/java/org/openslx/util/Util.java @@ -0,0 +1,74 @@ +package org.openslx.util; + +import java.io.Closeable; + +import org.apache.log4j.Logger; +import org.openslx.util.Util; + +public class Util +{ + private static Logger log = Logger.getLogger( Util.class ); + + /** + * Check if the given object is null, abort program if true. An optional + * message to be printed can be passed. A stack trace will be printed, too. + * Finally the application terminates with exit code 2. + * + * This comes in handy if something must not be null, and you want user + * friendly output. A perfect example would be reading settings from a + * config file. You can use this on mandatory fields. + * + * @param something + * the object to compare to null + * @param message + * the message to be printed if something is null + */ + public static void notNullFatal( Object something, String message ) + { + if ( something == null ) { + if ( message != null ) + log.fatal( "[NOTNULL] " + message ); + log.warn( Thread.currentThread().getStackTrace().toString() ); + System.exit( 2 ); + } + } + + public static void notNullOrEmptyFatal( String something, String message ) + { + if ( something == null || something.isEmpty() ) { + if ( message != null ) + log.fatal( "[NOTNULL] " + message ); + log.warn( Thread.currentThread().getStackTrace().toString() ); + System.exit( 2 ); + } + } + + + /** + * Tries to parse an int. Returns 0 on error. + * + * @param s + * The string to parse + * @return The parsed int or 0 on error + */ + public static int tryToParseInt( String s ) + { + try { + return Integer.parseInt( s ); + } catch ( NumberFormatException e ) { + return 0; + } + } + + public static void streamClose( Closeable... closeable ) + { + for ( Closeable c : closeable ) { + if ( c == null ) + continue; + try { + c.close(); + } catch ( Throwable t ) { + } + } + } +} -- cgit v1.2.3-55-g7522