[Git][java-team/jboss-logmanager][upstream] New upstream version 2.1.15

Markus Koschany gitlab at salsa.debian.org
Sun Apr 26 00:15:52 BST 2020



Markus Koschany pushed to branch upstream at Debian Java Maintainers / jboss-logmanager


Commits:
cfbe16e1 by Markus Koschany at 2020-04-26T01:07:04+02:00
New upstream version 2.1.15
- - - - -


7 changed files:

- + .github/workflows/maven.yml
- pom.xml
- src/main/java/org/jboss/logmanager/ClassLoaderLogContextSelector.java
- src/main/java/org/jboss/logmanager/JDKSpecific.java
- src/main/java/org/jboss/logmanager/LogContext.java
- src/main/java/org/jboss/logmanager/Logger.java
- src/main/java9/org/jboss/logmanager/JDKSpecific.java


Changes:

=====================================
.github/workflows/maven.yml
=====================================
@@ -0,0 +1,41 @@
+# This workflow will build a Java project with Maven
+# For more information see: https://help.github.com/actions/language-and-framework-guides/building-and-testing-java-with-maven
+
+name: Java CI with Maven
+
+on:
+  push:
+    branches: [ '**' ]
+  pull_request:
+    branches: [ '**' ]
+
+jobs:
+  build:
+
+    runs-on: ${{ matrix.os }}
+    strategy:
+      matrix:
+        os: [ubuntu-latest, windows-latest ]
+
+    steps:
+      - uses: actions/checkout at v2
+      - uses: actions/cache at v1
+        with:
+          path: ~/.m2/repository
+          key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
+          restore-keys: |
+            ${{ runner.os }}-maven-
+      - name: Set up JDK 1.8
+        uses: actions/setup-java at v1
+        with:
+          java-version: 1.8
+      - name: Set up JDK 11
+        uses: actions/setup-java at v1
+        with:
+          java-version: 11
+      - name: Build with Maven Linux
+        if: runner.os == 'Linux'
+        run: mvn verify -Djava8.home=$JAVA_HOME_8_X64
+      - name: Build with Maven Windows
+        if: runner.os == 'Windows'
+        run: mvn verify '-Djava8.home="%JAVA_HOME_8_X64%"'


=====================================
pom.xml
=====================================
@@ -28,7 +28,7 @@
     <groupId>org.jboss.logmanager</groupId>
     <artifactId>jboss-logmanager</artifactId>
     <packaging>jar</packaging>
-    <version>2.1.14.Final</version>
+    <version>2.1.15.Final</version>
 
     <parent>
         <groupId>org.jboss</groupId>


=====================================
src/main/java/org/jboss/logmanager/ClassLoaderLogContextSelector.java
=====================================
@@ -20,12 +20,12 @@
 package org.jboss.logmanager;
 
 import java.security.AccessController;
-import java.security.PrivilegedAction;
 import java.security.Permission;
-import java.util.Collection;
+import java.security.PrivilegedAction;
 import java.util.Collections;
 import java.util.Set;
 import java.util.concurrent.ConcurrentMap;
+import java.util.function.Function;
 
 /**
  * A log context selector which chooses a log context based on the caller's classloader.
@@ -88,31 +88,32 @@ public final class ClassLoaderLogContextSelector implements LogContextSelector {
     private final Set<ClassLoader> logApiClassLoaders = Collections.newSetFromMap(new CopyOnWriteMap<ClassLoader, Boolean>());
     private final boolean checkParentClassLoaders;
 
-    private final PrivilegedAction<LogContext> logContextAction = new PrivilegedAction<LogContext>() {
-        public LogContext run() {
-            final Collection<Class<?>> callingClasses = JDKSpecific.findCallingClasses(logApiClassLoaders);
-            for (Class<?> caller : callingClasses) {
-                final LogContext result = check(caller.getClassLoader());
-                if (result != null) {
-                    return result;
-                }
-            }
-            return defaultSelector.getLogContext();
-        }
+    private final Function<ClassLoader, LogContext> logContextFinder = new Function<ClassLoader, LogContext>() {
+        @Override
+        public LogContext apply(final ClassLoader classLoader) {
 
-        private LogContext check(final ClassLoader classLoader) {
             final LogContext context = contextMap.get(classLoader);
             if (context != null) {
                 return context;
             }
             final ClassLoader parent = classLoader.getParent();
-            if (parent != null && checkParentClassLoaders && ! logApiClassLoaders.contains(parent)) {
-                return check(parent);
+            if (parent != null && checkParentClassLoaders && !logApiClassLoaders.contains(parent)) {
+                return apply(parent);
             }
             return null;
         }
     };
 
+    private final PrivilegedAction<LogContext> logContextAction = new PrivilegedAction<LogContext>() {
+        public LogContext run() {
+            final LogContext result = JDKSpecific.logContextFinder(logApiClassLoaders, logContextFinder);
+            if (result != null) {
+                return result;
+            }
+            return defaultSelector.getLogContext();
+        }
+    };
+
     /**
      * {@inheritDoc}  This instance will consult the call stack to see if any calling classloader is associated
      * with any log context.


=====================================
src/main/java/org/jboss/logmanager/JDKSpecific.java
=====================================
@@ -21,9 +21,8 @@ package org.jboss.logmanager;
 
 import java.security.AccessController;
 import java.security.PrivilegedAction;
-import java.util.Collection;
-import java.util.LinkedHashSet;
 import java.util.Set;
+import java.util.function.Function;
 
 import org.jboss.modules.Module;
 import org.jboss.modules.Version;
@@ -69,15 +68,17 @@ final class JDKSpecific {
         return null;
     }
 
-    static Collection<Class<?>> findCallingClasses(Set<ClassLoader> rejectClassLoaders) {
-        final Collection<Class<?>> result = new LinkedHashSet<>();
+    static LogContext logContextFinder(Set<ClassLoader> rejectClassLoaders, final Function<ClassLoader, LogContext> finder) {
         for (Class<?> caller : GATEWAY.getClassContext()) {
             final ClassLoader classLoader = caller.getClassLoader();
             if (classLoader != null && !rejectClassLoaders.contains(classLoader)) {
-                result.add(caller);
+                final LogContext result = finder.apply(classLoader);
+                if (result != null) {
+                    return result;
+                }
             }
         }
-        return result;
+        return null;
     }
 
     static void calculateCaller(ExtLogRecord logRecord) {


=====================================
src/main/java/org/jboss/logmanager/LogContext.java
=====================================
@@ -422,6 +422,10 @@ public final class LogContext implements Protectable, AutoCloseable {
      * @param closeHandler the close handler to use
      */
     public void addCloseHandler(final AutoCloseable closeHandler) {
+        final SecurityManager sm = System.getSecurityManager();
+        if (sm != null) {
+            sm.checkPermission(CONTROL_PERMISSION);
+        }
         synchronized (treeLock) {
             closeHandlers.add(closeHandler);
         }
@@ -449,6 +453,10 @@ public final class LogContext implements Protectable, AutoCloseable {
      * @param closeHandlers the close handlers to use
      */
     public void setCloseHandlers(final Collection<AutoCloseable> closeHandlers) {
+        final SecurityManager sm = System.getSecurityManager();
+        if (sm != null) {
+            sm.checkPermission(CONTROL_PERMISSION);
+        }
         synchronized (treeLock) {
             this.closeHandlers.clear();
             this.closeHandlers.addAll(closeHandlers);


=====================================
src/main/java/org/jboss/logmanager/Logger.java
=====================================
@@ -83,8 +83,8 @@ public final class Logger extends java.util.logging.Logger implements Serializab
     Logger(final LoggerNode loggerNode, final String name) {
         // Don't set up the bundle in the parent...
         super(name, null);
-        // We maintain our own level
-        super.setLevel(Level.ALL);
+        // We have to propagate our level to an internal data structure in the superclass
+        super.setLevel(loggerNode.getLevel());
         this.loggerNode = loggerNode;
     }
 
@@ -116,6 +116,8 @@ public final class Logger extends java.util.logging.Logger implements Serializab
      */
     public void setLevel(Level newLevel) throws SecurityException {
         LogContext.checkAccess(loggerNode.getContext());
+        // We have to propagate our level to an internal data structure in the superclass
+        super.setLevel(newLevel);
         loggerNode.setLevel(newLevel);
     }
 


=====================================
src/main/java9/org/jboss/logmanager/JDKSpecific.java
=====================================
@@ -23,10 +23,8 @@ import static java.security.AccessController.doPrivileged;
 
 import java.lang.module.ModuleDescriptor;
 import java.security.PrivilegedAction;
-import java.util.Collection;
 import java.util.EnumSet;
 import java.util.Iterator;
-import java.util.LinkedHashSet;
 import java.util.Optional;
 import java.util.Set;
 import java.util.function.Function;
@@ -64,12 +62,12 @@ final class JDKSpecific {
         }
     }
 
-    static Collection<Class<?>> findCallingClasses(Set<ClassLoader> rejectClassLoaders) {
+    static LogContext logContextFinder(Set<ClassLoader> rejectClassLoaders, final Function<ClassLoader, LogContext> finder) {
         final SecurityManager sm = System.getSecurityManager();
         if (sm != null) {
-            return doPrivileged(new FindCallingClassesAction(rejectClassLoaders));
+            return doPrivileged(new FindCallingClassesAction(rejectClassLoaders, finder));
         } else {
-            return WALKER.walk(new FindAllWalkFunction(rejectClassLoaders));
+            return WALKER.walk(new FindAllWalkFunction(rejectClassLoaders, finder));
         }
     }
 
@@ -163,15 +161,17 @@ final class JDKSpecific {
         }
     }
 
-    static final class FindCallingClassesAction implements PrivilegedAction<Collection<Class<?>>> {
+    static final class FindCallingClassesAction implements PrivilegedAction<LogContext> {
         private final Set<ClassLoader> rejectClassLoaders;
+        private final Function<ClassLoader, LogContext> finder;
 
-        FindCallingClassesAction(final Set<ClassLoader> rejectClassLoaders) {
+        FindCallingClassesAction(final Set<ClassLoader> rejectClassLoaders, final Function<ClassLoader, LogContext> finder) {
             this.rejectClassLoaders = rejectClassLoaders;
+            this.finder = finder;
         }
 
-        public Collection<Class<?>> run() {
-            return WALKER.walk(new FindAllWalkFunction(rejectClassLoaders));
+        public LogContext run() {
+            return WALKER.walk(new FindAllWalkFunction(rejectClassLoaders, finder));
         }
     }
 
@@ -195,24 +195,29 @@ final class JDKSpecific {
         }
     }
 
-    static final class FindAllWalkFunction implements Function<Stream<StackWalker.StackFrame>, Collection<Class<?>>> {
+    static final class FindAllWalkFunction implements Function<Stream<StackWalker.StackFrame>, LogContext> {
         private final Set<ClassLoader> rejectClassLoaders;
+        private final Function<ClassLoader, LogContext> finder;
 
-        FindAllWalkFunction(final Set<ClassLoader> rejectClassLoaders) {
+        FindAllWalkFunction(final Set<ClassLoader> rejectClassLoaders, final Function<ClassLoader, LogContext> finder) {
             this.rejectClassLoaders = rejectClassLoaders;
+            this.finder = finder;
         }
 
-        public Collection<Class<?>> apply(final Stream<StackWalker.StackFrame> stream) {
-            final Collection<Class<?>> results = new LinkedHashSet<>();
+        @Override
+        public LogContext apply(final Stream<StackWalker.StackFrame> stream) {
             final Iterator<StackWalker.StackFrame> iterator = stream.iterator();
             while (iterator.hasNext()) {
                 final Class<?> clazz = iterator.next().getDeclaringClass();
                 final ClassLoader classLoader = clazz.getClassLoader();
                 if (classLoader != null && ! rejectClassLoaders.contains(classLoader)) {
-                    results.add(clazz);
+                    final LogContext result = finder.apply(classLoader);
+                    if (result != null) {
+                        return result;
+                    }
                 }
             }
-            return results;
+            return null;
         }
     }
 }



View it on GitLab: https://salsa.debian.org/java-team/jboss-logmanager/-/commit/cfbe16e14733a323b8097f5ae60ba9e61cf805dd

-- 
View it on GitLab: https://salsa.debian.org/java-team/jboss-logmanager/-/commit/cfbe16e14733a323b8097f5ae60ba9e61cf805dd
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/20200425/3345fc48/attachment.html>


More information about the pkg-java-commits mailing list