You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@tomee.apache.org by rm...@apache.org on 2012/11/14 14:38:34 UTC

svn commit: r1409196 - /openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java

Author: rmannibucau
Date: Wed Nov 14 13:38:33 2012
New Revision: 1409196

URL: http://svn.apache.org/viewvc?rev=1409196&view=rev
Log:
TOMEE-569 cdi in ear deploymentBeans doesn't contain ear lib part

Modified:
    openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java

Modified: openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java
URL: http://svn.apache.org/viewvc/openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java?rev=1409196&r1=1409195&r2=1409196&view=diff
==============================================================================
--- openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java (original)
+++ openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/cdi/WebappBeanManager.java Wed Nov 14 13:38:33 2012
@@ -16,12 +16,8 @@
  */
 package org.apache.openejb.cdi;
 
-import java.lang.annotation.Annotation;
-import java.lang.reflect.Type;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
+import org.apache.webbeans.container.BeanManagerImpl;
+
 import javax.el.ELResolver;
 import javax.el.ExpressionFactory;
 import javax.enterprise.context.spi.Context;
@@ -36,7 +32,13 @@ import javax.enterprise.inject.spi.Injec
 import javax.enterprise.inject.spi.InterceptionType;
 import javax.enterprise.inject.spi.Interceptor;
 import javax.enterprise.inject.spi.ObserverMethod;
-import org.apache.webbeans.container.BeanManagerImpl;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Type;
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.concurrent.CopyOnWriteArraySet;
 
 public class WebappBeanManager extends BeanManagerImpl {
     private final WebappWebBeansContext webappCtx;
@@ -46,6 +48,7 @@ public class WebappBeanManager extends B
             return false;
         }
     };
+    private final Set<Bean<?>> deploymentBeans = new CopyOnWriteArraySet<Bean<?>>();
 
     public WebappBeanManager(WebappWebBeansContext ctx) {
         super(ctx);
@@ -359,7 +362,27 @@ public class WebappBeanManager extends B
         return super.wrapExpressionFactory(getParentBm().wrapExpressionFactory(expressionFactory));
     }
 
-    public BeanManager getParentBm() {
+    public BeanManagerImpl getParentBm() {
         return webappCtx.getParent().getBeanManagerImpl();
     }
+
+    @Override
+    public BeanManager addInternalBean(Bean<?> newBean) {
+        super.addInternalBean(newBean);
+
+        deploymentBeans.clear();
+        deploymentBeans.addAll(getParentBm().getBeans());
+        deploymentBeans.addAll(super.getBeans());
+        return this;
+    }
+
+    @Override
+    public Set<Bean<?>> getComponents() {
+        return deploymentBeans;
+    }
+
+    @Override
+    public Set<Bean<?>> getBeans() {
+        return deploymentBeans;
+    }
 }