[Git][java-team/logback][upstream] New upstream version 1.2.11

Tony Mancill (@tmancill) gitlab at salsa.debian.org
Wed Mar 23 03:55:40 GMT 2022



Tony Mancill pushed to branch upstream at Debian Java Maintainers / logback


Commits:
f279610d by tony mancill at 2022-03-22T20:34:27-07:00
New upstream version 1.2.11
- - - - -


23 changed files:

- logback-access/pom.xml
- logback-classic/pom.xml
- logback-classic/src/main/java/ch/qos/logback/classic/joran/action/InsertFromJNDIAction.java
- logback-classic/src/main/java/ch/qos/logback/classic/selector/ContextJNDISelector.java
- logback-classic/src/main/java/ch/qos/logback/classic/selector/servlet/ContextDetachingSCL.java
- logback-classic/src/main/java/ch/qos/logback/classic/spi/ThrowableProxy.java
- logback-classic/src/test/java/ch/qos/logback/classic/pattern/ThrowableProxyConverterTest.java
- logback-classic/src/test/java/ch/qos/logback/classic/selector/ContextDetachingSCLTest.java
- logback-classic/src/test/java/ch/qos/logback/classic/selector/ContextJNDISelectorTest.java
- logback-classic/src/test/java/ch/qos/logback/classic/spi/ThrowableProxyTest.java
- logback-core/pom.xml
- logback-core/src/main/java/ch/qos/logback/core/net/SMTPAppenderBase.java
- logback-core/src/main/java/ch/qos/logback/core/util/JNDIUtil.java
- logback-core/src/main/java/ch/qos/logback/core/util/OptionHelper.java
- logback-classic/src/test/java/ch/qos/logback/classic/util/MockInitialContext.java → logback-core/src/test/java/ch/qos/logback/core/testUtil/MockInitialContext.java
- logback-classic/src/test/java/ch/qos/logback/classic/util/MockInitialContextFactory.java → logback-core/src/test/java/ch/qos/logback/core/testUtil/MockInitialContextFactory.java
- + logback-core/src/test/java/ch/qos/logback/core/testUtil/VersionUtil.java
- + logback-core/src/test/java/ch/qos/logback/core/testUtil/VersionUtilTest.java
- logback-core/src/test/java/ch/qos/logback/core/util/CoreTestConstants.java
- logback-core/src/test/java/ch/qos/logback/core/util/JNDIUtilTest.java
- logback-examples/pom.xml
- logback-site/pom.xml
- pom.xml


Changes:

=====================================
logback-access/pom.xml
=====================================
@@ -8,7 +8,7 @@
   <parent>
     <groupId>ch.qos.logback</groupId>
     <artifactId>logback-parent</artifactId>
-    <version>1.2.10</version>
+    <version>1.2.11</version>
   </parent>
 
   <artifactId>logback-access</artifactId>
@@ -91,7 +91,6 @@
             <id>bundle-test-jar</id>
             <phase>package</phase>
             <goals>
-              <goal>jar</goal>
               <goal>test-jar</goal>
             </goals>
           </execution>


=====================================
logback-classic/pom.xml
=====================================
@@ -8,7 +8,7 @@
   <parent>
     <groupId>ch.qos.logback</groupId>
     <artifactId>logback-parent</artifactId>
-    <version>1.2.10</version>
+    <version>1.2.11</version>
   </parent>
 
   <artifactId>logback-classic</artifactId>
@@ -164,7 +164,6 @@
             <id>bundle-test-jar</id>
             <phase>package</phase>
             <goals>
-              <goal>jar</goal>
               <goal>test-jar</goal>
             </goals>
           </execution>


