Author: rmannibucau
Date: Fri Aug 10 17:21:31 2012
New Revision: 1371773

URL: http://svn.apache.org/viewvc?rev=1371773&view=rev
Log:
caching MyFaces faces-config.xml resources to avoid to scan multiple times the 
same app

Added:
    
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEMyFacesContextListener.java
Modified:
    
openejb/trunk/openejb/tomee/tomee-catalina/src/main/java/org/apache/tomee/catalina/OpenEJBContextConfig.java
    
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEFacesConfigResourceProvider.java

Modified: 
openejb/trunk/openejb/tomee/tomee-catalina/src/main/java/org/apache/tomee/catalina/OpenEJBContextConfig.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/tomee/tomee-catalina/src/main/java/org/apache/tomee/catalina/OpenEJBContextConfig.java?rev=1371773&r1=1371772&r2=1371773&view=diff
==============================================================================
--- 
openejb/trunk/openejb/tomee/tomee-catalina/src/main/java/org/apache/tomee/catalina/OpenEJBContextConfig.java
 (original)
+++ 
openejb/trunk/openejb/tomee/tomee-catalina/src/main/java/org/apache/tomee/catalina/OpenEJBContextConfig.java
 Fri Aug 10 17:21:31 2012
@@ -44,6 +44,7 @@ public class OpenEJBContextConfig extend
 
     private static final String MYFACES_STARTUP_SERVLET_CONTEXT_LISTENER = 
"org.apache.myfaces.webapp.StartupServletContextListener";
     private static final String MYFACES_TOMEEM_CONTAINER_INITIALIZER = 
"org.apache.tomee.myfaces.TomEEMyFacesContainerInitializer";
+    private static final String TOMEE_MYFACES_CONTEXT_LISTENER = 
"org.apache.tomee.myfaces.TomEEMyFacesContextListener";
 
     private TomcatWebAppBuilder.StandardContextInfo info;
 
@@ -93,6 +94,7 @@ public class OpenEJBContextConfig extend
             if 
(!Arrays.asList(context.findApplicationListeners()).contains(MYFACES_STARTUP_SERVLET_CONTEXT_LISTENER))
 {
                 
context.addApplicationListener(MYFACES_STARTUP_SERVLET_CONTEXT_LISTENER);
             }
+            context.addApplicationListener(TOMEE_MYFACES_CONTEXT_LISTENER); // 
cleanup listener
         } catch (Exception ignored) {
             // no-op
         }

Modified: 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEFacesConfigResourceProvider.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEFacesConfigResourceProvider.java?rev=1371773&r1=1371772&r2=1371773&view=diff
==============================================================================
--- 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEFacesConfigResourceProvider.java
 (original)
+++ 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEFacesConfigResourceProvider.java
 Fri Aug 10 17:21:31 2012
@@ -27,10 +27,11 @@ import javax.faces.context.ExternalConte
 import java.io.File;
 import java.io.IOException;
 import java.net.URL;
-import java.util.ArrayList;
 import java.util.Collection;
 import java.util.Enumeration;
-import java.util.List;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
 import java.util.jar.JarEntry;
 import java.util.jar.JarFile;
 import java.util.regex.Pattern;
@@ -40,12 +41,19 @@ public class TomEEFacesConfigResourcePro
     private static final String FACES_CONFIG_SUFFIX = ".faces-config.xml";
     private static final String FACES_CONFIG_IMPLICIT = 
"META-INF/faces-config.xml";
     private static final Pattern FILE_PATTERN = Pattern.compile("^.*" + 
Pattern.quote(FACES_CONFIG_SUFFIX) + "$");
+    private static final Map<ClassLoader, Collection<URL>> CACHED_RESOURCES = 
new HashMap<ClassLoader, Collection<URL>>();
 
     @Override
     public Collection<URL> getMetaInfConfigurationResources(final 
ExternalContext context) throws IOException {
-        final List<URL> urlSet = new ArrayList<URL>();
         final ClassLoader loader = getClassLoader();
 
+        Collection<URL> urlSet = CACHED_RESOURCES.get(loader);
+        if (urlSet != null) {
+            return urlSet;
+        }
+
+        urlSet  = new HashSet<URL>();
+
         final Enumeration<URL> resources = 
loader.getResources(FACES_CONFIG_IMPLICIT);
         while (resources.hasMoreElements()) {
             urlSet.add(resources.nextElement());
@@ -83,6 +91,7 @@ public class TomEEFacesConfigResourcePro
             }
         }
 
+        CACHED_RESOURCES.put(loader, urlSet);
         return urlSet;
     }
 
@@ -93,4 +102,8 @@ public class TomEEFacesConfigResourcePro
         }
         return loader;
     }
+
+    public static void clear(final ClassLoader loader) {
+        CACHED_RESOURCES.remove(loader);
+    }
 }

Added: 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEMyFacesContextListener.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEMyFacesContextListener.java?rev=1371773&view=auto
==============================================================================
--- 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEMyFacesContextListener.java
 (added)
+++ 
openejb/trunk/openejb/tomee/tomee-myfaces/src/main/java/org/apache/tomee/myfaces/TomEEMyFacesContextListener.java
 Fri Aug 10 17:21:31 2012
@@ -0,0 +1,16 @@
+package org.apache.tomee.myfaces;
+
+import javax.servlet.ServletContextEvent;
+import javax.servlet.ServletContextListener;
+
+public class TomEEMyFacesContextListener implements ServletContextListener {
+    @Override
+    public void contextInitialized(final ServletContextEvent sce) {
+        // no-op
+    }
+
+    @Override
+    public void contextDestroyed(final ServletContextEvent sce) {
+        
TomEEFacesConfigResourceProvider.clear(sce.getServletContext().getClassLoader());
+    }
+}


Reply via email to