[lttng-dev] [PATCH lttng-ust] Allow compiling the Java agent with Java 1.6

Mathieu Desnoyers mathieu.desnoyers at efficios.com
Wed Jul 29 16:35:25 EDT 2015


Merged, thanks!

Mathieu

----- On Jul 29, 2015, at 4:29 PM, Alexandre Montplaisir alexmonthy at efficios.com wrote:

> Previous patch d60dfbe inadvertently made use of
> ReflectiveOperationException, which was introduced in Java 7.
> To continue being able to compile the agent with Java 6, we
> can list individual exception types instead.
> 
> Signed-off-by: Alexandre Montplaisir <alexmonthy at efficios.com>
> ---
> .../org/lttng/ust/agent/LTTngAgent.java            | 71 +++++++++++++++++-----
> 1 file changed, 57 insertions(+), 14 deletions(-)
> 
> diff --git
> a/liblttng-ust-java-agent/java/lttng-ust-agent-common/org/lttng/ust/agent/LTTngAgent.java
> b/liblttng-ust-java-agent/java/lttng-ust-agent-common/org/lttng/ust/agent/LTTngAgent.java
> index 3c9a799..1a6b59a 100644
> ---
> a/liblttng-ust-java-agent/java/lttng-ust-agent-common/org/lttng/ust/agent/LTTngAgent.java
> +++
> b/liblttng-ust-java-agent/java/lttng-ust-agent-common/org/lttng/ust/agent/LTTngAgent.java
> @@ -18,6 +18,7 @@
> package org.lttng.ust.agent;
> 
> import java.lang.reflect.Constructor;
> +import java.lang.reflect.InvocationTargetException;
> import java.lang.reflect.Method;
> import java.util.logging.Handler;
> import java.util.logging.Logger;
> @@ -95,11 +96,19 @@ public class LTTngAgent {
> 
> 			/* Attach the handler to the root JUL logger */
> 			Logger.getLogger("").addHandler((Handler) julHandler);
> -		} catch (ReflectiveOperationException e) {
> +
> 			/*
> -			 * LTTng JUL classes not found, no need to create the relevant
> -			 * objects
> +			 * If any of the following exceptions happen, it means we could not
> +			 * find or initialize LTTng JUL classes. We will not setup LTTng JUL
> +			 * tracing in this case.
> 			 */
> +		} catch (SecurityException e) {
> +		} catch (IllegalAccessException e) {
> +		} catch (IllegalArgumentException e) {
> +		} catch (ClassNotFoundException e) {
> +		} catch (NoSuchMethodException e) {
> +		} catch (InstantiationException e) {
> +		} catch (InvocationTargetException e) {
> 		}
> 	}
> 
> @@ -119,11 +128,25 @@ public class LTTngAgent {
> 			Class<?> log4jAppenderClass =
> 			Class.forName("org.lttng.ust.agent.log4j.LttngLogAppender");
> 			Constructor<?> log4jAppendCtor = log4jAppenderClass.getConstructor();
> 			log4jAppender = (ILttngHandler) log4jAppendCtor.newInstance();
> -		} catch (ReflectiveOperationException e) {
> +
> 			/*
> -			 * LTTng Log4j classes not found, no need to create the relevant
> -			 * objects.
> +			 * If any of the following exceptions happen, it means we could not
> +			 * find or initialize LTTng log4j classes. We will not setup LTTng
> +			 * log4j tracing in this case.
> 			 */
> +		} catch (SecurityException e) {
> +			return;
> +		} catch (ClassNotFoundException e) {
> +			return;
> +		} catch (NoSuchMethodException e) {
> +			return;
> +		} catch (IllegalArgumentException e) {
> +			return;
> +		} catch (InstantiationException e) {
> +			return;
> +		} catch (IllegalAccessException e) {
> +			return;
> +		} catch (InvocationTargetException e) {
> 			return;
> 		}
> 
> @@ -143,12 +166,22 @@ public class LTTngAgent {
> 			Object rootLogger = getRootLoggerMethod.invoke(null, (Object[]) null);
> 			addAppenderMethod.invoke(rootLogger, log4jAppender);
> 
> -		} catch (ReflectiveOperationException e) {
> 			/*
> -			 * We have checked for the log4j library version previously, these
> -			 * classes should exist.
> +			 * We have checked for the log4j library version previously, none of
> +			 * the following exceptions should happen.
> 			 */
> -			throw new IllegalStateException();
> +		} catch (SecurityException e) {
> +			throw new IllegalStateException(e);
> +		} catch (ClassNotFoundException e) {
> +			throw new IllegalStateException(e);
> +		} catch (NoSuchMethodException e) {
> +			throw new IllegalStateException(e);
> +		} catch (IllegalArgumentException e) {
> +			throw new IllegalStateException(e);
> +		} catch (IllegalAccessException e) {
> +			throw new IllegalStateException(e);
> +		} catch (InvocationTargetException e) {
> +			throw new IllegalStateException(e);
> 		}
> 	}
> 
> @@ -228,12 +261,22 @@ public class LTTngAgent {
> 			Object rootLogger = getRootLoggerMethod.invoke(null, (Object[]) null);
> 			removeAppenderMethod.invoke(rootLogger, log4jAppender);
> 
> -		} catch (ReflectiveOperationException e) {
> 			/*
> -			 * We were able to attach the appender, we should not have problems
> -			 * here either!
> +			 * We were able to attach the appender previously, we should not
> +			 * have problems here either!
> 			 */
> -			throw new IllegalStateException();
> +		} catch (SecurityException e) {
> +			throw new IllegalStateException(e);
> +		} catch (ClassNotFoundException e) {
> +			throw new IllegalStateException(e);
> +		} catch (NoSuchMethodException e) {
> +			throw new IllegalStateException(e);
> +		} catch (IllegalArgumentException e) {
> +			throw new IllegalStateException(e);
> +		} catch (IllegalAccessException e) {
> +			throw new IllegalStateException(e);
> +		} catch (InvocationTargetException e) {
> +			throw new IllegalStateException(e);
> 		}
> 
> 		/* Close the appender */
> --
> 2.1.4
> 
> 
> _______________________________________________
> lttng-dev mailing list
> lttng-dev at lists.lttng.org
> http://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev

-- 
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com



More information about the lttng-dev mailing list