=====================================
logback-classic/src/main/java/ch/qos/logback/classic/joran/action/InsertFromJNDIAction.java
=====================================
@@ -65,7 +65,7 @@ public class InsertFromJNDIAction extends Action {
 
         try {
             Context ctx = JNDIUtil.getInitialContext();
-            envEntryValue = JNDIUtil.lookup(ctx, envEntryName);
+            envEntryValue = JNDIUtil.lookupString(ctx, envEntryName);
             if (OptionHelper.isEmpty(envEntryValue)) {
                 addError("[" + envEntryName + "] has null or empty value");
             } else {


=====================================
logback-classic/src/main/java/ch/qos/logback/classic/selector/ContextJNDISelector.java
=====================================
@@ -84,7 +84,7 @@ public class ContextJNDISelector implements ContextSelector {
             // We first try to find the name of our
             // environment's LoggerContext
             ctx = JNDIUtil.getInitialContext();
-            contextName = (String) JNDIUtil.lookup(ctx, JNDI_CONTEXT_NAME);
+            contextName = (String) JNDIUtil.lookupString(ctx, JNDI_CONTEXT_NAME);
         } catch (NamingException ne) {
             // We can't log here
         }
@@ -127,7 +127,7 @@ public class ContextJNDISelector implements ContextSelector {
 
         String jndiEntryForConfigResource = null;
         try {
-            jndiEntryForConfigResource = JNDIUtil.lookup(ctx, JNDI_CONFIGURATION_RESOURCE);
+            jndiEntryForConfigResource = JNDIUtil.lookupString(ctx, JNDI_CONFIGURATION_RESOURCE);
         } catch (NamingException ne) {
         }
         // Do we have a dedicated configuration file?


=====================================
logback-classic/src/main/java/ch/qos/logback/classic/selector/servlet/ContextDetachingSCL.java
=====================================
@@ -40,7 +40,7 @@ public class ContextDetachingSCL implements ServletContextListener {
 
         try {
             Context ctx = JNDIUtil.getInitialContext();
-            loggerContextName = (String) JNDIUtil.lookup(ctx, JNDI_CONTEXT_NAME);
+            loggerContextName = (String) JNDIUtil.lookupString(ctx, JNDI_CONTEXT_NAME);
         } catch (NamingException ne) {
         }
 


=====================================
logback-classic/src/main/java/ch/qos/logback/classic/spi/ThrowableProxy.java
=====================================
@@ -17,141 +17,196 @@ import ch.qos.logback.core.CoreConstants;
 
 import java.lang.reflect.InvocationTargetException;
 import java.lang.reflect.Method;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.IdentityHashMap;
+import java.util.List;
+import java.util.Set;
 
 public class ThrowableProxy implements IThrowableProxy {
 
-    private Throwable throwable;
-    private String className;
-    private String message;
-    // package-private because of ThrowableProxyUtil
-    StackTraceElementProxy[] stackTraceElementProxyArray;
-    // package-private because of ThrowableProxyUtil
-    int commonFrames;
-    private ThrowableProxy cause;
-    private ThrowableProxy[] suppressed = NO_SUPPRESSED;
-
-    private transient PackagingDataCalculator packagingDataCalculator;
-    private boolean calculatedPackageData = false;
-
-    private static final Method GET_SUPPRESSED_METHOD;
-
-    static {
-        Method method = null;
-        try {
-            method = Throwable.class.getMethod("getSuppressed");
-        } catch (NoSuchMethodException e) {
-            // ignore, will get thrown in Java < 7
-        }
-        GET_SUPPRESSED_METHOD = method;
-    }
-
-    private static final ThrowableProxy[] NO_SUPPRESSED = new ThrowableProxy[0];
-
-    public ThrowableProxy(Throwable throwable) {
-
-        this.throwable = throwable;
-        this.className = throwable.getClass().getName();
-        this.message = throwable.getMessage();
-        this.stackTraceElementProxyArray = ThrowableProxyUtil.steArrayToStepArray(throwable.getStackTrace());
-
-        Throwable nested = throwable.getCause();
-
-        if (nested != null) {
-            this.cause = new ThrowableProxy(nested);
-            this.cause.commonFrames = ThrowableProxyUtil.findNumberOfCommonFrames(nested.getStackTrace(), stackTraceElementProxyArray);
-        }
-        if (GET_SUPPRESSED_METHOD != null) {
-            // this will only execute on Java 7
-            try {
-                Object obj = GET_SUPPRESSED_METHOD.invoke(throwable);
-                if (obj instanceof Throwable[]) {
-                    Throwable[] throwableSuppressed = (Throwable[]) obj;
-                    if (throwableSuppressed.length > 0) {
-                        suppressed = new ThrowableProxy[throwableSuppressed.length];
-                        for (int i = 0; i < throwableSuppressed.length; i++) {
-                            this.suppressed[i] = new ThrowableProxy(throwableSuppressed[i]);
-                            this.suppressed[i].commonFrames = ThrowableProxyUtil.findNumberOfCommonFrames(throwableSuppressed[i].getStackTrace(),
-                                            stackTraceElementProxyArray);
-                        }
-                    }
-                }
-            } catch (IllegalAccessException e) {
-                // ignore
-            } catch (InvocationTargetException e) {
-                // ignore
-            }
-        }
-
-    }
-
-    public Throwable getThrowable() {
-        return throwable;
-    }
-
-    public String getMessage() {
-        return message;
-    }
-
-    /*
-     * (non-Javadoc)
-     * 
-     * @see ch.qos.logback.classic.spi.IThrowableProxy#getClassName()
-     */
-    public String getClassName() {
-        return className;
-    }
-
-    public StackTraceElementProxy[] getStackTraceElementProxyArray() {
-        return stackTraceElementProxyArray;
-    }
-
-    public int getCommonFrames() {
-        return commonFrames;
-    }
-
-    /*
-     * (non-Javadoc)
-     * 
-     * @see ch.qos.logback.classic.spi.IThrowableProxy#getCause()
-     */
-    public IThrowableProxy getCause() {
-        return cause;
-    }
-
-    public IThrowableProxy[] getSuppressed() {
-        return suppressed;
-    }
-
-    public PackagingDataCalculator getPackagingDataCalculator() {
-        // if original instance (non-deserialized), and packagingDataCalculator
-        // is not already initialized, then create an instance.
-        // here we assume that (throwable == null) for deserialized instances
-        if (throwable != null && packagingDataCalculator == null) {
-            packagingDataCalculator = new PackagingDataCalculator();
-        }
-        return packagingDataCalculator;
-    }
-
-    public void calculatePackagingData() {
-        if (calculatedPackageData) {
-            return;
-        }
-        PackagingDataCalculator pdc = this.getPackagingDataCalculator();
-        if (pdc != null) {
-            calculatedPackageData = true;
-            pdc.calculate(this);
-        }
-    }
-
-    public void fullDump() {
-        StringBuilder builder = new StringBuilder();
-        for (StackTraceElementProxy step : stackTraceElementProxyArray) {
-            String string = step.toString();
-            builder.append(CoreConstants.TAB).append(string);
-            ThrowableProxyUtil.subjoinPackagingData(builder, step);
-            builder.append(CoreConstants.LINE_SEPARATOR);
-        }
-        System.out.println(builder.toString());
-    }
+	static final StackTraceElementProxy[] EMPTY_STEP = new StackTraceElementProxy[0];
+
+	private Throwable throwable;
+	private String className;
+	private String message;
+	// package-private because of ThrowableProxyUtil
+	StackTraceElementProxy[] stackTraceElementProxyArray;
+	// package-private because of ThrowableProxyUtil
+	int commonFrames;
+	private ThrowableProxy cause;
+	private static final ThrowableProxy[] NO_SUPPRESSED = new ThrowableProxy[0];
+	private ThrowableProxy[] suppressed = NO_SUPPRESSED;
+
+	// private final Set<Throwable> alreadyProcessedSet;
+
+	private transient PackagingDataCalculator packagingDataCalculator;
+	private boolean calculatedPackageData = false;
+
+	private boolean circular;
+
+	private static final Method GET_SUPPRESSED_METHOD;
+
+	static {
+		Method method = null;
+		try {
+			method = Throwable.class.getMethod("getSuppressed");
+		} catch (NoSuchMethodException e) {
+			// ignore, will get thrown in Java < 7
+		}
+		GET_SUPPRESSED_METHOD = method;
+	}
+
+	public ThrowableProxy(Throwable throwable) {
+		// use an identity set to detect cycles in the throwable chain
+		this(throwable, Collections.newSetFromMap(new IdentityHashMap<Throwable, Boolean>()));
+	}
+
+	// used for circular exceptions
+	private ThrowableProxy(Throwable circular, boolean isCircular) {
+		this.throwable = circular;
+		this.className = circular.getClass().getName();
+		this.message = circular.getMessage();
+		this.stackTraceElementProxyArray = EMPTY_STEP;
+		this.circular = true;
+	}
+
+	public ThrowableProxy(Throwable throwable, Set<Throwable> alreadyProcessedSet) {
+
+		this.throwable = throwable;
+		this.className = throwable.getClass().getName();
+		this.message = throwable.getMessage();
+		this.stackTraceElementProxyArray = ThrowableProxyUtil.steArrayToStepArray(throwable.getStackTrace());
+		this.circular = false;
+
+		alreadyProcessedSet.add(throwable);
+
+		Throwable nested = throwable.getCause();
+		if (nested != null) {
+			if (alreadyProcessedSet.contains(nested)) {
+				this.cause = new ThrowableProxy(nested, true);
+			} else {
+				this.cause = new ThrowableProxy(nested, alreadyProcessedSet);
+				this.cause.commonFrames = ThrowableProxyUtil.findNumberOfCommonFrames(nested.getStackTrace(),
+						stackTraceElementProxyArray);
+			}
+		}
+
+		if (GET_SUPPRESSED_METHOD != null) {
+			// this will only execute on Java 7
+			Throwable[] throwableSuppressed = extractSupressedThrowables(throwable);
+			
+			if (throwableSuppressed.length > 0) {
+				List<ThrowableProxy> suppressedList = new ArrayList<ThrowableProxy>(throwableSuppressed.length);
+				for (Throwable sup : throwableSuppressed) {
+					if (alreadyProcessedSet.contains(sup)) {
+						ThrowableProxy throwableProxy = new ThrowableProxy(sup, true);
+						suppressedList.add(throwableProxy);
+					} else {
+						ThrowableProxy throwableProxy = new ThrowableProxy(sup, alreadyProcessedSet);
+						throwableProxy.commonFrames = ThrowableProxyUtil.findNumberOfCommonFrames(sup.getStackTrace(),
+								stackTraceElementProxyArray);
+						suppressedList.add(throwableProxy);
+					}
+				}
+				this.suppressed = suppressedList.toArray(new ThrowableProxy[suppressedList.size()]);
+			}
+		}
+	}
+
+	private Throwable[] extractSupressedThrowables(Throwable t) {
+		try {
+			Object obj = GET_SUPPRESSED_METHOD.invoke(t);
+			if (obj instanceof Throwable[]) {
+				Throwable[] throwableSuppressed = (Throwable[]) obj;
+				return throwableSuppressed;
+			} else {
+				return null;
+			}
+		} catch (IllegalAccessException e) {
+			// ignore
+		} catch (IllegalArgumentException e) {
+			// ignore
+		} catch (InvocationTargetException e) {
+			// ignore
+		}
+
+		return null;
+
+	}
+
+	public Throwable getThrowable() {
+		return throwable;
+	}
+
+	public String getMessage() {
+		return message;
+	}
+
+	/*
+	 * (non-Javadoc)
+	 * 
+	 * @see ch.qos.logback.classic.spi.IThrowableProxy#getClassName()
+	 */
+	public String getClassName() {
+		return className;
+	}
+
+	public StackTraceElementProxy[] getStackTraceElementProxyArray() {
+		return stackTraceElementProxyArray;
+	}
+
+	public boolean isCyclic() {
+		return circular;
+	}
+
+	public int getCommonFrames() {
+		return commonFrames;
+	}
+
+	/*
+	 * (non-Javadoc)
+	 * 
+	 * @see ch.qos.logback.classic.spi.IThrowableProxy#getCause()
+	 */
+	public IThrowableProxy getCause() {
+		return cause;
+	}
+
+	public IThrowableProxy[] getSuppressed() {
+		return suppressed;
+	}
+
+	public PackagingDataCalculator getPackagingDataCalculator() {
+		// if original instance (non-deserialized), and packagingDataCalculator
+		// is not already initialized, then create an instance.
+		// here we assume that (throwable == null) for deserialized instances
+		if (throwable != null && packagingDataCalculator == null) {
+			packagingDataCalculator = new PackagingDataCalculator();
+		}
+		return packagingDataCalculator;
+	}
+
+	public void calculatePackagingData() {
+		if (calculatedPackageData) {
+			return;
+		}
+		PackagingDataCalculator pdc = this.getPackagingDataCalculator();
+		if (pdc != null) {
+			calculatedPackageData = true;
+			pdc.calculate(this);
+		}
+	}
+
+	public void fullDump() {
+		StringBuilder builder = new StringBuilder();
+		for (StackTraceElementProxy step : stackTraceElementProxyArray) {
+			String string = step.toString();
+			builder.append(CoreConstants.TAB).append(string);
+			ThrowableProxyUtil.subjoinPackagingData(builder, step);
+			builder.append(CoreConstants.LINE_SEPARATOR);
+		}
+		System.out.println(builder.toString());
+	}
 
 }


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/pattern/ThrowableProxyConverterTest.java
=====================================
@@ -22,6 +22,9 @@ import java.util.Arrays;
 import java.util.List;
 
 import ch.qos.logback.core.CoreConstants;
+import ch.qos.logback.core.testUtil.VersionUtil;
+import ch.qos.logback.classic.util.EnvUtil;
+
 import org.junit.After;
 import org.junit.Before;
 import org.junit.Test;
@@ -45,6 +48,8 @@ public class ThrowableProxyConverterTest {
     StringWriter sw = new StringWriter();
     PrintWriter pw = new PrintWriter(sw);
 
+    int javaVersion = VersionUtil.getJavaMajorVersion();
+    
     @Before
     public void setUp() throws Exception {
         tpc.setContext(lc);
@@ -122,6 +127,28 @@ public class ThrowableProxyConverterTest {
         verify(t);
     }
 
+
+    @Test
+    public void cyclicCause() {
+
+        Exception e = new Exception("foo");
+        Exception e2 = new Exception(e);
+        e.initCause(e2);
+        convertToStringResult(e);
+    }
+    
+    @Test
+    public void cyclicSuppressed() {
+
+    	if(javaVersion < 7) {
+    		return;
+    	}
+        Exception e = new Exception("foo");
+        Exception e2 = new Exception(e);
+        e.addSuppressed(e2);
+        convertToStringResult(e);
+    }
+    
     @Test
     public void withArgumentOfOne() throws Exception {
         final Throwable t = TestHelper.makeNestedException(0);
@@ -217,10 +244,15 @@ public class ThrowableProxyConverterTest {
     void verify(Throwable t) {
         t.printStackTrace(pw);
 
-        ILoggingEvent le = createLoggingEvent(t);
+        String result = convertToStringResult(t);
+        assertEquals(sw.toString(), result);
+    }
+
+	private String convertToStringResult(Throwable t) {
+		ILoggingEvent le = createLoggingEvent(t);
         String result = tpc.convert(le);
         System.out.println(result);
         result = result.replace("common frames omitted", "more");
-        assertEquals(sw.toString(), result);
-    }
+		return result;
+	}
 }


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/selector/ContextDetachingSCLTest.java
=====================================
@@ -23,8 +23,9 @@ import org.slf4j.LoggerFactory;
 import ch.qos.logback.classic.ClassicConstants;
 import ch.qos.logback.classic.selector.servlet.ContextDetachingSCL;
 import ch.qos.logback.classic.util.ContextSelectorStaticBinder;
-import ch.qos.logback.classic.util.MockInitialContext;
-import ch.qos.logback.classic.util.MockInitialContextFactory;
+import ch.qos.logback.core.testUtil.MockInitialContext;
+import ch.qos.logback.core.testUtil.MockInitialContextFactory;
+
 import org.slf4j.LoggerFactoryFriend;
 import org.slf4j.impl.StaticLoggerBinderFriend;
 


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/selector/ContextJNDISelectorTest.java
=====================================
@@ -23,9 +23,9 @@ import org.slf4j.impl.StaticLoggerBinderFriend;
 
 import ch.qos.logback.classic.ClassicConstants;
 import ch.qos.logback.classic.util.ContextSelectorStaticBinder;
-import ch.qos.logback.classic.util.MockInitialContext;
-import ch.qos.logback.classic.util.MockInitialContextFactory;
 import ch.qos.logback.core.Context;
+import ch.qos.logback.core.testUtil.MockInitialContext;
+import ch.qos.logback.core.testUtil.MockInitialContextFactory;
 
 public class ContextJNDISelectorTest {
 


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/spi/ThrowableProxyTest.java
=====================================
@@ -15,24 +15,25 @@ package ch.qos.logback.classic.spi;
 
 import static ch.qos.logback.classic.util.TestHelper.addSuppressed;
 import static org.junit.Assert.assertEquals;
-import static org.junit.Assume.assumeNotNull;
 import static org.junit.Assume.assumeTrue;
 
 import java.io.PrintWriter;
 import java.io.StringWriter;
 import java.lang.reflect.InvocationTargetException;
-import java.lang.reflect.Method;
 
-import ch.qos.logback.classic.util.TestHelper;
 import org.junit.After;
 import org.junit.Before;
 import org.junit.Test;
 
+import ch.qos.logback.classic.util.TestHelper;
+import ch.qos.logback.core.testUtil.VersionUtil;
+
 public class ThrowableProxyTest {
 
     StringWriter sw = new StringWriter();
     PrintWriter pw = new PrintWriter(sw);
-
+    int javaVersion = VersionUtil.getJavaMajorVersion();
+    
     @Before
     public void setUp() throws Exception {
     }
@@ -159,6 +160,27 @@ public class ThrowableProxyTest {
         verify(w);
     }
 
+    // see also https://jira.qos.ch/browse/LOGBACK-1454
+    @Test
+    public void nestedLoop1() {
+        Exception e = new Exception("foo");
+        Exception e2 = new Exception(e);
+        e.initCause(e2);
+        new ThrowableProxy(e);
+    }
+
+    // see also https://jira.qos.ch/browse/LOGBACK-1454
+    @Test
+    public void nestedLoop2() {
+    	if(javaVersion < 7) {
+    		return;
+    	}
+        Exception e = new Exception("foo");
+        Exception e2 = new Exception(e);
+        e.addSuppressed(e2);
+        new ThrowableProxy(e);
+    }
+
     void someMethod() throws Exception {
         throw new Exception("someMethod");
     }


=====================================
logback-core/pom.xml
=====================================
@@ -8,7 +8,7 @@
   <parent>
     <groupId>ch.qos.logback</groupId>
     <artifactId>logback-parent</artifactId>
-    <version>1.2.10</version>
+    <version>1.2.11</version>
   </parent>
 
   <artifactId>logback-core</artifactId>
@@ -86,7 +86,6 @@
             <id>bundle-test-jar</id>
             <phase>package</phase>
             <goals>
-              <goal>jar</goal>
               <goal>test-jar</goal>
             </goals>
           </execution>
@@ -124,4 +123,4 @@
     </plugins>
   </build>
 
-</project>
\ No newline at end of file
+</project>


=====================================
logback-core/src/main/java/ch/qos/logback/core/net/SMTPAppenderBase.java
=====================================
@@ -135,7 +135,7 @@ public abstract class SMTPAppenderBase<E> extends AppenderBase<E> {
         addInfo("Looking up javax.mail.Session at JNDI location [" + jndiLocation + "]");
         try {
             Context initialContext = JNDIUtil.getInitialContext();
-            Object obj = JNDIUtil.lookup(initialContext, jndiLocation);
+            Object obj = JNDIUtil.lookupObject(initialContext, jndiLocation);
             return (Session) obj;
         } catch (Exception e) {
             addError("Failed to obtain javax.mail.Session from JNDI location [" + jndiLocation + "]");
@@ -156,7 +156,7 @@ public abstract class SMTPAppenderBase<E> extends AppenderBase<E> {
 
         LoginAuthenticator loginAuthenticator = null;
 
-        if (username != null) {
+        if (!OptionHelper.isEmpty(username)) {
             loginAuthenticator = new LoginAuthenticator(username, password);
             props.put("mail.smtp.auth", "true");
         }
@@ -543,7 +543,7 @@ public abstract class SMTPAppenderBase<E> extends AppenderBase<E> {
         if (to == null || to.length() == 0) {
             throw new IllegalArgumentException("Null or empty <to> property");
         }
-        PatternLayoutBase plb = makeNewToPatternLayout(to.trim());
+        PatternLayoutBase<E> plb = makeNewToPatternLayout(to.trim());
         plb.setContext(context);
         plb.start();
         this.toPatternLayoutList.add(plb);
@@ -553,7 +553,7 @@ public abstract class SMTPAppenderBase<E> extends AppenderBase<E> {
 
     public List<String> getToAsListOfString() {
         List<String> toList = new ArrayList<String>();
-        for (PatternLayoutBase plb : toPatternLayoutList) {
+        for (PatternLayoutBase<E> plb : toPatternLayoutList) {
             toList.add(plb.getPattern());
         }
         return toList;


=====================================
logback-core/src/main/java/ch/qos/logback/core/util/JNDIUtil.java
=====================================
@@ -15,6 +15,8 @@ package ch.qos.logback.core.util;
 
 import static ch.qos.logback.core.CoreConstants.JNDI_JAVA_NAMESPACE;
 
+import java.util.Hashtable;
+
 import javax.naming.Context;
 import javax.naming.InitialContext;
 import javax.naming.NamingException;
@@ -23,33 +25,47 @@ import javax.naming.NamingException;
  * A simple utility class to create and use a JNDI Context.
  *
  * @author Ceki Gülcü
- * @author Michael Osipov 
+ * @author Michael Osipov
  * @author Sébastien Pennec
  * 
  */
 
 public class JNDIUtil {
 
-    static final String RESTRICTION_MSG = "JNDI name must start with " + JNDI_JAVA_NAMESPACE + " but was ";
+	static final String RESTRICTION_MSG = "JNDI name must start with " + JNDI_JAVA_NAMESPACE + " but was ";
 
 	public static Context getInitialContext() throws NamingException {
-        return new InitialContext();
-    }
+		return new InitialContext();
+	}
+
+	public static Context getInitialContext(Hashtable<?,?> props) throws NamingException {
+		return new InitialContext(props);
+	}
 
-    public static String lookup(Context ctx, String name) throws NamingException {
-        if (ctx == null) {
-            return null;
-        }
+	public static Object lookupObject(Context ctx, String name) throws NamingException {
+		if (ctx == null) {
+			return null;
+		}
 
-        if (OptionHelper.isEmpty(name)) {
-            return null;
-        }
+		if (OptionHelper.isEmpty(name)) {
+			return null;
+		}
 
-        if (!name.startsWith(JNDI_JAVA_NAMESPACE)) {
-            throw new NamingException(RESTRICTION_MSG + name);
-        }
+		jndiNameSecurityCheck(name);
 
         Object lookup = ctx.lookup(name);
-        return lookup == null ? null : lookup.toString();
-    }
+        return lookup;
+	}
+
+	private static void jndiNameSecurityCheck(String name) throws NamingException {
+		if (!name.startsWith(JNDI_JAVA_NAMESPACE)) {
+			throw new NamingException(RESTRICTION_MSG + name);
+		}
+	}
+
+	public static String lookupString(Context ctx, String name) throws NamingException {
+		Object lookup = lookupObject(ctx, name);
+		return (String) lookup;
+	}
+
 }


=====================================
logback-core/src/main/java/ch/qos/logback/core/util/OptionHelper.java
=====================================
@@ -17,7 +17,6 @@ import java.lang.reflect.Constructor;
 import java.util.Properties;
 
 import ch.qos.logback.core.Context;
-import ch.qos.logback.core.CoreConstants;
 import ch.qos.logback.core.spi.ContextAware;
 import ch.qos.logback.core.spi.PropertyContainer;
 import ch.qos.logback.core.spi.ScanException;
@@ -258,7 +257,7 @@ public class OptionHelper {
     }
 
     public static boolean isEmpty(String str) {
-        return ((str == null) || CoreConstants.EMPTY_STRING.equals(str));
+        return ((str == null) || str.length() == 0);
     }
 
 }


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/util/MockInitialContext.java → logback-core/src/test/java/ch/qos/logback/core/testUtil/MockInitialContext.java
=====================================
@@ -11,7 +11,7 @@
  * under the terms of the GNU Lesser General Public License version 2.1
  * as published by the Free Software Foundation.
  */
-package ch.qos.logback.classic.util;
+package ch.qos.logback.core.testUtil;
 
 import java.util.HashMap;
 import java.util.Map;


=====================================
logback-classic/src/test/java/ch/qos/logback/classic/util/MockInitialContextFactory.java → logback-core/src/test/java/ch/qos/logback/core/testUtil/MockInitialContextFactory.java
=====================================
@@ -11,7 +11,7 @@
  * under the terms of the GNU Lesser General Public License version 2.1
  * as published by the Free Software Foundation.
  */
-package ch.qos.logback.classic.util;
+package ch.qos.logback.core.testUtil;
 
 import java.util.Hashtable;
 


=====================================
logback-core/src/test/java/ch/qos/logback/core/testUtil/VersionUtil.java
=====================================
@@ -0,0 +1,52 @@
+/**
+ * Logback: the reliable, generic, fast and flexible logging framework.
+ * Copyright (C) 1999-2022, 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.testUtil;
+
+public class VersionUtil {
+
+    static final int DEFAULT_GUESS = 6;
+
+    static public int getJavaMajorVersion() {
+        String javaVersionString = System.getProperty("java.version");
+        int result = getJavaMajorVersion(javaVersionString);
+        return result;
+    }
+
+    static public int getJavaMajorVersion(String versionString) {
+        if (versionString == null)
+            return DEFAULT_GUESS;
+        if (versionString.startsWith("1.")) {
+            return versionString.charAt(2) - '0';
+        } else {
+            String firstDigits = extractFirstDigits(versionString);
+            try {
+               return Integer.parseInt(firstDigits);
+            } catch(NumberFormatException e) {
+                return DEFAULT_GUESS;
+            }
+        }
+    }
+
+    private static String extractFirstDigits(String versionString) {
+        StringBuffer buf = new StringBuffer();
+        for (char c : versionString.toCharArray()) {
+            if (Character.isDigit(c))
+                buf.append(c);
+            else
+                break;
+        }
+        return buf.toString();
+
+    }
+}


=====================================
logback-core/src/test/java/ch/qos/logback/core/testUtil/VersionUtilTest.java
=====================================
@@ -0,0 +1,33 @@
+package ch.qos.logback.core.testUtil;
+
+import static org.junit.Assert.assertEquals;
+
+import org.junit.Test;
+
+public class VersionUtilTest {
+
+    
+    @Test
+    public void test() {
+        System.out.println(System.getProperty("java.version"));
+        assertEquals(6, VersionUtil.getJavaMajorVersion("1.6"));
+        assertEquals(7, VersionUtil.getJavaMajorVersion("1.7.0_21-b11"));
+        assertEquals(8, VersionUtil.getJavaMajorVersion("1.8.0_25"));
+    }
+
+    @Test 
+    public void testJava9() {
+        assertEquals(9, VersionUtil.getJavaMajorVersion("9"));
+        assertEquals(9, VersionUtil.getJavaMajorVersion("9.12"));
+        assertEquals(9, VersionUtil.getJavaMajorVersion("9ea"));
+        
+    }
+
+    @Test 
+    public void testJava11() {
+        assertEquals(11, VersionUtil.getJavaMajorVersion("11"));
+        assertEquals(11, VersionUtil.getJavaMajorVersion("11.612"));
+
+    }
+
+}


=====================================
logback-core/src/test/java/ch/qos/logback/core/util/CoreTestConstants.java
=====================================
@@ -29,4 +29,5 @@ public class CoreTestConstants {
     public static final String BASH_PATH_ON_LINUX = "bash";
 
     public static final String SLOW_JENKINS = "slowJenkins";
+    public static final String JAVA_NAMING_FACTORY_INITIAL = "java.naming.factory.initial";
 }


=====================================
logback-core/src/test/java/ch/qos/logback/core/util/JNDIUtilTest.java
=====================================
@@ -1,23 +1,28 @@
 package ch.qos.logback.core.util;
 
-import static org.junit.Assert.*;
+import static org.junit.Assert.assertNull;
+import static org.junit.Assert.fail;
+
+import java.util.Hashtable;
 
 import javax.naming.Context;
 import javax.naming.NamingException;
 
 import org.junit.Test;
 
+import ch.qos.logback.core.testUtil.MockInitialContextFactory;
+
 public class JNDIUtilTest {
 
 	@Test
 	public void ensureJavaNameSpace() throws NamingException {
-		Context ctxt = JNDIUtil.getInitialContext();
 
 		try {
-			JNDIUtil.lookup(ctxt, "ldap:...");
+			Context ctxt = JNDIUtil.getInitialContext();
+			JNDIUtil.lookupString(ctxt, "ldap:...");
 		} catch (NamingException e) {
 			String excaptionMsg = e.getMessage();
-			if(excaptionMsg.startsWith(JNDIUtil.RESTRICTION_MSG)) 
+			if (excaptionMsg.startsWith(JNDIUtil.RESTRICTION_MSG))
 				return;
 			else {
 				fail("unexpected exception " + e);
@@ -27,4 +32,18 @@ public class JNDIUtilTest {
 		fail("Should aNot yet implemented");
 	}
 
+	@Test
+	public void testToStringCast() throws NamingException {
+		Hashtable<String, String> props = new Hashtable<String, String>();
+		props.put(CoreTestConstants.JAVA_NAMING_FACTORY_INITIAL, MockInitialContextFactory.class.getCanonicalName());
+		Context ctxt = JNDIUtil.getInitialContext(props);
+		String x = JNDIUtil.lookupString(ctxt, "java:comp:/inexistent");
+		assertNull(x);
+	}
+
+	public String castToString(Object input) {
+		String a = (String) input;
+		return a;
+	}
+
 }


=====================================
logback-examples/pom.xml
=====================================
@@ -8,7 +8,7 @@
   <parent>
     <groupId>ch.qos.logback</groupId>
     <artifactId>logback-parent</artifactId>
-    <version>1.2.10</version>
+    <version>1.2.11</version>
   </parent>
 
   <artifactId>logback-examples</artifactId>
@@ -100,4 +100,4 @@
 
    </plugins>
   </build>
-</project>
\ No newline at end of file
+</project>


=====================================
logback-site/pom.xml
=====================================
@@ -7,7 +7,7 @@
   <parent>
     <groupId>ch.qos.logback</groupId>
     <artifactId>logback-parent</artifactId>
-    <version>1.2.10</version>
+    <version>1.2.11</version>
   </parent>
 
   <artifactId>logback-site</artifactId>


=====================================
pom.xml
=====================================
@@ -7,7 +7,7 @@
 
   <groupId>ch.qos.logback</groupId>
   <artifactId>logback-parent</artifactId>
-  <version>1.2.10</version>
+  <version>1.2.11</version>
   <packaging>pom</packaging>
 
   <name>Logback-Parent</name>
@@ -47,6 +47,7 @@
   </modules>
 
   <properties>
+    <project.build.outputTimestamp>2022-03-05T19:45:00Z</project.build.outputTimestamp>    
     <maven.compiler.source>1.6</maven.compiler.source>
     <maven.compiler.target>1.6</maven.compiler.target>
     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
@@ -71,11 +72,12 @@
     <maven-javadoc-plugin.version>3.1.0</maven-javadoc-plugin.version>
     <maven-source-plugin.version>3.2.0</maven-source-plugin.version>
     <maven-license-plugin.version>3.0</maven-license-plugin.version>
-    <maven-jar-plugin.version>2.6</maven-jar-plugin.version>
+    <maven-jar-plugin.version>3.2.2</maven-jar-plugin.version>
     <maven-jxr-plugin.version>3.1.1</maven-jxr-plugin.version>
     <maven-deploy-plugin.version>3.0.0-M1</maven-deploy-plugin.version>
     <cobertura.maven.plugin.version>2.7</cobertura.maven.plugin.version>
-
+    <maven-bundle-plugin.version>5.1.4</maven-bundle-plugin.version>
+    
   </properties>
 
   <developers>
@@ -286,7 +288,7 @@
         <plugin>
           <groupId>org.apache.felix</groupId>
           <artifactId>maven-bundle-plugin</artifactId>
-          <version>2.5.4</version>
+          <version>${maven-bundle-plugin.version}</version>
         </plugin>
 
         <plugin>
@@ -348,8 +350,6 @@
         </configuration>
       </plugin>
 
- 
-
 
       <!-- ================ site plugin ==================== -->
       <plugin>
@@ -435,6 +435,33 @@
   </distributionManagement>
 
   <profiles>
+
+    <profile>
+      <id>java6</id>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-toolchains-plugin</artifactId>
+            <version>1.1</version>
+            <executions>
+              <execution>
+                <goals>
+                  <goal>toolchain</goal>
+                </goals>
+              </execution>
+            </executions>
+            <configuration>
+              <toolchains>
+                <jdk>
+                  <version>1.6</version>
+                </jdk>
+              </toolchains>
+            </configuration>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
     <profile>
       <id>testSkip</id>
       <properties>



View it on GitLab: https://salsa.debian.org/java-team/logback/-/commit/f279610de4947a1b13fbe8185b02e5a805e1a371

-- 
View it on GitLab: https://salsa.debian.org/java-team/logback/-/commit/f279610de4947a1b13fbe8185b02e5a805e1a371
You're receiving this email because of your account on salsa.debian.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-java-commits/attachments/20220323/cf18b9b7/attachment.htm>


More information about the pkg-java-commits mailing list