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

com.helger.commons.debug.GlobalDebug Maven / Gradle / Ivy

/**
 * Copyright (C) 2014-2015 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.helger.commons.debug;

import java.util.concurrent.atomic.AtomicBoolean;

import javax.annotation.concurrent.ThreadSafe;

import com.helger.commons.system.SystemProperties;

/**
 * Global class for handling the following typical application modes:
 * 
    *
  • trace
  • *
  • debug
  • *
  • production
  • *
* trace is the lowest mode, debug is one level higher and production is the * highest value. By default all modes are deactivated. * * @author Philip */ @ThreadSafe public final class GlobalDebug { /** * By default debug mode is enabled */ public static final boolean DEFAULT_DEBUG_MODE = true; /** * By default production mode is disable */ public static final boolean DEFAULT_PRODUCTION_MODE = false; public static final String SYSTEM_PROPERTY_MAIL_DEBUG = "mail.debug"; public static final String SYSTEM_PROPERTY_JAVAX_ACTIVATION_DEBUG = "javax.activation.debug"; public static final String SYSTEM_PROPERTY_JAXP_DEBUG = "jaxp.debug"; private static final AtomicBoolean s_aDebugMode = new AtomicBoolean (DEFAULT_DEBUG_MODE); private static final AtomicBoolean s_aProductionMode = new AtomicBoolean (DEFAULT_PRODUCTION_MODE); // to set it per dependency injection public void setDebugMode (final boolean bDebugMode) { setDebugModeDirect (bDebugMode); } // to set it per dependency injection public void setProductionMode (final boolean bProductionMode) { setProductionModeDirect (bProductionMode); } /** * Set the debug mode for the common Java components: *
    *
  • JAXP
  • *
  • Javax Activation
  • *
  • Javax Mail
  • *
* * @param bDebugMode * true to enable debug mode, false to * disable it */ public static void setJavaCommonComponentsDebugMode (final boolean bDebugMode) { // Set JAXP debugging! // Note: this property is read-only on Ubuntu, defined by the following // policy file: /etc/tomcat6/policy.d/04webapps.policy SystemProperties.setPropertyValue (SYSTEM_PROPERTY_JAXP_DEBUG, bDebugMode); // Set javax.activation debugging SystemProperties.setPropertyValue (SYSTEM_PROPERTY_JAVAX_ACTIVATION_DEBUG, bDebugMode); // Set javax.mail debugging SystemProperties.setPropertyValue (SYSTEM_PROPERTY_MAIL_DEBUG, bDebugMode); } /** * Enable or disable debug mode. If debug mode is disabled, also trace mode is * disabled. * * @param bDebugMode * true to enable, false to disable */ public static void setDebugModeDirect (final boolean bDebugMode) { s_aDebugMode.set (bDebugMode); setJavaCommonComponentsDebugMode (bDebugMode); } /** * Enable or disable production mode. If production mode is enabled, also * trace mode and debug mode are disabled. * * @param bProductionMode * true to enable, false to disable */ public static void setProductionModeDirect (final boolean bProductionMode) { s_aProductionMode.set (bProductionMode); // If enabling production mode, disable debug mode if (bProductionMode) setDebugModeDirect (false); } /** * @return true if debug mode is active, false if * not */ public static boolean isDebugMode () { return s_aDebugMode.get (); } /** * @return true if production mode is active, false * if not */ public static boolean isProductionMode () { return s_aProductionMode.get (); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy