All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ch.qos.logback.core.util.OptionHelper Maven / Gradle / Ivy

/**
 * Logback: the reliable, generic, fast and flexible logging framework.
 * Copyright (C) 1999-2009, QOS.ch. All rights reserved.
 *
 * This program and the accompanying materials are dual-licensed under
 * either the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation
 *
 *   or (per the licensee's choosing)
 *
 * under the terms of the GNU Lesser General Public License version 2.1
 * as published by the Free Software Foundation.
 */
package ch.qos.logback.core.util;

import java.util.Properties;

import ch.qos.logback.core.Context;
import ch.qos.logback.core.CoreConstants;
import ch.qos.logback.core.spi.PropertyContainer;

/**
 * @author Ceki Gulcu
 */
public class OptionHelper {

  public static Object instantiateByClassName(String className,
      Class superClass, Context context) throws IncompatibleClassException,
      DynamicClassLoadingException {
    ClassLoader classLoader = Loader.getClassLoaderOfObject(context);
    return instantiateByClassName(className, superClass, classLoader);
  }

  @SuppressWarnings("unchecked")
  public static Object instantiateByClassName(String className,
      Class superClass, ClassLoader classLoader)
      throws IncompatibleClassException, DynamicClassLoadingException {

    if (className == null) {
      throw new NullPointerException();
    }

    try {
      Class classObj = null;
      classObj = classLoader.loadClass(className);
      if (!superClass.isAssignableFrom(classObj)) {
        throw new IncompatibleClassException(superClass, classObj);
      }
      return classObj.newInstance();
    } catch (IncompatibleClassException ice) {
      throw ice;
    } catch (Throwable t) {
      throw new DynamicClassLoadingException("Failed to instantiate type "
          + className, t);
    }
  }

  /**
   * Find the value corresponding to key in props.
   * Then perform variable substitution on the found value.
   * 
   */
  // public static String findAndSubst(String key, Properties props) {
  // String value = props.getProperty(key);
  //
  // if (value == null) {
  // return null;
  // }
  //
  // try {
  // return substVars(value, props);
  // } catch (IllegalArgumentException e) {
  // return value;
  // }
  // }
  final static String DELIM_START = "${";
  final static char DELIM_STOP = '}';
  final static int DELIM_START_LEN = 2;
  final static int DELIM_STOP_LEN = 1;
  final static String _IS_UNDEFINED = "_IS_UNDEFINED";

  /**
   * Perform variable substitution in string val from the values
   * of keys found in context property map, and if that fails, then in the
   * system properties.
   * 
   * 

The variable substitution delimeters are ${ and }. * *

For example, if the context property map contains a property "key1" set * as "value1", then the call * *

   * String s = OptionConverter.substituteVars("Value of key is ${key1}.", context);
* * will set the variable s to "Value of key is value1.". * *

If no value could be found for the specified key in the context map, * then the system properties are searched, if that fails, then substitution * defaults to appending "_IS_UNDEFINED" to the key name. * *

For example, if not the context not the system properties contains no * value for the key "inexistentKey", then the call * *

   * String s = OptionConverter.subsVars(
   *     "Value of inexistentKey is [${inexistentKey}]", context);
* * will set s to "Value of inexistentKey is * [inexistentKey_IS_UNDEFINED]". * *

Nevertheless, it is possible to specify a default substitution value * using the ":-" operator. For example, the call * *

   * String s = OptionConverter.subsVars("Value of key is [${key2:-val2}]", context);
* * will set s to "Value of key is [val2]" even if the "key2" * property is not set. * *

An {@link java.lang.IllegalArgumentException} is thrown if * val contains a start delimeter "${" which is not balanced by * a stop delimeter "}".

* * * @param val * The string on which variable substitution is performed. * @throws IllegalArgumentException * if val is malformed. */ public static String substVars(String val, PropertyContainer pc) { StringBuffer sbuf = new StringBuffer(); int i = 0; int j; int k; while (true) { j = val.indexOf(DELIM_START, i); if (j == -1) { // no more variables if (i == 0) { // this is a simple string return val; } else { // add the tail string which contails no variables and return // the result. sbuf.append(val.substring(i, val.length())); return sbuf.toString(); } } else { sbuf.append(val.substring(i, j)); k = val.indexOf(DELIM_STOP, j); if (k == -1) { throw new IllegalArgumentException('"' + val + "\" has no closing brace. Opening brace at position " + j + '.'); } else { j += DELIM_START_LEN; String rawKey = val.substring(j, k); // Massage the key to extract a default replacement if there is one String[] extracted = extractDefaultReplacement(rawKey); String key = extracted[0]; String defaultReplacement = extracted[1]; // can be null String replacement = null; // first try the props passed as parameter replacement = pc.getProperty(key); // then try in System properties if (replacement == null) { replacement = getSystemProperty(key, null); } // if replacement is still null, use the defaultReplacement which // can be null as well if (replacement == null) { replacement = defaultReplacement; } if (replacement != null) { // Do variable substitution on the replacement string // such that we can solve "Hello ${x2}" as "Hello p1" // where the properties are // x1=p1 // x2=${x1} String recursiveReplacement = substVars(replacement, pc); sbuf.append(recursiveReplacement); } else { // if we could not find a replacement, then signal the error sbuf.append(key + "_IS_UNDEFINED"); } i = k + DELIM_STOP_LEN; } } } } /** * Very similar to System.getProperty except that the * {@link SecurityException} is absorbed. * * @param key * The key to search for. * @param def * The default value to return. * @return the string value of the system property, or the default value if * there is no property with that key. */ public static String getSystemProperty(String key, String def) { try { return System.getProperty(key, def); } catch (SecurityException e) { return def; } } /** * Very similar to System.getProperty except that the * {@link SecurityException} is absorbed. * * @param key * The key to search for. * * @return the string value of the system property. */ public static String getSystemProperty(String key) { try { return System.getProperty(key); } catch (SecurityException e) { return null; } } /** * Very similar to {@link System#getProperties()} except that the * {@link SecurityException} is absorbed. * * @return the system properties */ public static Properties getSystemProperties() { try { return System.getProperties(); } catch (SecurityException e) { return new Properties(); } } static public String[] extractDefaultReplacement(String key) { String[] result = new String[2]; result[0] = key; int d = key.indexOf(":-"); if (d != -1) { result[0] = key.substring(0, d); result[1] = key.substring(d + 2); } return result; } /** * If value is "true", then true is returned. If * value is "false", then true is returned. * Otherwise, default is returned. * *

Case of value is unimportant. */ public static boolean toBoolean(String value, boolean dEfault) { if (value == null) { return dEfault; } String trimmedVal = value.trim(); if ("true".equalsIgnoreCase(trimmedVal)) { return true; } if ("false".equalsIgnoreCase(trimmedVal)) { return false; } return dEfault; } public static boolean isEmpty(String val) { return ((val == null) || CoreConstants.EMPTY_STRING.equals(val)); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy