[webbeans-commits] Webbeans SVN: r841 - in tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api: util and 1 other directory.
by webbeans-commits@lists.jboss.org
Author: shane.bryzak(a)jboss.com
Date: 2009-01-09 02:25:50 -0500 (Fri, 09 Jan 2009)
New Revision: 841
Added:
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/TckUtils.java
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/Reflections.java
Modified:
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Beans.java
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Contexts.java
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Managers.java
tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/DeploymentProperties.java
Log:
refactor
Modified: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Beans.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Beans.java 2009-01-09 06:41:20 UTC (rev 840)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Beans.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -5,7 +5,7 @@
*
* @author Shane Bryzak
*/
-public abstract class Beans extends Configurable
+public interface Beans
{
}
Modified: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Contexts.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Contexts.java 2009-01-09 06:41:20 UTC (rev 840)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Contexts.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -1,10 +1,32 @@
package org.jboss.webbeans.tck.api;
+import javax.webbeans.manager.Context;
+
/**
+ * Context related operations
*
* @author Shane Bryzak
*/
-public abstract class Contexts extends Configurable
+public interface Contexts
{
-
+ /**
+ * Sets the specified context as active
+ *
+ * @param context The context to set active
+ */
+ void setActive(Context context);
+
+ /**
+ * Sets the specified context as inactive
+ *
+ * @param context The context to set inactive
+ */
+ void setInactive(Context context);
+
+ /**
+ * Creates a new request context
+ *
+ * @return The new request context
+ */
+ Context createRequestContext();
}
Modified: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Managers.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Managers.java 2009-01-09 06:41:20 UTC (rev 840)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/Managers.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -6,35 +6,25 @@
import javax.webbeans.manager.Manager;
/**
- * This class provides operations relating to a Web Beans Manager.
+ * This interface provides operations relating to a Web Beans Manager.
*
- * The TCK porting package must provide an implementation of this abstract class which is
+ * The TCK porting package must provide an implementation of this interface which is
* suitable for the target Web Beans implementation.
*
* @author Shane Bryzak
*/
-public abstract class Managers extends Configurable
-{
+public interface Managers
+{
/**
- * Returns the concrete implementation of Managers
*
- * @return
- */
- public static Managers instance()
- {
- return (Managers) getInstance(Managers.class);
- }
-
- /**
- *
* @param enabledDeploymentTypes
*/
- public abstract void setEnabledDeploymentTypes(List<Class<? extends Annotation>> enabledDeploymentTypes);
+ void setEnabledDeploymentTypes(List<Class<? extends Annotation>> enabledDeploymentTypes);
/**
* Creates a new Manager instance
*
* @return The new Manager
*/
- public abstract Manager createManager();
+ Manager createManager();
}
Added: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/TckUtils.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/TckUtils.java (rev 0)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/TckUtils.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -0,0 +1,62 @@
+package org.jboss.webbeans.tck.api;
+
+import java.lang.reflect.Constructor;
+
+import org.jboss.webbeans.tck.api.util.DeploymentProperties;
+import org.jboss.webbeans.tck.api.util.Reflections;
+
+/**
+ *
+ * @author Shane Bryzak
+ *
+ */
+public class TckUtils
+{
+ private static DeploymentProperties deploymentProperties = new DeploymentProperties();
+
+ public static Managers getManagers()
+ {
+ Managers managers = null;
+
+ for (Class<? extends Managers> cls : deploymentProperties.getClasses(Managers.class.getName(), Managers.class))
+ {
+ Constructor<? extends Managers> constructor = Reflections.getConstructor(cls);
+ if (constructor != null)
+ {
+ try
+ {
+ managers = constructor.newInstance();
+ }
+ catch (Exception ex)
+ {
+ // Do something with the exception (log it?)
+ }
+ }
+ }
+
+ return managers;
+ }
+
+ public static Contexts getContexts()
+ {
+ Contexts contexts = null;
+
+ for (Class<? extends Contexts> cls : deploymentProperties.getClasses(Contexts.class.getName(), Contexts.class))
+ {
+ Constructor<? extends Contexts> constructor = Reflections.getConstructor(cls);
+ if (constructor != null)
+ {
+ try
+ {
+ contexts = constructor.newInstance();
+ }
+ catch (Exception ex)
+ {
+ // Do something with the exception (log it?)
+ }
+ }
+ }
+
+ return contexts;
+ }
+}
Modified: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/DeploymentProperties.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/DeploymentProperties.java 2009-01-09 06:41:20 UTC (rev 840)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/DeploymentProperties.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -40,9 +40,6 @@
* First, System properties are tried, followed by the specified resource
* bundle (first in classpath only).
*
- * Colon (:) deliminated lists are split out. (gotta love Petes choice of
- * ASCII art for that one ;-)
- *
* @param key The key to search for
* @return A list of possible values. An empty list is returned if there are
* no matches.
@@ -131,10 +128,10 @@
* @return A set of classes specified
*/
@SuppressWarnings("unchecked")
- public static <T> Set<Class<? extends T>> getClasses(DeploymentProperties deploymentProperties, SimpleResourceLoader resourceLoader, String propertyName, Class<T> expectedType)
+ public <T> Set<Class<? extends T>> getClasses(String propertyName, Class<T> expectedType)
{
Set<Class<? extends T>> classes = new HashSet<Class<? extends T>>();
- for (String className : deploymentProperties.getPropertyValues(propertyName))
+ for (String className : getPropertyValues(propertyName))
{
try
{
Added: tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/Reflections.java
===================================================================
--- tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/Reflections.java (rev 0)
+++ tck/trunk/api/src/main/java/org/jboss/webbeans/tck/api/util/Reflections.java 2009-01-09 07:25:50 UTC (rev 841)
@@ -0,0 +1,629 @@
+package org.jboss.webbeans.tck.api.util;
+
+import java.beans.Introspector;
+import java.io.Serializable;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.Field;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Member;
+import java.lang.reflect.Method;
+import java.lang.reflect.Modifier;
+import java.lang.reflect.ParameterizedType;
+import java.lang.reflect.Type;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.webbeans.BindingType;
+import javax.webbeans.ExecutionException;
+
+/**
+ * Utility class for static reflection-type operations
+ *
+ * @author Pete Muir
+ *
+ */
+public class Reflections
+{
+
+ /**
+ * Gets the property name from a getter method
+ *
+ * @param method The getter method
+ * @return The name of the property. Returns null if method wasn't JavaBean
+ * getter-styled
+ */
+ public static String getPropertyName(Method method)
+ {
+ String methodName = method.getName();
+ if (methodName.matches("^(get).*") && method.getParameterTypes().length == 0)
+ {
+ return Introspector.decapitalize(methodName.substring(3));
+ }
+ else if (methodName.matches("^(is).*") && method.getParameterTypes().length == 0)
+ {
+ return Introspector.decapitalize(methodName.substring(2));
+ }
+ else
+ {
+ return null;
+ }
+
+ }
+
+ /**
+ * Checks if class is final
+ *
+ * @param clazz The class to check
+ * @return True if final, false otherwise
+ */
+ public static boolean isFinal(Class<?> clazz)
+ {
+ return Modifier.isFinal(clazz.getModifiers());
+ }
+
+ /**
+ * Checks if member is final
+ *
+ * @param member The member to check
+ * @return True if final, false otherwise
+ */
+ public static boolean isFinal(Member member)
+ {
+ return Modifier.isFinal(member.getModifiers());
+ }
+
+ /**
+ * Checks if type or member is final
+ *
+ * @param type Type or member
+ * @return True if final, false otherwise
+ */
+ public static boolean isTypeOrAnyMethodFinal(Class<?> type)
+ {
+ if (isFinal(type))
+ {
+ return true;
+ }
+ for (Method method : type.getDeclaredMethods())
+ {
+ if (isFinal(method))
+ {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ /**
+ * Checks if type is primitive
+ *
+ * @param type Type to check
+ * @return True if primitive, false otherwise
+ */
+ public static boolean isPrimitive(Class<?> type)
+ {
+ return type.isPrimitive();
+ }
+
+ /**
+ * Checks if type is static
+ *
+ * @param type Type to check
+ * @return True if static, false otherwise
+ */
+ public static boolean isStatic(Class<?> type)
+ {
+ return Modifier.isStatic(type.getModifiers());
+ }
+
+ /**
+ * Checks if member is static
+ *
+ * @param member Member to check
+ * @return True if static, false otherwise
+ */
+ public static boolean isStatic(Member member)
+ {
+ return Modifier.isStatic(member.getModifiers());
+ }
+
+ public static boolean isTransient(Member member)
+ {
+ return Modifier.isTransient(member.getModifiers());
+ }
+
+ /**
+ * Checks if clazz is abstract
+ *
+ * @param clazz Class to check
+ * @return True if abstract, false otherwise
+ */
+ public static boolean isAbstract(Class<?> clazz)
+ {
+ return Modifier.isAbstract(clazz.getModifiers());
+ }
+
+ /**
+ * Checks if class is a static inner one
+ *
+ * @param clazz Class to check
+ * @return True if static, false otherwise
+ */
+ public static boolean isStaticInnerClass(Class<?> clazz)
+ {
+ return clazz.isMemberClass() && isStatic(clazz);
+ }
+
+ /**
+ * Checks if class is a non-static inner one
+ *
+ * @param clazz Class to Check
+ * @return True if static, false otherwise
+ */
+ public static boolean isNonStaticInnerClass(Class<?> clazz)
+ {
+ return clazz.isMemberClass() && !isStatic(clazz);
+ }
+
+ /**
+ * Gets a constructor with matching parameter types
+ *
+ * @param <T> The type
+ * @param clazz The class
+ * @param parameterTypes The parameter types
+ * @return The matching constructor. Null is returned if none is found
+ */
+ public static <T> Constructor<T> getConstructor(Class<T> clazz, Class<?>... parameterTypes)
+ {
+ try
+ {
+ return clazz.getConstructor(parameterTypes);
+ }
+ catch (NoSuchMethodException e)
+ {
+ return null;
+ }
+ catch (Exception e)
+ {
+ throw new RuntimeException("Error accessing constructor (with parameters " + parameterTypes + ") of " + clazz, e);
+ }
+ }
+
+ /**
+ * Gets all methods with a given annotation
+ *
+ * @param clazz The class the examine
+ * @param annotationType The annotation type to search for
+ * @return A list of matching methods. An empty list is returned if no
+ * matches are found
+ */
+ public static List<Method> getMethods(Class<?> clazz, Class<? extends Annotation> annotationType)
+ {
+ List<Method> methods = new ArrayList<Method>();
+ for (Method method : clazz.getMethods())
+ {
+ if (method.isAnnotationPresent(annotationType))
+ {
+ methods.add(method);
+ }
+ }
+ return methods;
+ }
+
+ /**
+ * Gets all constructors with a given annotation
+ *
+ * @param <T> The type of the class
+ * @param clazz The class
+ * @param annotationType The annotation type
+ * @return A list of matching constructors. An empty list is returned if no
+ * matches are found
+ */
+ @SuppressWarnings("unchecked")
+ public static <T> List<Constructor<T>> getAnnotatedConstructors(Class<? extends T> clazz, Class<? extends Annotation> annotationType)
+ {
+ List<Constructor<T>> constructors = new ArrayList<Constructor<T>>();
+ for (Constructor<?> constructor : clazz.getConstructors())
+ {
+ if (constructor.isAnnotationPresent(annotationType))
+ {
+ constructors.add((Constructor<T>) constructor);
+ }
+ }
+ return constructors;
+ }
+
+ /**
+ * Gets constructors with a given annotated parameter
+ *
+ * @param <T> The type
+ * @param clazz The class
+ * @param parameterAnnotationType The parameter annotation type
+ * @return A list of matching constructors. An empty list is returned if no
+ * matches are found
+ */
+ @SuppressWarnings("unchecked")
+ public static <T> List<Constructor<T>> getConstructorsForAnnotatedParameter(Class<? extends T> clazz, Class<? extends Annotation> parameterAnnotationType)
+ {
+ List<Constructor<T>> constructors = new ArrayList<Constructor<T>>();
+ for (Constructor<?> constructor : clazz.getConstructors())
+ {
+ for (Annotation[] annotations : constructor.getParameterAnnotations())
+ {
+ for (Annotation annotation : annotations)
+ {
+ if (annotation.annotationType().equals(parameterAnnotationType))
+ {
+ constructors.add((Constructor<T>) constructor);
+ }
+ }
+ }
+ }
+ return constructors;
+ }
+
+ /**
+ * Gets constructors with a given meta-annotated parameter
+ *
+ * @param <T> The type
+ * @param clazz The class
+ * @param metaAnnotationType The parameter meta-annotation type
+ * @return A list of matching constructors. An empty list is returned if no
+ * matches are found
+ */
+ @SuppressWarnings("unchecked")
+ public static <T> List<Constructor<T>> getConstructorsForMetaAnnotatedParameter(Class<? extends T> clazz, Class<? extends Annotation> metaAnnotationType)
+ {
+ List<Constructor<T>> constructors = new ArrayList<Constructor<T>>();
+ for (Constructor<?> constructor : clazz.getConstructors())
+ {
+ for (Annotation[] annotations : constructor.getParameterAnnotations())
+ {
+ for (Annotation annotation : annotations)
+ {
+ if (annotation.annotationType().isAnnotationPresent(metaAnnotationType))
+ {
+ constructors.add((Constructor<T>) constructor);
+ }
+ }
+ }
+ }
+ return constructors;
+ }
+
+ /**
+ * Checks if all annotations types are in a given set of annotations
+ *
+ * @param annotations The annotation set
+ * @param annotationTypes The annotation types to match
+ * @return True if match, false otherwise
+ */
+ public static boolean annotationTypeSetMatches(Set<Class<? extends Annotation>> annotations, Class<? extends Annotation>... annotationTypes)
+ {
+ List<Class<? extends Annotation>> annotationTypeList = new ArrayList<Class<? extends Annotation>>();
+ annotationTypeList.addAll(Arrays.asList(annotationTypes));
+ for (Class<? extends Annotation> annotation : annotations)
+ {
+ if (annotationTypeList.contains(annotation))
+ {
+ annotationTypeList.remove(annotation);
+ }
+ else
+ {
+ return false;
+ }
+ }
+ return annotationTypeList.size() == 0;
+ }
+
+ /**
+ * Checks if all annotations are in a given set of annotations
+ *
+ * @param annotations The annotation set
+ * @param annotationTypes The annotations to match
+ * @return True if match, false otherwise
+ */
+ public static boolean annotationSetMatches(Set<Annotation> annotations, Class<? extends Annotation>... annotationTypes)
+ {
+ List<Class<? extends Annotation>> annotationTypeList = new ArrayList<Class<? extends Annotation>>();
+ annotationTypeList.addAll(Arrays.asList(annotationTypes));
+ for (Annotation annotation : annotations)
+ {
+ if (annotationTypeList.contains(annotation.annotationType()))
+ {
+ annotationTypeList.remove(annotation.annotationType());
+ }
+ else
+ {
+ return false;
+ }
+ }
+ return annotationTypeList.size() == 0;
+ }
+
+ /**
+ * Gets the actual type arguments of a class
+ *
+ * @param clazz The class to examine
+ * @return The type arguments
+ */
+ public static Type[] getActualTypeArguments(Class<?> clazz)
+ {
+ if (clazz.getGenericSuperclass() instanceof ParameterizedType)
+ {
+ return ((ParameterizedType) clazz.getGenericSuperclass()).getActualTypeArguments();
+ }
+ else
+ {
+ return new Type[0];
+ }
+ }
+
+ /**
+ * Checks if raw type is array type
+ *
+ * @param rawType The raw type to check
+ * @return True if array, false otherwise
+ */
+ public static boolean isArrayType(Class<?> rawType)
+ {
+ return rawType.isArray();
+ }
+
+ /**
+ * Checks if type is parameterized type
+ *
+ * @param type The type to check
+ * @return True if parameterized, false otherwise
+ */
+ public static boolean isParameterizedType(Class<?> type)
+ {
+ return type.getTypeParameters().length > 0;
+ }
+
+ /**
+ * Invokes a method and wraps exceptions
+ *
+ * @param method The method to invoke
+ * @param instance The instance to invoke on
+ * @param parameters The parameters
+ * @return The return value
+ */
+ public static Object invokeAndWrap(Method method, Object instance, Object... parameters)
+ {
+ try
+ {
+ return method.invoke(instance, parameters);
+ }
+ catch (IllegalArgumentException e)
+ {
+ throw new ExecutionException("Error invoking method " + method.getName() + " on " + method.getDeclaringClass(), e);
+ }
+ catch (IllegalAccessException e)
+ {
+ throw new ExecutionException("Error invoking method " + method.getName() + " on " + method.getDeclaringClass(), e);
+ }
+ catch (InvocationTargetException e)
+ {
+ throw new ExecutionException("Error invoking method " + method.getName() + " on " + method.getDeclaringClass(), e);
+ }
+ }
+
+ /**
+ * Invokes a method and wraps exceptions
+ *
+ * @param methodName The method name to find on the instance and invoke
+ * @param parameterTypes The method name to find on the instance and invoke
+ * @param instance The instance to invoke on
+ * @param parameterValues The parameters values
+ * @return The return value
+ */
+ public static Object invokeAndWrap(String methodName, Class<?>[] parameterTypes, Object instance, Object[] parameterValues)
+ {
+ try
+ {
+ return instance.getClass().getMethod(methodName, parameterTypes).invoke(instance, parameterValues);
+ }
+ catch (IllegalArgumentException e)
+ {
+ throw new ExecutionException("Error invoking method " + methodName + " on " + instance.getClass(), e);
+ }
+ catch (IllegalAccessException e)
+ {
+ throw new ExecutionException("Error invoking method " + methodName + " on " + instance.getClass(), e);
+ }
+ catch (InvocationTargetException e)
+ {
+ throw new ExecutionException("Error invoking method " + methodName + " on " + instance.getClass(), e);
+ }
+ catch (SecurityException e)
+ {
+ throw new ExecutionException("Error invoking method " + methodName + " on " + instance.getClass(), e);
+ }
+ catch (NoSuchMethodException e)
+ {
+ throw new ExecutionException("Error invoking method " + methodName + " on " + instance.getClass(), e);
+ }
+ }
+
+ /**
+ * Sets value of a field and wraps exceptions
+ *
+ * @param field The field to set on
+ * @param target The instance to set on
+ * @param value The value to set
+ */
+ public static void setAndWrap(Field field, Object target, Object value)
+ {
+ try
+ {
+ field.set(target, value);
+ }
+ catch (IllegalArgumentException e)
+ {
+ throw new ExecutionException("Error setting field " + field.getName() + " on " + field.getDeclaringClass(), e);
+ }
+ catch (IllegalAccessException e)
+ {
+ throw new ExecutionException("Error setting field " + field.getName() + " on " + field.getDeclaringClass(), e);
+ }
+ }
+
+ /**
+ * Sets value of a field and wraps exceptions
+ *
+ * @param field The field to set on
+ * @param target The instance to set on
+ * @param value The value to set
+ */
+ public static void setAndWrap(String fieldName, Object target, Object value)
+ {
+ try
+ {
+ target.getClass().getField(fieldName).set(target, value);
+ }
+ catch (IllegalArgumentException e)
+ {
+ throw new ExecutionException("Error setting field " + fieldName + " on " + target.getClass(), e);
+ }
+ catch (IllegalAccessException e)
+ {
+ throw new ExecutionException("Error setting field " + fieldName + " on " + target.getClass(), e);
+ }
+ catch (SecurityException e)
+ {
+ throw new ExecutionException("Error setting field " + fieldName + " on " + target.getClass(), e);
+ }
+ catch (NoSuchFieldException e)
+ {
+ throw new ExecutionException("Error setting field " + fieldName + " on " + target.getClass(), e);
+ }
+ }
+
+ /**
+ * Gets value of a field and wraps exceptions
+ *
+ * @param field The field to set on
+ * @param target The instance to set on
+ * @return The value to set
+ */
+ public static Object getAndWrap(Field field, Object target)
+ {
+ try
+ {
+ return field.get(target);
+ }
+ catch (IllegalArgumentException e)
+ {
+ throw new ExecutionException("Error getting field " + field.getName() + " on " + field.getDeclaringClass(), e);
+ }
+ catch (IllegalAccessException e)
+ {
+ throw new ExecutionException("Error getting field " + field.getName() + " on " + field.getDeclaringClass(), e);
+ }
+ }
+
+ /**
+ * Looks up a method in the type hierarchy of an instance
+ *
+ * @param method The method to look for
+ * @param instance The instance to start from
+ * @return The method found, or an NoSuchMethodException if it is not found
+ */
+ public static Method lookupMethod(Method method, Object instance)
+ {
+ for (Class<? extends Object> clazz = instance.getClass(); clazz != null; clazz = clazz.getSuperclass())
+ {
+ try
+ {
+ Method targetMethod = clazz.getDeclaredMethod(method.getName(), method.getParameterTypes());
+ if (!targetMethod.isAccessible())
+ {
+ targetMethod.setAccessible(true);
+ }
+ return targetMethod;
+ }
+ catch (NoSuchMethodException nsme)
+ {
+ // Expected, nothing to see here.
+ }
+ }
+ throw new IllegalArgumentException("Method " + method.getName() + " not implemented by instance");
+ }
+
+ /**
+ * Indicates if an instance is a Javassist proxy
+ *
+ * @param instance The instance to examine
+ * @return True if proxy, false otherwise
+ */
+ public static boolean isProxy(Object instance)
+ {
+ return instance.getClass().getName().indexOf("_$$_javassist_") > 0;
+ }
+
+ /**
+ * Gets the type hierarchy for a class
+ *
+ * A recursive function that adds the class to the set of type and then calls
+ * itself with the suprerclass as paramater until the top of the hierarchy is
+ * reached. For each steps, adds all interfaces of the class to the set.
+ * Since the data structure is a set, duplications are eliminated
+ *
+ * @param clazz The class to examine
+ * @return The set of classes and interfaces in the hierarchy
+ * @see #getTypeHierachy(Class, Set)
+ */
+ public static Set<Class<?>> getTypeHierachy(Class<?> clazz)
+ {
+ Set<Class<?>> classes = new HashSet<Class<?>>();
+ getTypeHierachy(clazz, classes);
+ return classes;
+ }
+
+ /**
+ * Gets the flattened type hierarchy for a class, including all super classes
+ * and the entire interface type hierarchy
+ *
+ * @param clazz the class to examine
+ * @param classes the set of types
+ */
+ public static void getTypeHierachy(Class<?> clazz, Set<? super Class<?>> classes)
+ {
+ if (clazz != null)
+ {
+ classes.add(clazz);
+ getTypeHierachy(clazz.getSuperclass(), classes);
+ for (Class<?> c : clazz.getInterfaces())
+ {
+ getTypeHierachy(c, classes);
+ }
+ }
+ }
+
+ /**
+ * Checks the bindingType to make sure the annotation was declared properly
+ * as a binding type (annotated with @BindingType).
+ *
+ * @param bindingType The binding type to check
+ * @return true only if the annotation is really a binding type
+ */
+ public static boolean isBindingType(Annotation bindingType)
+ {
+ boolean isBindingAnnotation = false;
+ if (bindingType.annotationType().isAnnotationPresent(BindingType.class))
+ {
+ isBindingAnnotation = true;
+ }
+ return isBindingAnnotation;
+ }
+
+ public static boolean isSerializable(Class<?> clazz)
+ {
+ return getTypeHierachy(clazz).contains(Serializable.class);
+ }
+}
\ No newline at end of file
16 years
[webbeans-commits] Webbeans SVN: r840 - doc/trunk/reference/es-ES.
by webbeans-commits@lists.jboss.org
Author: guegl
Date: 2009-01-09 01:41:20 -0500 (Fri, 09 Jan 2009)
New Revision: 840
Modified:
doc/trunk/reference/es-ES/Author_Group.po
doc/trunk/reference/es-ES/decorators.po
doc/trunk/reference/es-ES/events.po
doc/trunk/reference/es-ES/example.po
doc/trunk/reference/es-ES/extend.po
doc/trunk/reference/es-ES/injection.po
Log:
in progress
Modified: doc/trunk/reference/es-ES/Author_Group.po
===================================================================
--- doc/trunk/reference/es-ES/Author_Group.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/Author_Group.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -8,7 +8,7 @@
"Project-Id-Version: Author_Group\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2009-01-08 14:07+0000\n"
-"PO-Revision-Date: 2009-01-08 12:17+1000\n"
+"PO-Revision-Date: 2009-01-09 11:40+1000\n"
"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
@@ -40,12 +40,13 @@
#. Tag: affiliation
#: Author_Group.xml:15
-#, fuzzy, no-c-format
+#, no-c-format
+#, fuzzy
msgid ""
"<jobtitle>Web Beans (JSR-299) Reference Implementation lead </jobtitle> "
"<orgname>Red Hat Middleware LLC</orgname>"
msgstr ""
-"<jobtitle>Web Beans (JSR-299) Reference Implementation lead </jobtitle> "
+"<jobtitle>Web Beans (JSR-299) Guía de Referencia de Aplicación </jobtitle> "
"<orgname>Red Hat Middleware LLC</orgname>"
#. Tag: othercredit
@@ -65,3 +66,4 @@
#, no-c-format
msgid "<firstname>Francesco</firstname> <surname>Milesi</surname>"
msgstr "<firstname>Francesco</firstname> <surname>Milesi</surname>"
+
Modified: doc/trunk/reference/es-ES/decorators.po
===================================================================
--- doc/trunk/reference/es-ES/decorators.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/decorators.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -8,7 +8,7 @@
"Project-Id-Version: decorators\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2008-12-19 20:26+0000\n"
-"PO-Revision-Date: 2009-01-08 12:15+1000\n"
+"PO-Revision-Date: 2009-01-09 11:30+1000\n"
"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
@@ -33,7 +33,7 @@
"However, by nature, interceptors are unaware of the actual semantics of the "
"events they intercept. Thus, interceptors aren't an appropriate tool for "
"separating business-related concerns."
-msgstr "Los interceptores son una forma potente de capturar y distinguir preocupaciones que son <emphasis>ortogonales</emphasis> al tipo de sistema. Cualquier interceptor puede interceptar invocaciones de cualquier tipo Java. Esto los hace perfectos para resolver las dudas técnicas como la administración de transacción y la seguridad. Sin embargo, por naturaleza, los interceptores desconocen la semántica real de los eventos que interceptan. Por lo tanto, los interceptores no son una herramienta apropiada para separar las cuestiones relacionadas con negocios."
+msgstr "Los interceptores son una forma potente de capturar y distinguir cuestiones que son <emphasis>ortogonales</emphasis> al tipo de sistema. Cualquier interceptor puede interceptar invocaciones de cualquier tipo Java. Esto los hace perfectos para resolver las cuestiones técnicas como la administración de transacción y la seguridad. Sin embargo, por naturaleza, los interceptores desconocen la semántica real de los eventos que interceptan. Por lo tanto, los interceptores no son una herramienta apropiada para distinguir cuestiones relacionadas con negocios."
#. Tag: para
#: decorators.xml:14
@@ -45,7 +45,7 @@
"a perfect tool for modeling some kinds of business concerns. It also means "
"that a decorator doesn't have the generality of an interceptor. Decorators "
"aren't able to solve technical concerns that cut across many disparate types."
-msgstr "Contrario a los <emphasis>decoradores</emphasis>, los cuales interceptan invocaciones únicamente para una cierta interfaz de Java y son por lo tanto, conscientes de toda la semántica asociada a la interfaz. Esto los hace una herramienta perfecta para representar algunos tipos de problemas de negocios. También significa que los decoradores no tienen la generalidad de un interceptor. Los decoradores no pueden resolver problemas técnicos que atraviesan muchos tipos dispares."
+msgstr "Contrario a los <emphasis>decoradores</emphasis>, los cuales interceptan invocaciones únicamente para una cierta interfaz de Java y son por lo tanto, conscientes de toda la semántica asociada a la interfaz. Esto los hace una herramienta perfecta para representar algunas clases de cuestiones de negocios. También significa que los decoradores no tienen la generalidad de un interceptor. Los decoradores no pueden resolver problemas técnicos que atraviesan muchos tipos dispares."
#. Tag: para
#: decorators.xml:22
Modified: doc/trunk/reference/es-ES/events.po
===================================================================
--- doc/trunk/reference/es-ES/events.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/events.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -8,7 +8,7 @@
"Project-Id-Version: events\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2008-12-19 20:26+0000\n"
-"PO-Revision-Date: 2009-01-08 17:04+1000\n"
+"PO-Revision-Date: 2009-01-09 11:24+1000\n"
"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
@@ -32,7 +32,7 @@
"Bean manager. This basic schema might sound like the familiar observer/"
"observable pattern, but there are a couple of twists:"
msgstr ""
-"La notificación de eventos de Web Beans permite a Web Beans interactuar de una manera completamente disociada. Los <emphasis>productores</emphasis> levantan eventos que son enviados luego a <emphasis>observadores</emphasis> de evento por el administrador de Web "
+"La notificación de eventos de Web Beans permite a Web Beans interactuar de una manera completamente disociada. Los <emphasis>productores</emphasis> crean eventos que son enviados luego a <emphasis>observadores</emphasis> de evento por el administrador de Web "
"Beans. Este esquema básico podría sonar como el patrón de observador familiar/"
"observable, pero hay un par de cambios:"
@@ -50,7 +50,7 @@
msgid ""
"observers can specify a combination of \"selectors\" to narrow the set of "
"event notifications they will receive, and"
-msgstr "los observadores pueden especificar una combinación de \"selectores\" para estrechar el conjunto de notificaciones de eventos que recibirán y "
+msgstr "los observadores pueden especificar una combinación de \"selectores\" para limitar el conjunto de notificaciones de eventos que recibirán y"
#. Tag: para
#: events.xml:22
@@ -185,7 +185,7 @@
"with scope <literal>@Dependent</literal> and deployment type "
"<literal>@Standard</literal>, with an implementation provided by the Web "
"Bean manager."
-msgstr "La anotación <literal>@Observable</literal> define implícitamente un Web Bean con alcance <literal>@Dependent</literal> y tipo de despliegue <literal>@Standard</literal>, con una implementación provista por el administrador de Web Bean."
+msgstr "La anotación <literal>@Observable</literal> define implícitamente un Web Bean con ámbito <literal>@Dependent</literal> y tipo de despliegue <literal>@Standard</literal>, con una implementación provista por el administrador de Web Bean."
#. Tag: para
#: events.xml:72
@@ -217,7 +217,7 @@
#: events.xml:83 events.xml:107 events.xml:126
#, no-c-format
msgid "has an event parameter to which the event object is assignable, and"
-msgstr "tenga un parámetro de evento al cual el objeto de evento sea asignable y "
+msgstr "tenga un parámetro de evento al cual el objeto de evento sea asignable y"
#. Tag: para
#: events.xml:86
@@ -233,7 +233,7 @@
"event object as the value of the event parameter. If any observer method "
"throws an exception, the Web Bean manager stops calling observer methods, "
"and the exception is rethrown by the <literal>fire()</literal> method."
-msgstr "El administrador de Web Bean simplemente llama a todos los métodos de observador, pasando el objeto del evento como el valor de un parámetro de evento. Si cualquier método de observador lanza una excepción, el administrador de Web Bean se detiene llamando a los métodos de observador y la excepción es reenviada por le método <literal>fire()</literal>."
+msgstr "El administrador de Web Beans simplemente llama a todos los métodos de observador, pasando el objeto del evento como el valor de un parámetro de evento. Si cualquier método de observador lanza una excepción, el administrador de Web Beans se detiene llamando a los métodos de observador y la excepción es reenviada por le método <literal>fire()</literal>."
#. Tag: para
#: events.xml:95
@@ -241,7 +241,7 @@
msgid ""
"To specify a \"selector\", the event producer may pass an instance of the "
"event binding type to the <literal>fire()</literal> method:"
-msgstr ""
+msgstr "Para especificar un \"selector\", el productor del evento puede pasar una instancia del tipo de enlace del evento al método <literal>fire()</literal>:"
#. Tag: programlisting
#: events.xml:98
@@ -250,6 +250,8 @@
"<![CDATA[documentEvent.fire( document, new AnnotationLiteral<Updated>()"
"{} );]]>"
msgstr ""
+"<![CDATA[documentEvent.fire( document, new AnnotationLiteral<Updated>()"
+"{} );]]>"
#. Tag: para
#: events.xml:100
@@ -258,13 +260,13 @@
"The helper class <literal>AnnotationLiteral</literal> makes it possible to "
"instantiate binding types inline, since this is otherwise difficult to do in "
"Java."
-msgstr ""
+msgstr "La <literal>Anotación Literal</literal> clase auxiliar hace posible crear una instancia de tipos de enlaces en línea, ya que de otra manera es difícil hacerlo en Java."
#. Tag: para
#: events.xml:103
#, no-c-format
msgid "The event will be delivered to every observer method that:"
-msgstr ""
+msgstr "El evento será entregado a cada método de observador que:"
#. Tag: para
#: events.xml:110
@@ -272,7 +274,7 @@
msgid ""
"does not specify any event binding <emphasis>except</emphasis> for the event "
"bindings passed to <literal>fire()</literal>."
-msgstr ""
+msgstr "no especifique ningún enlace de evento <emphasis>excepto</emphasis> para enlaces de evento pasados a <literal>fire()</literal>."
#. Tag: para
#: events.xml:115
@@ -280,13 +282,13 @@
msgid ""
"Alternatively, event bindings may be specified by annotating the event "
"notifier injection point:"
-msgstr ""
+msgstr "De modo alternativo, se pueden especificar eventos de enlaces anotando el punto de inyección de notificador de eventos:"
#. Tag: programlisting
#: events.xml:118
#, no-c-format
msgid "<![CDATA[@Observable @Updated Event<Document> documentUpdatedEvent]]>"
-msgstr ""
+msgstr "<![CDATA[@Observable @Updated Event<Document> documentUpdatedEvent]]>"
#. Tag: para
#: events.xml:120
@@ -295,7 +297,7 @@
"Then every event fired via this instance of <literal>Event</literal> has the "
"annotated event binding. The event will be delivered to every observer "
"method that:"
-msgstr ""
+msgstr "Luego cada evento disparado vía esta instancia de <literal>Evento</literal> tiene el enlace de evento anotado. El evento será enviado a cada método de observador que:"
#. Tag: para
#: events.xml:129
@@ -304,13 +306,13 @@
"does not specify any event binding <emphasis>except</emphasis> for the event "
"bindings passed to <literal>fire()</literal> or the annotated event bindings "
"of the event notifier injection point."
-msgstr ""
+msgstr "no especifica ningún enlace de evento<emphasis>excepto</emphasis> para los enlaces de eventos pasados a <literal>fire()</literal> o a los enlaces de evento anotados del punto de inyección del notificador de evento."
#. Tag: title
#: events.xml:138
#, no-c-format
msgid "Registering observers dynamically"
-msgstr ""
+msgstr "Registrando observadores dinámicamente"
#. Tag: para
#: events.xml:140
@@ -320,7 +322,7 @@
"may implement the <literal>Observer</literal> interface and register an "
"instance with an event notifier by calling the <literal>observe()</literal> "
"method."
-msgstr ""
+msgstr "Suele ser útil registrar dinámicamente un observador de evento. La aplicación puede implementar la interfaz del <literal>Observador</literal> y registrar una instancia con un notificador de evento llamando el método de <literal>observe()</literal>."
#. Tag: programlisting
#: events.xml:144
@@ -329,6 +331,8 @@
"<![CDATA[documentEvent.observe( new Observer<Document>() { public void notify"
"(Document doc) { ... } } );]]>"
msgstr ""
+"<![CDATA[documentEvent.observe( new Observer<Document>() { public void notify"
+"(Document doc) { ... } } );]]>"
#. Tag: para
#: events.xml:146
@@ -338,6 +342,8 @@
"or by passing event binding type instances to the <literal>observe()</"
"literal> method:"
msgstr ""
+"Los tipos de enlace de evento pueden ser especificados por el punto de inyección del notificador del evento o pasando las instancias de tipo de enlace de evento al método <literal>observe()</"
+"literal>:"
#. Tag: programlisting
#: events.xml:149
@@ -348,18 +354,22 @@
" new "
"AnnotationLiteral<Updated>(){} );]]>"
msgstr ""
+"<![CDATA[documentEvent.observe( new Observer<Document>() { public void notify"
+"(Document doc) { ... } }, \n"
+" new "
+"AnnotationLiteral<Updated>(){} );]]>"
#. Tag: title
#: events.xml:154
#, no-c-format
msgid "Event bindings with members"
-msgstr ""
+msgstr "Enlaces de evento con miembros"
#. Tag: para
#: events.xml:156
#, no-c-format
msgid "An event binding type may have annotation members:"
-msgstr ""
+msgstr "Un tipo de enlace de evento puede tener miembros de anotación:"
#. Tag: programlisting
#: events.xml:158
@@ -372,12 +382,18 @@
" RoleType value();\n"
"}]]>"
msgstr ""
+"<![CDATA[@BindingType\n"
+"@Target({PARAMETER, FIELD})\n"
+"@Retention(RUNTIME)\n"
+"public @interface Role {\n"
+" RoleType value();\n"
+"}]]>"
#. Tag: para
#: events.xml:160
#, no-c-format
msgid "The member value is used to narrow the messages delivered to the observer:"
-msgstr ""
+msgstr "El valor de miembro se utiliza para limitar los mensajes enviados al observador:"
#. Tag: programlisting
#: events.xml:162
@@ -386,6 +402,8 @@
"<![CDATA[public void adminLoggedIn(@Observes @Role(ADMIN) LoggedIn event) "
"{ ... }]]>"
msgstr ""
+"<![CDATA[public void adminLoggedIn(@Observes @Role(ADMIN) LoggedIn event) "
+"{ ... }]]>"
#. Tag: para
#: events.xml:164
@@ -393,13 +411,13 @@
msgid ""
"Event binding type members may be specified statically by the event "
"producer, via annotations at the event notifier injection point:"
-msgstr ""
+msgstr "Los miembros de tipo de enlace de evento se pueden especificar estáticamente por el producto del evento, a través de anotaciones en el punto de inyección del notificador de evento."
#. Tag: programlisting
#: events.xml:167
#, no-c-format
msgid "<![CDATA[@Observable @Role(ADMIN) Event<LoggedIn> LoggedInEvent;}}]]>"
-msgstr ""
+msgstr "<![CDATA[@Observable @Role(ADMIN) Event<LoggedIn> LoggedInEvent;}}]]>"
#. Tag: para
#: events.xml:169
@@ -408,7 +426,7 @@
"Alternatively, the value of the event binding type member may be determined "
"dynamically by the event producer. We start by writing an abstract subclass "
"of <literal>AnnotationLiteral</literal>:"
-msgstr ""
+msgstr "Alternativamente, el valor del miembro de tipo de enlace de evento puede ser determinado de modo dinámico por el productor de evento. Empezamos por escribir una subclase abstracta de <literal>AnotacíonLiteral</literal>:"
#. Tag: programlisting
#: events.xml:172
@@ -418,6 +436,9 @@
" extends AnnotationLiteral<Role> \n"
" implements Role {}]]>"
msgstr ""
+"<![CDATA[abstract class RoleBinding \n"
+" extends AnnotationLiteral<Role> \n"
+" implements Role {}]]>"
#. Tag: para
#: events.xml:174
@@ -426,6 +447,8 @@
"The event producer passes an instance of this class to <literal>fire()</"
"literal>:"
msgstr ""
+"El productor de evento pasa una instancia de esta clase a <literal>fire()</"
+"literal>:"
#. Tag: programlisting
#: events.xml:176
@@ -434,18 +457,20 @@
"<![CDATA[documentEvent.fire( document, new RoleBinding() { public void value"
"() { return user.getRole(); } } );]]>"
msgstr ""
+"<![CDATA[documentEvent.fire( document, new RoleBinding() { public void value"
+"() { return user.getRole(); } } );]]>"
#. Tag: title
#: events.xml:181
#, no-c-format
msgid "Multiple event bindings"
-msgstr ""
+msgstr "Enlaces de evento múltiples"
#. Tag: para
#: events.xml:183
#, no-c-format
msgid "Event binding types may be combined, for example:"
-msgstr ""
+msgstr "Los tipos de enlaces de evento pueden combinarse, por ejemplo:"
#. Tag: programlisting
#: events.xml:185
@@ -456,6 +481,10 @@
"if (document.isBlog()) blogEvent.fire(document, new "
"AnnotationLiteral<Updated>(){});]]>"
msgstr ""
+"<![CDATA[@Observable @Blog Event<Document> blogEvent;\n"
+"...\n"
+"if (document.isBlog()) blogEvent.fire(document, new "
+"AnnotationLiteral<Updated>(){});]]>"
#. Tag: para
#: events.xml:187
@@ -463,7 +492,7 @@
msgid ""
"When this event occurs, all of the following observer methods will be "
"notified:"
-msgstr ""
+msgstr "Cuando un evento ocurre, todos los siguientes métodos de observador serán notificados:"
#. Tag: programlisting
#: events.xml:189
@@ -472,6 +501,8 @@
"<![CDATA[public void afterBlogUpdate(@Observes @Updated @Blog Document "
"document) { ... }]]>"
msgstr ""
+"<![CDATA[public void afterBlogUpdate(@Observes @Updated @Blog Document "
+"document) { ... }]]>"
#. Tag: programlisting
#: events.xml:191
@@ -480,6 +511,8 @@
"<![CDATA[public void onAnyBlogEvent(@Observes @Blog Document document) "
"{ ... }]]>"
msgstr ""
+"<![CDATA[public void onAnyBlogEvent(@Observes @Blog Document document) "
+"{ ... }]]>"
#. Tag: programlisting
#: events.xml:192
@@ -488,12 +521,14 @@
"<![CDATA[public void onAnyDocumentEvent(@Observes Document document) "
"{ ... }}}]]>"
msgstr ""
+"<![CDATA[public void onAnyDocumentEvent(@Observes Document document) "
+"{ ... }}}]]>"
#. Tag: title
#: events.xml:197
#, no-c-format
msgid "Transactional observers"
-msgstr ""
+msgstr "Observadores transaccionales"
#. Tag: para
#: events.xml:199
@@ -504,7 +539,7 @@
"For example, the following observer method needs to refresh a query result "
"set that is cached in the application context, but only when transactions "
"that update the <literal>Category</literal> tree succeed:"
-msgstr ""
+msgstr "Los observadores transaccionales reciben las notificaciones de sus eventos antes o después de la fase de finalización de la transacción en la se creó el evento. Por ejemplo, el siguiente método de observador necesita actualizar un conjunto de resultados de petición almacenado en caché en el contexto de aplicación, pero sólo cuando las transacciones que actualizan el árbol de <literal>Categoría</literal> tengan éxito:"
#. Tag: programlisting
#: events.xml:205
@@ -513,12 +548,14 @@
"<![CDATA[public void refreshCategoryTree(@AfterTransactionSuccess @Observes "
"CategoryUpdateEvent event) { ... }]]>"
msgstr ""
+"<![CDATA[public void refreshCategoryTree(@AfterTransactionSuccess @Observes "
+"CategoryUpdateEvent event) { ... }]]>"
#. Tag: para
#: events.xml:207
#, no-c-format
msgid "There are three kinds of transactional observers:"
-msgstr ""
+msgstr "Hay tres clases de observadores transaccionales:"
#. Tag: para
#: events.xml:211
@@ -527,7 +564,7 @@
"<literal>@AfterTransactionSuccess</literal> observers are called during the "
"after completion phase of the transaction, but only if the transaction "
"completes successfully"
-msgstr ""
+msgstr "Los observadores<literal>@AfterTransactionSuccess</literal> son llamados durante la fase de después de finalización de la transacción, pero sólo si la transacción finaliza exitosamente."
#. Tag: para
#: events.xml:216
@@ -536,7 +573,7 @@
"<literal>@AfterTransactionFailure</literal> observers are called during the "
"after completion phase of the transaction, but only if the transaction fails "
"to complete successfully"
-msgstr ""
+msgstr "Los observadores <literal>@AfterTransactionFailure</literal> son llamados durante la fase de después de la finalización de la transacción, pero sólo si la transacción falla"
#. Tag: para
#: events.xml:221
@@ -544,7 +581,7 @@
msgid ""
"<literal>@AfterTransactionCompletion</literal> observers are called during "
"the after completion phase of the transaction"
-msgstr ""
+msgstr "Los observadores <literal>@AfterTransactionCompletion</literal> son llamados durante la fase de después de finalización de la transacción"
#. Tag: para
#: events.xml:225
@@ -552,7 +589,7 @@
msgid ""
"<literal>@BeforeTransactionCompletion</literal> observers are called during "
"the before completion phase of the transaction"
-msgstr ""
+msgstr "Los observadores <literal>@BeforeTransactionCompletion</literal> son llamados durante la fase de antes de finalización de la transacción"
#. Tag: para
#: events.xml:230
@@ -561,13 +598,13 @@
"Transactional observers are very important in a stateful object model like "
"Web Beans, because state is often held for longer than a single atomic "
"transaction."
-msgstr ""
+msgstr "Los observadores transaccionales son muy importantes en un modelo de objetos con estado como Web Beans, porque el estado suele ser mantenido para más de una transacción atómica."
#. Tag: para
#: events.xml:233
#, no-c-format
msgid "Imagine that we have cached a JPA query result set in the application scope:"
-msgstr ""
+msgstr "Imagine que hemos almacenado en caché un conjunto de resultados de petición JPA en el ámbito de la aplicación:"
#. Tag: programlisting
#: events.xml:235
@@ -592,6 +629,24 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[@ApplicationScoped @Singleton\n"
+"public class Catalog {\n"
+"\n"
+" @PersistenceContext EntityManager em;\n"
+" \n"
+" List<Product> products;\n"
+"\n"
+" @Produces @Catalog \n"
+" List<Product> getCatalog() {\n"
+" if (products==null) {\n"
+" products = em.createQuery(\"select p from Product p where p."
+"deleted = false\")\n"
+" .getResultList();\n"
+" }\n"
+" return products;\n"
+" }\n"
+" \n"
+"}]]>"
#. Tag: para
#: events.xml:237
@@ -601,7 +656,7 @@
"this occurs, we need to refresh the <literal>Product</literal> catalog. But "
"we should wait until <emphasis>after</emphasis> the transaction completes "
"successfully before performing this refresh!"
-msgstr ""
+msgstr "De vez en cuando, se crea o borra un <literal>Producto</literal>. Cuando esto ocurre, necesitamos refrescar el catálogo del <literal>Producto</literal>. No obstante, deberíamos esperar hasta <emphasis>después</emphasis> de que la transacción finalice exitosamente antes de ¡actualizar!"
#. Tag: para
#: events.xml:242
@@ -609,7 +664,7 @@
msgid ""
"The Web Bean that creates and deletes <literal>Product</literal>s could "
"raise events, for example:"
-msgstr ""
+msgstr "El Web Bean que crea y borra <literal>Productos</literal> podría crear eventos, por ejemplo:"
#. Tag: programlisting
#: events.xml:245
@@ -635,6 +690,25 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[@Stateless\n"
+"public class ProductManager {\n"
+"\n"
+" @PersistenceContext EntityManager em;\n"
+" @Observable Event<Product> productEvent;\n"
+"\n"
+" public void delete(Product product) {\n"
+" em.delete(product);\n"
+" productEvent.fire(product, new AnnotationLiteral<Deleted>(){});\n"
+" }\n"
+" \n"
+" public void persist(Product product) {\n"
+" em.persist(product);\n"
+" productEvent.fire(product, new AnnotationLiteral<Created>(){});\n"
+" }\n"
+" \n"
+" ...\n"
+" \n"
+"}]]>"
#. Tag: para
#: events.xml:247
@@ -642,7 +716,7 @@
msgid ""
"And now <literal>Catalog</literal> can observe the events after successful "
"completion of the transaction:"
-msgstr ""
+msgstr "Ahora el <literal>Catálogo</literal> puede observar los eventos después de finalizar la transacción exitosamente:"
#. Tag: programlisting
#: events.xml:250
@@ -665,4 +739,20 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[@ApplicationScoped @Singleton\n"
+"public class Catalog {\n"
+"\n"
+" ...\n"
+" \n"
+" void addProduct(@AfterTransactionSuccess @Observes @Created Product "
+"product) {\n"
+" products.add(product);\n"
+" }\n"
+" \n"
+" void addProduct(@AfterTransactionSuccess @Observes @Deleted Product "
+"product) {\n"
+" products.remove(product);\n"
+" }\n"
+" \n"
+"}]]>"
Modified: doc/trunk/reference/es-ES/example.po
===================================================================
--- doc/trunk/reference/es-ES/example.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/example.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -1,23 +1,26 @@
+# translation of example.po to Spanish
# Language es-ES translations for master.xml package.
+#
# Automatically generated, 2008.
-#
+# Gladys Guerrero Lozano <gguerrer(a)redhat.com>, 2009.
msgid ""
msgstr ""
-"Project-Id-Version: master.xml \n"
+"Project-Id-Version: example\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2009-01-04 23:18+0000\n"
-"PO-Revision-Date: 2008-12-19 20:26+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"PO-Revision-Date: 2009-01-09 11:08+1000\n"
+"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
+"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: KBabel 1.11.4\n"
#. Tag: title
#: example.xml:4
#, no-c-format
msgid "JSF web application example"
-msgstr ""
+msgstr "ejemplo de aplicación de red JSF"
#. Tag: para
#: example.xml:6
@@ -26,7 +29,7 @@
"Let's illustrate these ideas with a full example. We're going to implement "
"user login/logout for an application that uses JSF. First, we'll define a "
"Web Bean to hold the username and password entered during login:"
-msgstr ""
+msgstr "Ilustremos estas ideas con un ejemplo. Vamos a implementar inicio/cierre de sesión de usuario para una aplicación que utiliza JSF. Primero, definiremos un Web Bean para mantener el nombre de usuario y contraseña escrito durante el inicio de sesión:"
#. Tag: programlisting
#: example.xml:11
@@ -46,12 +49,25 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[@Named @RequestScoped\n"
+"public class Credentials {\n"
+" \n"
+" private String username;\n"
+" private String password;\n"
+" \n"
+" public String getUsername() { return username; }\n"
+" public void setUsername(String username) { this.username = username; }\n"
+" \n"
+" public String getPassword() { return password; }\n"
+" public void setPassword(String password) { this.password = password; }\n"
+" \n"
+"}]]>"
#. Tag: para
#: example.xml:13
#, no-c-format
msgid "This Web Bean is bound to the login prompt in the following JSF form:"
-msgstr ""
+msgstr "Este Web Bean está vinculado al intérprete de comandos de inicio de sesión en la siguiente forma JSF:"
#. Tag: programlisting
#: example.xml:15
@@ -70,6 +86,18 @@
"{login.loggedIn}\"/>\n"
"</h:form>]]>"
msgstr ""
+"<![CDATA[<h:form>\n"
+" <h:panelGrid columns=\"2\" rendered=\"#{!login.loggedIn}\">\n"
+" <h:outputLabel for=\"username\">Username:</h:outputLabel>\n"
+" <h:inputText id=\"username\" value=\"#{credentials.username}\"/>\n"
+" <h:outputLabel for=\"password\">Password:</h:outputLabel>\n"
+" <h:inputText id=\"password\" value=\"#{credentials.password}\"/>\n"
+" </h:panelGrid>\n"
+" <h:commandButton value=\"Login\" action=\"#{login.login}\" rendered=\"#{!"
+"login.loggedIn}\"/>\n"
+" <h:commandButton value=\"Logout\" acion=\"#{login.logout}\" rendered=\"#"
+"{login.loggedIn}\"/>\n"
+"</h:form>]]>"
#. Tag: para
#: example.xml:17
@@ -78,7 +106,7 @@
"The actual work is done by a session scoped Web Bean that maintains "
"information about the currently logged-in user and exposes the "
"<literal>User</literal> entity to other Web Beans:"
-msgstr ""
+msgstr "El trabajo real está hecho por una sesión de ámbito Web Bean que mantiene información acerca del usuario actualmente conectado y expone la entidad del <literal>Usuario</literal> a otras Web Beans:"
#. Tag: programlisting
#: example.xml:21
@@ -121,12 +149,48 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[@SessionScoped @Named\n"
+"public class Login {\n"
+"\n"
+" @Current Credentials credentials;\n"
+" @PersistenceContext EntityManager userDatabase;\n"
+"\n"
+" private User user;\n"
+" \n"
+" public void login() {\n"
+" \n"
+" List<User> results = userDatabase.createQuery(\n"
+" \"select u from User u where u.username=:username and u.password=:"
+"password\")\n"
+" .setParameter(\"username\", credentials.getUsername())\n"
+" .setParameter(\"password\", credentials.getPassword())\n"
+" .getResultList();\n"
+" \n"
+" if ( !results.isEmpty() ) {\n"
+" user = results.get(0);\n"
+" }\n"
+" \n"
+" }\n"
+" \n"
+" public void logout() {\n"
+" user = null;\n"
+" }\n"
+" \n"
+" public boolean isLoggedIn() {\n"
+" return user!=null;\n"
+" }\n"
+" \n"
+" @Produces @LoggedIn User getCurrentUser() {\n"
+" return user;\n"
+" }\n"
+"\n"
+"}]]>"
#. Tag: para
#: example.xml:23
#, no-c-format
msgid "Of course, <literal>@LoggedIn</literal> is a binding annotation:"
-msgstr ""
+msgstr "Obviamente, <literal>@LoggedIn</literal> es una anotación de enlace:"
#. Tag: programlisting
#: example.xml:25
@@ -137,12 +201,16 @@
"@BindingType\n"
"public @interface LoggedIn {}]]>"
msgstr ""
+"<![CDATA[@Retention(RUNTIME)\n"
+"@Target({TYPE, METHOD, FIELD})\n"
+"@BindingType\n"
+"public @interface LoggedIn {}]]>"
#. Tag: para
#: example.xml:27
#, no-c-format
msgid "Now, any other Web Bean can easily inject the current user:"
-msgstr ""
+msgstr "Ahora, cualquier otro Web Bean puede fácilmente inyectar al usuario actual:"
#. Tag: programlisting
#: example.xml:29
@@ -161,6 +229,18 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[public class DocumentEditor {\n"
+"\n"
+" @Current Document document;\n"
+" @LoggedIn User currentUser;\n"
+" @PersistenceContext EntityManager docDatabase;\n"
+" \n"
+" public void save() {\n"
+" document.setCreatedBy(currentUser);\n"
+" docDatabase.persist(document);\n"
+" }\n"
+" \n"
+"}]]>"
#. Tag: para
#: example.xml:31
@@ -169,4 +249,5 @@
"Hopefully, this example gives a flavor of the Web Bean programming model. In "
"the next chapter, we'll explore Web Beans dependency injection in greater "
"depth."
-msgstr ""
+msgstr "Esperamos que este ejemplo de una idea del modelo de programación de Web Bean. En el próximo capítulo, estudiaremos más a fondo la inyección de dependencia de Web Beans."
+
Modified: doc/trunk/reference/es-ES/extend.po
===================================================================
--- doc/trunk/reference/es-ES/extend.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/extend.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -1,23 +1,26 @@
+# translation of extend.po to Spanish
# Language es-ES translations for master.xml package.
+#
# Automatically generated, 2008.
-#
+# Gladys Guerrero Lozano <gguerrer(a)redhat.com>, 2009.
msgid ""
msgstr ""
-"Project-Id-Version: master.xml \n"
+"Project-Id-Version: extend\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2008-12-19 20:26+0000\n"
-"PO-Revision-Date: 2008-12-19 20:26+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"PO-Revision-Date: 2009-01-09 12:09+1000\n"
+"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
+"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: KBabel 1.11.4\n"
#. Tag: title
#: extend.xml:4
#, no-c-format
msgid "Extending Web Beans"
-msgstr ""
+msgstr "Extensión de Web Beans"
#. Tag: para
#: extend.xml:6
@@ -28,13 +31,13 @@
"SPIs for the use of developers of portable extensions to Web Beans. For "
"example, the following kinds of extensions were envisaged by the designers "
"of Web Beans:"
-msgstr ""
+msgstr "Web Beans pretende ser una plataforma para marcos, extensiones e integración con otras tecnologías. Por lo tanto, Web Beans expone un conjunto de SPI para el uso de desarrolladores de extensiones portátiles para Web Beans. Por ejemplo, las siguientes clases de extensiones fueron previstas por los diseñadores de Web Beans:"
#. Tag: para
#: extend.xml:14
#, no-c-format
msgid "integration with Business Process Management engines,"
-msgstr ""
+msgstr "integración con motores de Gestión de Proceso de Negocios,"
#. Tag: para
#: extend.xml:17
@@ -42,13 +45,13 @@
msgid ""
"integration with third-party frameworks such as Spring, Seam, GWT or Wicket, "
"and"
-msgstr ""
+msgstr "integración con marcos de terceras partes tales como Spring, Seam, GWT o Wicket, y"
#. Tag: para
#: extend.xml:21
#, no-c-format
msgid "new technology based upon the Web Beans programming model."
-msgstr ""
+msgstr "nueva tecnología basada en el modelo de programación de Web Beans."
#. Tag: para
#: extend.xml:25
@@ -56,13 +59,13 @@
msgid ""
"The nerve center for extending Web Beans is the <literal>Manager</literal> "
"object."
-msgstr ""
+msgstr "El centro nervioso para extender Web Beans es el objeto de <literal>Manager</literal>. "
#. Tag: title
#: extend.xml:29
#, no-c-format
msgid "The <literal>Manager</literal> object"
-msgstr ""
+msgstr "El objeto <literal>Manager</literal>"
#. Tag: para
#: extend.xml:31
@@ -71,6 +74,8 @@
"The <literal>Manager</literal> interface lets us register and obtain Web "
"Beans, interceptors, decorators, observers and contexts programatically."
msgstr ""
+"La interfaz <literal>Manager</literal> nos permite registrar y obtener Web "
+"Beans, interceptores, decoradores, observadores y contextos en forma programada."
#. Tag: programlisting
#: extend.xml:34
@@ -133,24 +138,80 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[public interface Manager\n"
+"{\n"
+"\n"
+" public <T> Set<Bean<T>> resolveByType(Class<T> type, Annotation... "
+"bindings);\n"
+"\n"
+" public <T> Set<Bean<T>> resolveByType(TypeLiteral<T> apiType,\n"
+" Annotation... bindings);\n"
+"\n"
+" public <T> T getInstanceByType(Class<T> type, Annotation... bindings);\n"
+"\n"
+" public <T> T getInstanceByType(TypeLiteral<T> type,\n"
+" Annotation... bindings);\n"
+"\n"
+" public Set<Bean<?>> resolveByName(String name);\n"
+"\n"
+" public Object getInstanceByName(String name);\n"
+"\n"
+" public <T> T getInstance(Bean<T> bean);\n"
+"\n"
+" public void fireEvent(Object event, Annotation... bindings);\n"
+"\n"
+" public Context getContext(Class<? extends Annotation> scopeType);\n"
+"\n"
+" public Manager addContext(Context context);\n"
+"\n"
+" public Manager addBean(Bean<?> bean);\n"
+"\n"
+" public Manager addInterceptor(Interceptor interceptor);\n"
+"\n"
+" public Manager addDecorator(Decorator decorator);\n"
+"\n"
+" public <T> Manager addObserver(Observer<T> observer, Class<T> eventType,\n"
+" Annotation... bindings);\n"
+"\n"
+" public <T> Manager addObserver(Observer<T> observer, TypeLiteral<T> "
+"eventType,\n"
+" Annotation... bindings);\n"
+"\n"
+" public <T> Manager removeObserver(Observer<T> observer, Class<T> "
+"eventType,\n"
+" Annotation... bindings);\n"
+"\n"
+" public <T> Manager removeObserver(Observer<T> observer,\n"
+" TypeLiteral<T> eventType, Annotation... bindings);\n"
+"\n"
+" public <T> Set<Observer<T>> resolveObservers(T event, Annotation... "
+"bindings);\n"
+"\n"
+" public List<Interceptor> resolveInterceptors(InterceptionType type,\n"
+" Annotation... interceptorBindings);\n"
+"\n"
+" public List<Decorator> resolveDecorators(Set<Class<?>> types,\n"
+" Annotation... bindings);\n"
+"\n"
+"}]]>"
#. Tag: para
#: extend.xml:36
#, no-c-format
msgid "We can obtain an instance of <literal>Manager</literal> via injection:"
-msgstr ""
+msgstr "Podemos obtener una instancia de <literal>Manager</literal> vía inyección:"
#. Tag: programlisting
#: extend.xml:38
#, no-c-format
msgid "@Current Manager manager"
-msgstr ""
+msgstr "@Current Manager manager"
#. Tag: title
#: extend.xml:43
#, no-c-format
msgid "The <literal>Bean</literal> class"
-msgstr ""
+msgstr "La clase <literal>Bean</literal>"
#. Tag: para
#: extend.xml:45
@@ -159,7 +220,7 @@
"Instances of the abstract class <literal>Bean</literal> represent Web Beans. "
"There is an instance of <literal>Bean</literal> registered with the "
"<literal>Manager</literal> object for every Web Bean in the application."
-msgstr ""
+msgstr "Instancias de clase abstracta <literal>Bean</literal> representan Web Beans. Hay una instancia de <literal>Bean</literal> registrada con el objeto <literal>Manager</literal> para cada Web Bean en la aplicación. "
#. Tag: programlisting
#: extend.xml:50
@@ -191,6 +252,31 @@
" \n"
"}"
msgstr ""
+"public abstract class Bean<T> {\n"
+" \n"
+" private final Manager manager;\n"
+" \n"
+" protected Bean(Manager manager) {\n"
+" this.manager=manager;\n"
+" }\n"
+" \n"
+" protected Manager getManager() {\n"
+" return manager;\n"
+" }\n"
+" \n"
+" public abstract Set<Class> getTypes();\n"
+" public abstract Set<Annotation> getBindingTypes();\n"
+" public abstract Class<? extends Annotation> getScopeType();\n"
+" public abstract Class<? extends Annotation> getDeploymentType(); \n"
+" public abstract String getName();\n"
+" \n"
+" public abstract boolean isSerializable();\n"
+" public abstract boolean isNullable();\n"
+"\n"
+" public abstract T create();\n"
+" public abstract void destroy(T instance);\n"
+" \n"
+"}"
#. Tag: para
#: extend.xml:52
@@ -202,7 +288,7 @@
"specification (simple and enterprise Web Beans, producer methods and JMS "
"endpoints). For example, we could use the <literal>Bean</literal> class to "
"allow objects managed by another framework to be injected into Web Beans."
-msgstr ""
+msgstr "Es posible extender la clase <literal>Bean</literal> y registrar instancias llamando a <literal>Manager.addBean()</literal> para proveer soporte a nuevas clases de Web Beans, además de los definidos por la especificación Web Beans (Web Beans sencillos y de empresa, métodos de productor y endpoints JMS). Por ejemplo, podríamos utilizar la clase <literal>Bean</literal> para permitir que los objetos sean administrados por otro marco que se inyecta en Web Beans."
#. Tag: para
#: extend.xml:60
@@ -212,12 +298,14 @@
"specification: <literal>Interceptor</literal> and <literal>Decorator</"
"literal>."
msgstr ""
+"Hay dos subclase de <literal>Bean</literal> definidas por la especificación de Web Beans: <literal>Interceptor</literal> y <literal>Decorator</"
+"literal>."
#. Tag: title
#: extend.xml:67
#, no-c-format
msgid "The <literal>Context</literal> interface"
-msgstr ""
+msgstr "La interfaz <literal>Context</literal>"
#. Tag: para
#: extend.xml:69
@@ -225,7 +313,7 @@
msgid ""
"The <literal>Context</literal> interface supports addition of new scopes to "
"Web Beans, or extension of the built-in scopes to new environments."
-msgstr ""
+msgstr "La interfaz <literal>Context</literal> soporta la adición de nuevos ámbitos a Web Beans, o extensión de los ámbitos incorporados a nuevos entornos."
#. Tag: programlisting
#: extend.xml:72
@@ -241,6 +329,15 @@
" \n"
"}"
msgstr ""
+"public interface Context {\n"
+" \n"
+" public Class<? extends Annotation> getScopeType();\n"
+" \n"
+" public <T> T get(Bean<T> bean, boolean create);\n"
+" \n"
+" boolean isActive();\n"
+" \n"
+"}"
#. Tag: para
#: extend.xml:74
@@ -249,4 +346,5 @@
"For example, we might implement <literal>Context</literal> to add a business "
"process scope to Web Beans, or to add support for the conversation scope to "
"an application that uses Wicket."
-msgstr ""
+msgstr "Por ejemplo, podríamos implementar <literal>Context</literal> para agregar un ámbito de proceso de negocio a Web Beans, o agregar soporte para el ámbito de conversación a una aplicación que utiliza Wicket."
+
Modified: doc/trunk/reference/es-ES/injection.po
===================================================================
--- doc/trunk/reference/es-ES/injection.po 2009-01-09 06:19:30 UTC (rev 839)
+++ doc/trunk/reference/es-ES/injection.po 2009-01-09 06:41:20 UTC (rev 840)
@@ -1,35 +1,38 @@
+# translation of injection.po to Spanish
# Language es-ES translations for master.xml package.
+#
# Automatically generated, 2008.
-#
+# Gladys Guerrero Lozano <gguerrer(a)redhat.com>, 2009.
msgid ""
msgstr ""
-"Project-Id-Version: master.xml \n"
+"Project-Id-Version: injection\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2008-12-19 20:26+0000\n"
-"PO-Revision-Date: 2008-12-19 20:26+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"PO-Revision-Date: 2009-01-09 16:28+1000\n"
+"Last-Translator: Gladys Guerrero Lozano <gguerrer(a)redhat.com>\n"
+"Language-Team: Spanish <fedora-trans-es(a)redhat.com>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: KBabel 1.11.4\n"
#. Tag: title
#: injection.xml:4
#, no-c-format
msgid "Dependency injection"
-msgstr ""
+msgstr "Inyección de dependencia"
#. Tag: para
#: injection.xml:6
#, no-c-format
msgid "Web Beans supports three primary mechanisms for dependency injection:"
-msgstr ""
+msgstr "Web Beans soporta tres mecanismos primarios para inyección de dependencia:"
#. Tag: para
#: injection.xml:8
#, no-c-format
msgid "Constructor parameter injection:"
-msgstr ""
+msgstr "Constructor de inyección de parámetro:"
#. Tag: programlisting
#: injection.xml:10
@@ -46,12 +49,22 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[public class Checkout {\n"
+" \n"
+" private final ShoppingCart cart;\n"
+" \n"
+" @Initializer\n"
+" public Checkout(ShoppingCart cart) {\n"
+" this.cart = cart;\n"
+" }\n"
+"\n"
+"}]]>"
#. Tag: para
#: injection.xml:12
#, no-c-format
msgid "<emphasis>Initializer</emphasis> method parameter injection:"
-msgstr ""
+msgstr "Inyección de parámetro de método <emphasis>Iniciador</emphasis>:"
#. Tag: programlisting
#: injection.xml:14
@@ -68,12 +81,22 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[public class Checkout {\n"
+" \n"
+" private ShoppingCart cart;\n"
+"\n"
+" @Initializer \n"
+" void setShoppingCart(ShoppingCart cart) {\n"
+" this.cart = cart;\n"
+" }\n"
+" \n"
+"}]]>"
#. Tag: para
#: injection.xml:16
#, no-c-format
msgid "And direct field injection:"
-msgstr ""
+msgstr "E inyección directa de campo:"
#. Tag: programlisting
#: injection.xml:18
@@ -85,6 +108,11 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[public class Checkout {\n"
+"\n"
+" private @Current ShoppingCart cart;\n"
+" \n"
+"}]]>"
#. Tag: para
#: injection.xml:20
@@ -92,7 +120,7 @@
msgid ""
"Dependency injection always occurs when the Web Bean instance is first "
"instantiated."
-msgstr ""
+msgstr "La inyección de dependencia siempre se presenta cuando la instancia de Web Bean se instancia primero:"
#. Tag: para
#: injection.xml:25
@@ -100,7 +128,7 @@
msgid ""
"First, the Web Bean manager calls the Web Bean constructor, to obtain an "
"instance of the Web Bean."
-msgstr ""
+msgstr "Primero, el administrador de Web Bean llama al constructor de Web Bean, para obtener una instancia del Web Bean."
#. Tag: para
#: injection.xml:29
@@ -108,13 +136,13 @@
msgid ""
"Next, the Web Bean manager initializes the values of all injected fields of "
"the Web Bean."
-msgstr ""
+msgstr "Luego, el administrador de Web Bean inicializa los valores de los campos inyectados del Web Bean."
#. Tag: para
#: injection.xml:33
#, no-c-format
msgid "Next, the Web Bean manager calls all initializer methods of Web Bean."
-msgstr ""
+msgstr "Más tarde, el administrador de Web Bean llama a todos los métodos inicializadores del Web Bean."
#. Tag: para
#: injection.xml:37
@@ -122,7 +150,7 @@
msgid ""
"Finally, the <literal>@PostConstruct</literal> method of the Web Bean, if "
"any, is called."
-msgstr ""
+msgstr "Por último, se llama al método de Web Bean <literal>@PostConstruct</literal>, si existe."
#. Tag: para
#: injection.xml:42
@@ -131,6 +159,8 @@
"Constructor parameter injection is not supported for EJB beans, since the "
"EJB is instantiated by the EJB container, not the Web Bean manager."
msgstr ""
+"La inyección de parámetro constructor no es admitida por beans de EJB, porque "
+"EJB es instanciada por el contenedor de EJB, no por el administrador de Web Bean."
#. Tag: para
#: injection.xml:45
@@ -141,13 +171,13 @@
"Injected fields, however, <emphasis>must</emphasis> specify a binding type, "
"even when the default binding type applies. If the field does not specify a "
"binding type, it will not be injected."
-msgstr ""
+msgstr "Los parámetros de constructores y métodos de inicializador no necesitan ser anotados explícitamente cuando el tipo de enlace predeterminado <literal>@Current</literal> se aplique. Los campos inyectados, sin embargo, <emphasis>deben</emphasis> especificar un tipo de enlace, cuando el tipo de enlace por defecto se aplique. Si el campo no especifica ningún tipo de enlace, no será inyectado."
#. Tag: para
#: injection.xml:51
#, no-c-format
msgid "Producer methods also support parameter injection:"
-msgstr ""
+msgstr "Los métodos de productor también admiten inyección de parámetro:"
#. Tag: programlisting
#: injection.xml:53
@@ -157,6 +187,9 @@
" return new Checkout(cart);\n"
"}]]>"
msgstr ""
+"<![CDATA[@Produces Checkout createCheckout(ShoppingCart cart) {\n"
+" return new Checkout(cart);\n"
+"}]]>"
#. Tag: para
#: injection.xml:55
@@ -164,7 +197,7 @@
msgid ""
"Finally, observer methods (which we'll meet in <xref linkend=\"events\"/>), "
"disposal methods and destructor methods all support parameter injection."
-msgstr ""
+msgstr "Por último, los métodos de observador (que encontraremos en <xref linkend=\"events\"/>), los métodos desechables y los métodos destructores, admiten inyección de parámetro."
#. Tag: para
#: injection.xml:58
@@ -179,7 +212,7 @@
"immediately if a Web Bean's dependencies cannot be satisfied, by throwing a "
"<literal>UnsatisfiedDependencyException</literal> or "
"<literal>AmbiguousDependencyException</literal>."
-msgstr ""
+msgstr "La especificación de Web Beans define un procedimiento, llamado <emphasis>algoritmo de resolución de typesafe</emphasis> que el administrador de Web Bean sigue al identificar el Web Bean para inyectar a un punto de inyección. Este algoritmo parece complejo en un principio, pero una vez que lo entienda, es en realidad muy intuitivo. La resolución de Typesafe se realiza al inicializar el sistema, lo que significa que el administrador informará al usuario inmediatamente si se pueden cumplir las dependencias de un Web Bean, lanzando un <literal>UnsatisfiedDependencyException</literal> o un <literal>AmbiguousDependencyException</literal>."
#. Tag: para
#: injection.xml:67
@@ -187,7 +220,7 @@
msgid ""
"The purpose of this algorithm is to allow multiple Web Beans to implement "
"the same API type and either:"
-msgstr ""
+msgstr "El propósito de este algoritmo es permitir múltiples Web Beans para implementar el mismo tipo API y ya sea:"
#. Tag: para
#: injection.xml:72
@@ -195,7 +228,7 @@
msgid ""
"allow the client to select which implementation it requires using "
"<emphasis>binding annotations</emphasis>,"
-msgstr ""
+msgstr "permitiendo al cliente seleccionar la aplicación que requiere mediante <emphasis>anotaciones de enlace</emphasis>,"
#. Tag: para
#: injection.xml:77
@@ -204,7 +237,7 @@
"allow the application deployer to select which implementation is appropriate "
"for a particular deployment, without changes to the client, by enabling or "
"disabling <emphasis>deployment types</emphasis>, or"
-msgstr ""
+msgstr "permitiendo al desplegador de aplicación seleccionar la aplicación apropiada para una despliegue particular, sin cambios en el cliente, habilitando o inhabilitando los <emphasis>tipos de despliegue</emphasis>, o"
#. Tag: para
#: injection.xml:82
@@ -213,20 +246,19 @@
"allow one implementation of an API to override another implementation of the "
"same API at deployment time, without changes to the client, using "
"<emphasis>deployment type precedence</emphasis>."
-msgstr ""
+msgstr "permitiendo que una implementación de un API remplace otra implementación del mismo API en el momento del despliegue, sin cambios al cliente, mediante <emphasis>prioridad de tipo de despliegue</emphasis>."
#. Tag: para
#: injection.xml:88
#, no-c-format
-msgid ""
-"Let's explore how the Web Beans manager determines a Web Bean to be injected."
-msgstr ""
+msgid "Let's explore how the Web Beans manager determines a Web Bean to be injected."
+msgstr "Exploremos cómo el administrador de Web Beans determina una Web Bean para ser inyectado."
#. Tag: title
#: injection.xml:91
#, no-c-format
msgid "Binding annotations"
-msgstr ""
+msgstr "Anotaciones de Enlace"
#. Tag: para
#: injection.xml:93
@@ -236,7 +268,7 @@
"injection point can specify exactly which Web Bean should be injected using "
"a binding annotation. For example, there might be two implementations of "
"<literal>PaymentProcessor</literal>:"
-msgstr ""
+msgstr "Si tenemos más de un Web Bean que implemente un tipo determinado de API, el punto de inyección puede especificar el Web Bean que debe ser inyectado utilizando una anotación de enlace. Por ejemplo, debería haber dos aplicaciones del <literal>PaymentProcessor</literal>:"
#. Tag: programlisting
#: injection.xml:98
@@ -247,6 +279,10 @@
" public void process(Payment payment) { ... }\n"
"}]]>"
msgstr ""
+"<![CDATA[@PayByCheque\n"
+"public class ChequePaymentProcessor implements PaymentProcessor {\n"
+" public void process(Payment payment) { ... }\n"
+"}]]>"
#. Tag: programlisting
#: injection.xml:100
@@ -257,6 +293,10 @@
" public void process(Payment payment) { ... }\n"
"}]]>"
msgstr ""
+"<![CDATA[@PayByCreditCard\n"
+"public class CreditCardPaymentProcessor implements PaymentProcessor {\n"
+" public void process(Payment payment) { ... }\n"
+"}]]>"
#. Tag: para
#: injection.xml:102
@@ -265,6 +305,8 @@
"Where <literal>@PayByCheque</literal> and <literal>@PayByCreditCard</"
"literal> are binding annotations:"
msgstr ""
+"Donde <literal>@PayByCheque</literal> y <literal>@PayByCreditCard</"
+"literal> son anotaciones de enlace:"
#. Tag: programlisting
#: injection.xml:105
@@ -275,6 +317,10 @@
"@BindingType\n"
"public @interface PayByCheque {}]]>"
msgstr ""
+"<![CDATA[@Retention(RUNTIME)\n"
+"@Target({TYPE, METHOD, FIELD, PARAMETER})\n"
+"@BindingType\n"
+"public @interface PayByCheque {}]]>"
#. Tag: programlisting
#: injection.xml:107
@@ -285,6 +331,10 @@
"@BindingType\n"
"public @interface PayByCreditCard {}]]>"
msgstr ""
+"<![CDATA[@Retention(RUNTIME)\n"
+"@Target({TYPE, METHOD, FIELD, PARAMETER})\n"
+"@BindingType\n"
+"public @interface PayByCreditCard {}]]>"
#. Tag: para
#: injection.xml:109
@@ -292,13 +342,13 @@
msgid ""
"A client Web Bean developer uses the binding annotation to specify exactly "
"which Web Bean should be injected."
-msgstr ""
+msgstr "Un desarrollador de cliente de Web Bean utiliza la anotación de enlace para especificar exactamente qué Web Bean debe inyectarse."
#. Tag: para
#: injection.xml:112
#, no-c-format
msgid "Using field injection:"
-msgstr ""
+msgstr "Uso de inyección de campo:"
#. Tag: programlisting
#: injection.xml:114
@@ -307,12 +357,14 @@
"<![CDATA[@PayByCheque PaymentProcessor chequePaymentProcessor;\n"
"@PayByCreditCard PaymentProcessor creditCardPaymentProcessor;]]>"
msgstr ""
+"<![CDATA[@PayByCheque PaymentProcessor chequePaymentProcessor;\n"
+"@PayByCreditCard PaymentProcessor creditCardPaymentProcessor;]]>"
#. Tag: para
#: injection.xml:116
#, no-c-format
msgid "Using initializer method injection:"
-msgstr ""
+msgstr "Uso de inyección de método inicializador:"
#. Tag: programlisting
#: injection.xml:118
@@ -327,12 +379,20 @@
" this.creditCardPaymentProcessor = creditCardPaymentProcessor;\n"
"}]]>"
msgstr ""
+"<![CDATA[@Initializer\n"
+"public void setPaymentProcessors(@PayByCheque PaymentProcessor "
+"chequePaymentProcessor, \n"
+" @PayByCreditCard PaymentProcessor "
+"creditCardPaymentProcessor) {\n"
+" this.chequePaymentProcessor = chequePaymentProcessor;\n"
+" this.creditCardPaymentProcessor = creditCardPaymentProcessor;\n"
+"}]]>"
#. Tag: para
#: injection.xml:120
#, no-c-format
msgid "Or using constructor injection:"
-msgstr ""
+msgstr "O uso de inyección de constructor:"
#. Tag: programlisting
#: injection.xml:122
@@ -346,18 +406,25 @@
" this.creditCardPaymentProcessor = creditCardPaymentProcessor;\n"
"}]]>"
msgstr ""
+"<![CDATA[@Initializer\n"
+"public Checkout(@PayByCheque PaymentProcessor chequePaymentProcessor, \n"
+" @PayByCreditCard PaymentProcessor "
+"creditCardPaymentProcessor) {\n"
+" this.chequePaymentProcessor = chequePaymentProcessor;\n"
+" this.creditCardPaymentProcessor = creditCardPaymentProcessor;\n"
+"}]]>"
#. Tag: title
#: injection.xml:125
#, no-c-format
msgid "Binding annotations with members"
-msgstr ""
+msgstr "Anotaciones de enlace con miembros"
#. Tag: para
#: injection.xml:127
#, no-c-format
msgid "Binding annotations may have members:"
-msgstr ""
+msgstr "Las anotaciones de enlace pueden tener miembros:"
#. Tag: programlisting
#: injection.xml:129
@@ -370,12 +437,18 @@
" PaymentType value();\n"
"}]]>"
msgstr ""
+"<![CDATA[@Retention(RUNTIME)\n"
+"@Target({TYPE, METHOD, FIELD, PARAMETER})\n"
+"@BindingType\n"
+"public @interface PayBy {\n"
+" PaymentType value();\n"
+"}]]>"
#. Tag: para
#: injection.xml:131
#, no-c-format
msgid "In which case, the member value is significant:"
-msgstr ""
+msgstr "En cuyo caso, el valor de miembro es importante:"
#. Tag: programlisting
#: injection.xml:133
@@ -384,6 +457,8 @@
"<![CDATA[@PayBy(CHEQUE) PaymentProcessor chequePaymentProcessor;\n"
"@PayBy(CREDIT_CARD) PaymentProcessor creditCardPaymentProcessor;]]>"
msgstr ""
+"<![CDATA[@PayBy(CHEQUE) PaymentProcessor chequePaymentProcessor;\n"
+"@PayBy(CREDIT_CARD) PaymentProcessor creditCardPaymentProcessor;]]>"
#. Tag: para
#: injection.xml:135
@@ -391,26 +466,25 @@
msgid ""
"You can tell the Web Bean manager to ignore a member of a binding annotation "
"type by annotating the member <literal>@NonBinding</literal>."
-msgstr ""
+msgstr "Se puede pedir al administrador de Web Bean que ignore a un miembro de un tipo de anotación de enlace anotando al miembro <literal>@NonBinding</literal>."
#. Tag: title
#: injection.xml:141
#, no-c-format
msgid "Combinations of binding annnotations"
-msgstr ""
+msgstr "Combinaciones de anotaciones de enlace"
#. Tag: para
#: injection.xml:143
#, no-c-format
msgid "An injection point may even specify multiple binding annotations:"
-msgstr ""
+msgstr "Un punto de inyección puede incluso especificar múltiples anotaciones de enlace:"
#. Tag: programlisting
#: injection.xml:145
#, no-c-format
-msgid ""
-"<![CDATA[@Asynchronous @PayByCheque PaymentProcessor paymentProcessor]]>"
-msgstr ""
+msgid "<![CDATA[@Asynchronous @PayByCheque PaymentProcessor paymentProcessor]]>"
+msgstr "<![CDATA[@Asynchronous @PayByCheque PaymentProcessor paymentProcessor]]>"
#. Tag: para
#: injection.xml:147
@@ -418,19 +492,19 @@
msgid ""
"In this case, only a Web Bean which has <emphasis>both</emphasis> binding "
"annotations would be eligible for injection."
-msgstr ""
+msgstr "En este caso, sólo un Web Bean que tiene <emphasis>ambas</emphasis> anotaciones de enlace sería elegible para inyección."
#. Tag: title
#: injection.xml:153
#, no-c-format
msgid "Binding annotations and producer methods"
-msgstr ""
+msgstr "Anotaciones de enlace y métodos de productor"
#. Tag: para
#: injection.xml:155
#, no-c-format
msgid "Even producer methods may specify binding annotations:"
-msgstr ""
+msgstr "Incluso los métodos de productor pueden especificar anotaciones de enlace:"
#. Tag: programlisting
#: injection.xml:157
@@ -443,12 +517,18 @@
" return new AsynchronousPaymentProcessor(processor);\n"
"}]]>"
msgstr ""
+"<![CDATA[@Produces \n"
+"@Asynchronous @PayByCheque \n"
+"PaymentProcessor createAsyncPaymentProcessor(@PayByCheque PaymentProcessor "
+"processor) {\n"
+" return new AsynchronousPaymentProcessor(processor);\n"
+"}]]>"
#. Tag: title
#: injection.xml:162
#, no-c-format
msgid "The default binding type"
-msgstr ""
+msgstr "El tipo de enlace predeterminado"
#. Tag: para
#: injection.xml:164
@@ -457,7 +537,7 @@
"Web Beans defines a binding type <literal>@Current</literal> that is the "
"default binding type for any injection point or Web Bean that does not "
"explicitly specify a binding type."
-msgstr ""
+msgstr "Web Beans define un tipo de enlace <literal>@Current</literal> que es el tipo de enlace predeterminado para cualquier punto de inyección o Web Bean que no especifique explícitamente un tipo de enlace."
#. Tag: para
#: injection.xml:168
@@ -465,7 +545,7 @@
msgid ""
"There are two common circumstances in which it is necessary to explicitly "
"specify <literal>@Current</literal>:"
-msgstr ""
+msgstr "Hay dos circunstancias comunes en que se necesita especificar explícitamente a <literal>@Current</literal>:"
#. Tag: para
#: injection.xml:173
@@ -473,7 +553,7 @@
msgid ""
"on a field, in order to declare it as an injected field with the default "
"binding type, and"
-msgstr ""
+msgstr "en un campo, para declararlo como un campo inyectado con el tipo de enlace por defecto, y "
#. Tag: para
#: injection.xml:177
@@ -481,13 +561,13 @@
msgid ""
"on a Web Bean which has another binding type in addition to the default "
"binding type."
-msgstr ""
+msgstr "en un Web Bean, el cual tiene otro tipo de enlace además del tipo de enlace predeterminado."
#. Tag: title
#: injection.xml:187
#, no-c-format
msgid "Deployment types"
-msgstr ""
+msgstr "Tipos de despliegue"
#. Tag: para
#: injection.xml:189
@@ -496,7 +576,7 @@
"All Web Beans have a <emphasis>deployment type</emphasis>. Each deployment "
"type identifies a set of Web Beans that should be conditionally installed in "
"some deployments of the system."
-msgstr ""
+msgstr "Todos los Web Beans tienen un <emphasis>tipo de despliegue</emphasis>. Cada tipo de despliegue identifica un conjunto de Web Beans que debería ser instalado bajo condiciones en algunos despliegues del sistema."
#. Tag: para
#: injection.xml:193
@@ -506,6 +586,8 @@
"literal>, which would identify Web Beans that should only be installed when "
"the system executes inside an integration testing environment:"
msgstr ""
+"Por ejemplo, podríamos definir un tipo de despliegue llamado <literal>@Mock</"
+"literal>, el cual identificaría Web Beans que deberían ser instaladas sólo cuando el sistema se ejecute dentro de un entorno de pruebas de integración:"
#. Tag: programlisting
#: injection.xml:197
@@ -516,6 +598,10 @@
" @DeploymentType\n"
" public @interface Mock {}]]>"
msgstr ""
+"<![CDATA[@Retention(RUNTIME)\n"
+" @Target({TYPE, METHOD})\n"
+" @DeploymentType\n"
+" public @interface Mock {}]]>"
#. Tag: para
#: injection.xml:199
@@ -523,7 +609,7 @@
msgid ""
"Suppose we had some Web Bean that interacted with an external system to "
"process payments:"
-msgstr ""
+msgstr "Supongamos que tenemos algunos Web Bean que interactuaron con un sistema externo para procesar pagos:"
#. Tag: programlisting
#: injection.xml:202
@@ -537,6 +623,13 @@
" \n"
"}]]>"
msgstr ""
+"<![CDATA[public class ExternalPaymentProcessor {\n"
+" \n"
+" public void process(Payment p) {\n"
+" ...\n"
+" }\n"
+" \n"
+"}]]>"
#. Tag: para
#: injection.xml:204
@@ -544,7 +637,7 @@
msgid ""
"Since this Web Bean does not explicitly specify a deployment type, it has "
"the default deployment type <literal>@Production</literal>."
-msgstr ""
+msgstr "Como este Web Bean no especifica explícitamente un tipo de despliegue, tiene el tipo de despliegue predeterminado <literal>@Production</literal>."
#. Tag: para
#: injection.xml:207
@@ -552,7 +645,7 @@
msgid ""
"For integration or unit testing, the external system is slow or unavailable. "
"So we would create a mock object:"
-msgstr ""
+msgstr "Para prueba de integración o de unidad, el sistema externo está lento o no está disponible. Por lo tanto, cremos el objeto mock:"
#. Tag: programlisting
#: injection.xml:210
@@ -568,6 +661,15 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[@Mock \n"
+"public class MockPaymentProcessor implements PaymentProcessor {\n"
+"\n"
+" @Override\n"
+" public void process(Payment p) {\n"
+" p.setSuccessful(true);\n"
+" }\n"
+"\n"
+"}]]>"
#. Tag: para
#: injection.xml:212
@@ -575,13 +677,13 @@
msgid ""
"But how does the Web Bean manager determine which implementation to use in a "
"particular deployment?"
-msgstr ""
+msgstr "Pero, ¿cómo determina el administrador de Web Bean la aplicación que debe utilizar en un despliegue determinado?"
#. Tag: title
#: injection.xml:216
#, no-c-format
msgid "Enabling deployment types"
-msgstr ""
+msgstr "Habilitar tipos de despliegue"
#. Tag: para
#: injection.xml:218
@@ -593,6 +695,8 @@
"can identify additional deployment types to be enabled in a particular "
"deployment by listing them in <literal>web-beans.xml</literal>."
msgstr ""
+"Web Beans define dos tipos de despliegue incorporados: <literal>@Production</"
+"literal> y <literal>@Standard</literal>. Por defecto, sólo los Web Beans con tipos de despliegue incorporados se habilitan cuando se despliega el sistema. Podemos identificar tipos de despliegue adicionales en un despliegue particular listándolos en <literal>web-beans.xml</literal>."
#. Tag: para
#: injection.xml:224
@@ -600,7 +704,7 @@
msgid ""
"Going back to our example, when we deploy our integration tests, we want all "
"our <literal>@Mock</literal> objects to be installed:"
-msgstr ""
+msgstr "Volviendo a nuestro ejemplo, cuando desplegamos nuestras pruebas de integración, deseamos que todos nuestros objetos <literal>@Mock</literal> sean instalados:"
#. Tag: programlisting
#: injection.xml:227
@@ -614,6 +718,13 @@
" </Deploy>\n"
"</WebBeans>]]>"
msgstr ""
+"<![CDATA[<WebBeans>\n"
+" <Deploy>\n"
+" <Standard/>\n"
+" <Production/>\n"
+" <test:Mock/>\n"
+" </Deploy>\n"
+"</WebBeans>]]>"
#. Tag: para
#: injection.xml:229
@@ -623,6 +734,8 @@
"<literal>@Production</literal>, <literal>@Standard</literal> or "
"<literal>@Mock</literal> at deployment time."
msgstr ""
+"Ahora el administrador de Web Bean identificará e instalará todos los Web Beans anotados <literal>@Production</literal>, <literal>@Standard</literal> o "
+"<literal>@Mock</literal> en el momento del despliegue."
#. Tag: para
#: injection.xml:233
@@ -631,7 +744,7 @@
"The deployment type <literal>@Standard</literal> is used only for certain "
"special Web Beans defined by the Web Beans specification. We can't use it "
"for our own Web Beans, and we can't disable it."
-msgstr ""
+msgstr "El tipo de despliegue <literal>@Standard</literal> es utilizado únicamente por algunos Web Beans especiales definidos por la especificación de Web Beans. No podemos utilizarlo para nuestros propios Web Beans ni inhabilitarlo."
#. Tag: para
#: injection.xml:237
@@ -640,13 +753,13 @@
"The deployment type <literal>@Production</literal> is the default deployment "
"type for Web Beans which don't explicitly declare a deployment type, and may "
"be disabled."
-msgstr ""
+msgstr "El tipo de despliegue <literal>@Production</literal> es el tipo de despliegue predeterminado para Web Beans que no declaran explícitamente un tipo de despliegue, y que se puede inhabilitar."
#. Tag: title
#: injection.xml:244
#, no-c-format
msgid "Deployment type precedence"
-msgstr ""
+msgstr "Prioridad de tipo de despliegue"
#. Tag: para
#: injection.xml:246
@@ -657,12 +770,15 @@
"literal> or <literal>MockPaymentProcessor</literal>—to choose. Consider "
"what happens when the manager encounters this injection point:"
msgstr ""
+"Si ha prestado atención, probablemente se estará preguntando cómo escoge Web Bean "
+"la aplicación—<literal>ExternalPaymentProcessor</"
+"literal> o <literal>MockPaymentProcessor</literal>—. Piense en lo que sucede cuando el administrador encuentra este punto de inyección:"
#. Tag: programlisting
#: injection.xml:251
#, no-c-format
msgid "<![CDATA[@Current PaymentProcessor paymentProcessor]]>"
-msgstr ""
+msgstr "<![CDATA[@Current PaymentProcessor paymentProcessor]]>"
#. Tag: para
#: injection.xml:253
@@ -674,6 +790,8 @@
"the injection point, and we want the manager to be able to decide at "
"deployment time!"
msgstr ""
+"Ahora hay dos Web Beans que cumplen el contrato <literal>PaymentProcessor</"
+"literal>. Claro está que no podemos utilizar una anotación de enlace para explicar, porque las anotaciones de enlace están codificadas en la fuente en el punto de inyección, y queremos que el administrador pueda decidir en el ¡momento de despliegue!"
#. Tag: para
#: injection.xml:258
@@ -685,6 +803,8 @@
"literal>. In our example, <literal>@Mock</literal> appears later than "
"<literal>@Production</literal> so it has a higher precedence."
msgstr ""
+"La solución a este problema es que cada tipo de despliegue tiene una <emphasis>prioridad</emphasis> diferente. La prioridad de los tipos de despliegue es determinada por el orden de aparición en <literal>web-beans.xml</"
+"literal>. En nuestro ejemplo, <literal>@Mock</literal> posterior a <literal>@Production</literal> por lo tanto tiene una mayor prioridad."
#. Tag: para
#: injection.xml:264
@@ -697,7 +817,7 @@
"to inject. So, in our example, the Web Bean manager will inject "
"<literal>MockPaymentProcessor</literal> when executing in our integration "
"testing environment (which is exactly what we want)."
-msgstr ""
+msgstr "Cada vez que el administrador descubre que más de un Web Bean cumple el contrato (tipo API más anotaciones de enlace) especificados por un punto de inyección, considera la prioridad relativa de los Web Beans. Si uno tiene una prioridad mayor que los otros, se escoge el Web Bean de mayor prioridad para inyectar. Por lo tanto, en nuestro ejemplo, el administrador de Web Bean inyectará <literal>MockPaymentProcessor</literal> al ejecutar en nuestro entorno de prueba de integración (que es precisamente lo que queremos)."
#. Tag: para
#: injection.xml:271
@@ -714,6 +834,9 @@
"browsing the code can easily identify what deployment scenarios the Web Bean "
"will be used in."
msgstr ""
+"Es interesante comparar esta facilidad con las arquitecturas populares de administrador de hoy. Varios contenedores de \"pesoliviano\" también permiten despliegue condicional de clases que existen en el classpath, pero las clases que van a ser desplegadas deben ser explicitamente, listadas de modo individual en el código de configuración o en algún archivo de configuración XML. Web Beans no admite definición de Web Bean "
+"ni configuración vía XML, pero en el común de los casos donde no se requiere una configuración compleja, los tipos de despliegue permite habilitar un conjunto completo de Web "
+"Beans con una sóla línea de XML. Mientras tanto, un desarrollador que esté navegando el código puede fácilmente identificar los escenarios de despliegue en el que el Web Bean se utilizará."
#. Tag: title
#: injection.xml:284
@@ -724,8 +847,7 @@
#. Tag: para
#: injection.xml:286
#, no-c-format
-msgid ""
-"Deployment types are useful for all kinds of things, here's some examples:"
+msgid "Deployment types are useful for all kinds of things, here's some examples:"
msgstr ""
#. Tag: para
@@ -734,13 +856,13 @@
msgid ""
"<literal>@Mock</literal> and <literal>@Staging</literal> deployment types "
"for testing"
-msgstr ""
+msgstr "<literal>@Mock</literal> and <literal>@Staging</literal> tipos de despliegue para evaluación"
#. Tag: para
#: injection.xml:294
#, no-c-format
msgid "<literal>@AustralianTaxLaw</literal> for site-specific Web Beans"
-msgstr ""
+msgstr "<literal>@AustralianTaxLaw</literal> para Web Beans de sitio específico"
#. Tag: para
#: injection.xml:297
@@ -748,7 +870,7 @@
msgid ""
"<literal>@SeamFramework</literal>, <literal>@Guice</literal> for third-party "
"frameworks which build on Web Beans"
-msgstr ""
+msgstr "<literal>@SeamFramework</literal>, <literal>@Guice</literal> para marcos de terceras partes que se generan en Web Beans"
#. Tag: para
#: injection.xml:301
@@ -756,7 +878,7 @@
msgid ""
"<literal>@Standard</literal> for standard Web Beans defined by the Web Beans "
"specification"
-msgstr ""
+msgstr "<literal>@Standard</literal>para Web Beans definidos por la especificación Web Beans"
#. Tag: para
#: injection.xml:306
@@ -931,7 +1053,7 @@
#: injection.xml:397
#, no-c-format
msgid "<![CDATA[@Current Manager manager;]]>"
-msgstr ""
+msgstr "<![CDATA[@Current Manager manager;]]>"
#. Tag: para
#: injection.xml:399
@@ -948,6 +1070,8 @@
"<![CDATA[PaymentProcessor p = manager.getInstanceByType(PaymentProcessor."
"class);]]>"
msgstr ""
+"<![CDATA[PaymentProcessor p = manager.getInstanceByType(PaymentProcessor."
+"class);]]>"
#. Tag: para
#: injection.xml:404
@@ -967,6 +1091,10 @@
" new "
"AnnotationLiteral<CreditCard>(){});]]>"
msgstr ""
+"<![CDATA[PaymentProcessor p = manager.getInstanceByType(PaymentProcessor."
+"class, \n"
+" new "
+"AnnotationLiteral<CreditCard>(){});]]>"
#. Tag: para
#: injection.xml:410
@@ -985,6 +1113,9 @@
" extends AnnotationLiteral<CreditCard> \n"
" implements CreditCard {}]]>"
msgstr ""
+"<![CDATA[abstract class CreditCardBinding \n"
+" extends AnnotationLiteral<CreditCard> \n"
+" implements CreditCard {}]]>"
#. Tag: programlisting
#: injection.xml:415
@@ -997,6 +1128,12 @@
"{ return paymentType; } \n"
" } );]]>"
msgstr ""
+"<![CDATA[PaymentProcessor p = manager.getInstanceByType(PaymentProcessor."
+"class, \n"
+" new CreditCardBinding() { \n"
+" public void value() "
+"{ return paymentType; } \n"
+" } );]]>"
#. Tag: title
#: injection.xml:419
@@ -1081,7 +1218,7 @@
msgid ""
"Injection of the result of an EL expression evaluation depends upon the "
"expression that was specified at the injection point."
-msgstr ""
+msgstr "La inyección del resultado de una prueba de expresión EL depende de la expresión que fue especificada en el punto de inyección."
#. Tag: para
#: injection.xml:461
@@ -1104,7 +1241,7 @@
#: injection.xml:468
#, no-c-format
msgid "<![CDATA[Logger log = Logger.getLogger(MyClass.class.getName());]]>"
-msgstr ""
+msgstr "<![CDATA[Logger log = Logger.getLogger(MyClass.class.getName());]]>"
#. Tag: para
#: injection.xml:470
@@ -1127,6 +1264,14 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[class LogFactory {\n"
+"\n"
+" @Produces Logger createLogger(InjectionPoint injectionPoint) { \n"
+" return Logger.getLogger(injectionPoint.getMember().getDeclaringClass()."
+"getName()); \n"
+" }\n"
+"\n"
+"}]]>"
#. Tag: para
#: injection.xml:475
@@ -1138,7 +1283,7 @@
#: injection.xml:477
#, no-c-format
msgid "<![CDATA[@Current Logger log;]]>"
-msgstr ""
+msgstr "<![CDATA[@Current Logger log;]]>"
#. Tag: para
#: injection.xml:479
@@ -1159,6 +1304,12 @@
" @NonBinding public String value();\n"
"}]]>"
msgstr ""
+"<![CDATA[@BindingType\n"
+"@Retention(RUNTIME)\n"
+"@Target({TYPE, METHOD, FIELD, PARAMETER})\n"
+"public @interface HttpParam {\n"
+" @NonBinding public String value();\n"
+"}]]>"
#. Tag: para
#: injection.xml:484
@@ -1173,6 +1324,8 @@
"<![CDATA[@HttpParam(\"username\") String username;\n"
"@HttpParam(\"password\") String password;]]>"
msgstr ""
+"<![CDATA[@HttpParam(\"username\") String username;\n"
+"@HttpParam(\"password\") String password;]]>"
#. Tag: para
#: injection.xml:488
@@ -1194,6 +1347,15 @@
"\n"
"}]]>"
msgstr ""
+"<![CDATA[class HttpParams\n"
+"\n"
+" @Produces @HttpParam(\"\")\n"
+" String getParamValue(ServletRequest request, InjectionPoint ip) {\n"
+" return request.getParameter(ip.getAnnotation(HttpParam.class).value"
+"());\n"
+" }\n"
+"\n"
+"}]]>"
#. Tag: para
#: injection.xml:492
@@ -1224,3 +1386,11 @@
" public Set<T extends Annotation> getAnnotations(); \n"
"}]]>"
msgstr ""
+"<![CDATA[public interface InjectionPoint { \n"
+" public Object getInstance(); \n"
+" public Bean<?> getBean(); \n"
+" public Member getMember(): \n"
+" public <T extends Annotation> T getAnnotation(Class<T> annotation); \n"
+" public Set<T extends Annotation> getAnnotations(); \n"
+"}]]>"
+
16 years
[webbeans-commits] Webbeans SVN: r839 - doc/trunk/reference/ko-KR.
by webbeans-commits@lists.jboss.org
Author: eukim
Date: 2009-01-09 01:19:30 -0500 (Fri, 09 Jan 2009)
New Revision: 839
Modified:
doc/trunk/reference/ko-KR/master.po
doc/trunk/reference/ko-KR/next.po
doc/trunk/reference/ko-KR/part1.po
Log:
updated
Modified: doc/trunk/reference/ko-KR/master.po
===================================================================
--- doc/trunk/reference/ko-KR/master.po 2009-01-09 01:12:11 UTC (rev 838)
+++ doc/trunk/reference/ko-KR/master.po 2009-01-09 06:19:30 UTC (rev 839)
@@ -8,7 +8,7 @@
"Project-Id-Version: master\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2009-01-06 11:30+0000\n"
-"PO-Revision-Date: 2009-01-08 16:26+1000\n"
+"PO-Revision-Date: 2009-01-09 10:27+1000\n"
"Last-Translator: Eunju Kim <eukim(a)redhat.com>\n"
"Language-Team: Korean <ko(a)li.org>\n"
"MIME-Version: 1.0\n"
@@ -17,6 +17,7 @@
"X-Generator: KBabel 1.11.4\n"
"Plural-Forms: nplurals=2; plural=(n!=1);\n\n"
"\n"
+"\n"
#. Tag: title
#: master.xml:12
@@ -28,13 +29,13 @@
#: master.xml:25
#, no-c-format
msgid "Developing loosely-coupled code"
-msgstr ""
+msgstr "느슨하게 연결된 (loosely-coupled) 방식의 코드 개발 "
#. Tag: title
#: master.xml:35
#, no-c-format
msgid "Making the most of strong typing"
-msgstr ""
+msgstr "가장 강한 타이핑 (strong typing) 사용 "
#. Tag: title
#: master.xml:46
Modified: doc/trunk/reference/ko-KR/next.po
===================================================================
--- doc/trunk/reference/ko-KR/next.po 2009-01-09 01:12:11 UTC (rev 838)
+++ doc/trunk/reference/ko-KR/next.po 2009-01-09 06:19:30 UTC (rev 839)
@@ -1,23 +1,27 @@
+# translation of next.po to Korean
# Language ko-KR translations for Introduction_to_Web_Beans package.
+#
# Automatically generated, 2009.
-#
+# Eunju Kim <eukim(a)redhat.com>, 2009.
msgid ""
msgstr ""
-"Project-Id-Version: Introduction_to_Web_Beans VERSION\n"
+"Project-Id-Version: next\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2009-01-06 11:30+0000\n"
-"PO-Revision-Date: 2009-01-06 11:30+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"PO-Revision-Date: 2009-01-09 11:31+1000\n"
+"Last-Translator: Eunju Kim <eukim(a)redhat.com>\n"
+"Language-Team: Korean <ko(a)li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: KBabel 1.11.4\n"
+"Plural-Forms: nplurals=2; plural=(n!=1);\n\n"
#. Tag: title
#: next.xml:4
#, no-c-format
msgid "Next steps"
-msgstr ""
+msgstr "다음 단계 "
#. Tag: para
#: next.xml:6
@@ -25,7 +29,7 @@
msgid ""
"Because Web Beans is so new, there's not yet a lot of information available "
"online."
-msgstr ""
+msgstr "Web Beans는 새로운 기능이기 때문에 아직 온라인에서 사용 가능한 정보가 많지 않습니다. "
#. Tag: para
#: next.xml:9
@@ -36,7 +40,7 @@
"the length of this article, and almost as readable. But, of course, it "
"covers many details that we've skipped over. The spec is available from "
"<literal>http://jcp.org/en/jsr/detail?id=299</literal>."
-msgstr ""
+msgstr "Web Beans 사양은 자세한 Web Beans 정보가 있는 최고의 소스입니다. 이는 약 100 페이지로 된 이 문서의 두 배 길이로 대부분 읽을 수 있습니다. 이는 여기서 생략된 내용을 자세하게 다루고 있으며, <literal>http://jcp.org/en/jsr/detail?id=299</literal>에서 보실 수 있습니다. "
#. Tag: para
#: next.xml:15
@@ -46,4 +50,5 @@
"seamframework.org/WebBeans</literal>. The RI development team and the Web "
"Beans spec lead blog at <literal>http://in.relation.to</literal>. This "
"article is substantially based upon a series of blog entries published there."
-msgstr ""
+msgstr "Web Beans Reference 구현은 <literal>http://seamframework.org/WebBeans</literal>에서 개발되고 있습니다. RI 개발팀 및 Web Beans 사양은 <literal>http://in.relation.to</literal>에 있는 블로그에 있습니다. 이러한 문서는 실질적으로 블로그에 게시된 기사의 시리즈를 기반으로 합니다. "
+
Modified: doc/trunk/reference/ko-KR/part1.po
===================================================================
--- doc/trunk/reference/ko-KR/part1.po 2009-01-09 01:12:11 UTC (rev 838)
+++ doc/trunk/reference/ko-KR/part1.po 2009-01-09 06:19:30 UTC (rev 839)
@@ -1,17 +1,21 @@
+# translation of part1.po to Korean
# Language ko-KR translations for Introduction_to_Web_Beans package.
+#
# Automatically generated, 2009.
-#
+# Eunju Kim <eukim(a)redhat.com>, 2009.
msgid ""
msgstr ""
-"Project-Id-Version: Introduction_to_Web_Beans VERSION\n"
+"Project-Id-Version: part1\n"
"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
"POT-Creation-Date: 2009-01-06 11:30+0000\n"
-"PO-Revision-Date: 2009-01-06 11:30+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"PO-Revision-Date: 2009-01-09 14:58+1000\n"
+"Last-Translator: Eunju Kim <eukim(a)redhat.com>\n"
+"Language-Team: Korean <ko(a)li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
+"X-Generator: KBabel 1.11.4\n"
+"Plural-Forms: nplurals=2; plural=(n!=1);\n\n"
#. Tag: para
#: part1.xml:5
@@ -23,7 +27,7 @@
"component types including JavaBeans and Enterprise Java Beans. As a "
"complement to the traditional Java EE programming model, the Web Beans "
"services provide:"
-msgstr ""
+msgstr "Web Beans (JSR-299) 사양은 애플리케이션을 보다 쉽게 개발하기 위한 Java EE 환경에 대한 서비스 모음을 정의합니다. Web Beans는 JavaBeans 및 Enterprise Java Bean을 포함하여 기존의 Java 구성 요소 유형을 통해 향상된 수명 주기 및 상호 작용 모델을 계층화합니다. 전통적인 Java EE 프로그래밍 모델의 구성 요소로서, Web Beans는 다음과 같은 서비스를 제공합니다: "
#. Tag: para
#: part1.xml:14
@@ -31,20 +35,19 @@
msgid ""
"an improved lifecycle for stateful components, bound to well-defined "
"<emphasis>contexts</emphasis>,"
-msgstr ""
+msgstr "명확하게 정의된 <emphasis>컨텍스트</emphasis>에 바인딩된 상태 기반 구성 요소의 수명 주기 개선 "
#. Tag: para
#: part1.xml:18
#, no-c-format
msgid "a typesafe approach to <emphasis>dependency injection</emphasis>,"
-msgstr ""
+msgstr "<emphasis>의존성 주입 (dependency injection)</emphasis>으로의 타입 안정적 (typesafe) 접근 "
#. Tag: para
#: part1.xml:21
#, no-c-format
-msgid ""
-"interaction via an <emphasis>event notification</emphasis> facility, and"
-msgstr ""
+msgid "interaction via an <emphasis>event notification</emphasis> facility, and"
+msgstr "<emphasis>이벤트 통지</emphasis> 기능을 통한 상호작용 "
#. Tag: para
#: part1.xml:25
@@ -54,7 +57,7 @@
"components, along with a new kind of interceptor, called a "
"<emphasis>decorator</emphasis>, that is more appropriate for use in solving "
"business problems."
-msgstr ""
+msgstr "<emphasis>decorator</emphasis>라고 불리는 새로운 종류의 인터셉터와 함께 <emphasis>인터셉터</emphasis>를 구성요소에 바인딩하기 위한 개선된 접근으로, 비지니스 문제 해결을 위해 보다 적절하게 사용됩니다. "
#. Tag: para
#: part1.xml:32
@@ -63,43 +66,43 @@
"Dependency injection, together with contextual lifecycle management, saves "
"the user of an unfamiliar API from having to ask and answer the following "
"questions:"
-msgstr ""
+msgstr "컨텍스트 수명 주기 관리와 함께 의존성 주입은 다음과 같은 질문을 묻고 대답하는 것에서 생소한 API 사용자를 보호합니다: "
#. Tag: para
#: part1.xml:38
#, no-c-format
msgid "what is the lifecycle of this object?"
-msgstr ""
+msgstr "이러한 객체의 수명 주기는 무엇입니까? "
#. Tag: para
#: part1.xml:41
#, no-c-format
msgid "how many simultaneous clients can it have?"
-msgstr ""
+msgstr "얼마나 많은 클라이언트가 이를 동시에 갖을 수 있습니까? "
#. Tag: para
#: part1.xml:44
#, no-c-format
msgid "is it multithreaded?"
-msgstr ""
+msgstr "이는 멀티스레드됩니까? "
#. Tag: para
#: part1.xml:47
#, no-c-format
msgid "where can I get one from?"
-msgstr ""
+msgstr "어디서 얻을 수 있을까요? "
#. Tag: para
#: part1.xml:50
#, no-c-format
msgid "do I need to explicitly destroy it?"
-msgstr ""
+msgstr "이를 명시적으로 삭제해야 합니까? "
#. Tag: para
#: part1.xml:53
#, no-c-format
msgid "where should I keep my reference to it when I'm not using it directly?"
-msgstr ""
+msgstr "직접 사용하지 않을 경우 참조 사항을 어디에 보관해야 합니까? "
#. Tag: para
#: part1.xml:57
@@ -107,17 +110,18 @@
msgid ""
"how can I add an indirection layer, so that the implementation of this "
"object can vary at deployment time?"
-msgstr ""
+msgstr "어떻게 하면 우회 계층을 추가하여, 이러한 개체 구현을 배포시 다르게할 수 있을까요? "
#. Tag: para
#: part1.xml:61
#, no-c-format
msgid "how should I go about sharing this object between other objects?"
-msgstr ""
+msgstr "어떻게 하면 다른 개체 사이에서 이러한 개체를 공유할 수 있을까요? "
#. Tag: para
#: part1.xml:65
#, no-c-format
+#, fuzzy
msgid ""
"A Web Bean specifies only the type and semantics of other Web Beans it "
"depends upon. It need not be aware of the actual lifecycle, concrete "
@@ -126,6 +130,8 @@
"model of a Web Bean it depends upon may vary according to the deployment "
"scenario, without affecting any client."
msgstr ""
+"Web Bean은 의존하는 다른 Web Beans의 유형 및 의미 만을 지정합니다. 이는 Web Bean이 의존하는 다른 클라이언트 또는 스레딩 모델, 실제적인 수명 주기, 구체적 구현 방식을 인식할 필요가 없습니다. 더 나아가 "
+"이는 실제적인 수명주기, 구체적인 구현 방식, 의존하는 다른 Web Bean 클라이언트 또는 스레딩 모델을 인식할 필요가 없습니다. "
#. Tag: para
#: part1.xml:72
@@ -227,3 +233,4 @@
"Java EE, and with any Java SE environment where embeddable EJB Lite is "
"available."
msgstr ""
+
16 years
[webbeans-commits] Webbeans SVN: r838 - in ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test: ejb and 1 other directory.
by webbeans-commits@lists.jboss.org
Author: dallen6
Date: 2009-01-08 20:12:11 -0500 (Thu, 08 Jan 2009)
New Revision: 838
Modified:
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/AbstractTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/BeanDeploymentTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ClientProxyTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/EventBusTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InjectionPointTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InstantiationByNameTest.java
ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ejb/EnterpriseBeanLifecycleTest.java
Log:
A little refactoring on the tests and an update to specialization tests.
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/AbstractTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/AbstractTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/AbstractTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -15,6 +15,7 @@
import org.jboss.webbeans.bean.AbstractClassBean;
import org.jboss.webbeans.bean.EnterpriseBean;
import org.jboss.webbeans.bean.SimpleBean;
+import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.test.annotations.AnotherDeploymentType;
import org.jboss.webbeans.test.annotations.HornedAnimalDeploymentType;
import org.jboss.webbeans.test.mock.MockBootstrap;
@@ -86,4 +87,13 @@
return in.readObject();
}
+ protected void activateDependentContext()
+ {
+ DependentContext.INSTANCE.setActive(true);
+ }
+
+ protected void deactivateDependentContext()
+ {
+ DependentContext.INSTANCE.setActive(false);
+ }
}
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/BeanDeploymentTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/BeanDeploymentTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/BeanDeploymentTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -2,75 +2,75 @@
import org.testng.annotations.Test;
-@SpecVersion("20080605")
+@SpecVersion("20081222")
public class BeanDeploymentTest
{
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.1.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.6")
public void testOnlySpecializedSimpleBeanDeployed()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.1.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.6")
public void testSpecializedSimpleBeanExtends()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.1.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.6")
public void testSpecializedSimpleBeanHasSameBindingAnnotations()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.1.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.6")
public void testSpecializedSimpleBeanHasSameName()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testOnlySpecializedEnterpriseBeanDeployed()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testSpecializedEnterpriseBeanExtends()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testSpecializedEnterpriseBeanHasSameBindingAnnotations()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testSpecializedEnterpriseBeanHasSameName()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testSpecializedEnterpriseBeanAllLocalInterfaces()
{
// TODO Placeholder
assert false;
}
- @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.2.4")
+ @Test(groups={"stub", "specialization"}) @SpecAssertion(section="3.3.6")
public void testSpecializedEnterpriseBeanSupportsBeanClassLocalView()
{
// TODO Placeholder
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ClientProxyTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ClientProxyTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ClientProxyTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -7,7 +7,6 @@
import javax.webbeans.manager.Bean;
import org.jboss.webbeans.bean.SimpleBean;
-import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.test.beans.Fox;
import org.jboss.webbeans.test.beans.Tuna;
import org.jboss.webbeans.test.beans.TunedTuna;
@@ -36,13 +35,13 @@
Bean<Fox> foxBean = SimpleBean.of(Fox.class, manager);
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
Fox fox = manager.getInstance(foxBean);
assert !Reflections.isProxy(fox);
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/EventBusTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/EventBusTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/EventBusTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -11,7 +11,6 @@
import javax.webbeans.TypeLiteral;
import javax.webbeans.manager.Bean;
-import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.test.beans.AuroraFinch;
import org.jboss.webbeans.test.beans.BananaSpider;
import org.jboss.webbeans.test.beans.BirdCage;
@@ -487,7 +486,7 @@
// Now instantiate the bean and fire another event
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
RecluseSpider bean = manager.getInstanceByType(RecluseSpider.class);
assert bean != null;
@@ -496,7 +495,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -583,6 +582,7 @@
webBeansBootstrap.setWebBeanDiscovery(new MockWebBeanDiscovery(TeaCupPomeranian.class));
webBeansBootstrap.boot();
List<Bean<?>> beans = manager.getBeans();
+ assert !beans.isEmpty();
manager.fireEvent("Another event");
}
@@ -593,6 +593,7 @@
webBeansBootstrap.setWebBeanDiscovery(new MockWebBeanDiscovery(TeaCupPomeranian.class));
webBeansBootstrap.boot();
List<Bean<?>> beans = manager.getBeans();
+ assert !beans.isEmpty();
manager.fireEvent(new Integer(1));
}
@@ -604,13 +605,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
SweeWaxbill bean = manager.getInstanceByType(SweeWaxbill.class);
bean.methodThatFiresEvent();
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -622,13 +623,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
SweeWaxbill bean = manager.getInstanceByType(SweeWaxbill.class);
bean.methodThatRegistersObserver();
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -640,13 +641,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
OwlFinch bean = manager.getInstanceByType(OwlFinch.class);
bean.methodThatFiresEvent();
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -658,13 +659,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
OwlFinch bean = manager.getInstanceByType(OwlFinch.class);
bean.methodThatRegistersObserver();
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -676,7 +677,7 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
BlueFacedParrotFinch bean = manager.getInstanceByType(BlueFacedParrotFinch.class);
bean.methodThatRegistersObserver();
@@ -685,7 +686,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -697,7 +698,7 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
StarFinch starFinch = manager.getInstanceByType(StarFinch.class);
FinchKeeper birdKeeper = manager.getInstanceByType(FinchKeeper.class);
BirdCage birdCage = manager.getInstanceByType(BirdCage.class);
@@ -708,7 +709,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -720,7 +721,7 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
OrangeCheekedWaxbill bird = manager.getInstanceByType(OrangeCheekedWaxbill.class);
FinchKeeper birdKeeper = manager.getInstanceByType(FinchKeeper.class);
assert bird != null;
@@ -729,7 +730,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -750,7 +751,7 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
EuropeanGoldfinch bird = manager.getInstanceByType(EuropeanGoldfinch.class);
FinchKeeper birdKeeper = manager.getInstanceByType(FinchKeeper.class);
assert bird != null;
@@ -759,7 +760,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -771,7 +772,7 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
AuroraFinch bird = manager.getInstanceByType(AuroraFinch.class);
FinchKeeper birdKeeper = manager.getInstanceByType(FinchKeeper.class);
assert bird != null;
@@ -779,7 +780,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -791,13 +792,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
CommonWaxbill bean = manager.getInstanceByType(CommonWaxbill.class);
assert bean != null;
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -809,14 +810,14 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
BlackRumpedWaxbill bean = manager.getInstanceByType(BlackRumpedWaxbill.class);
webBeansBootstrap.boot();
assert bean != null;
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -828,13 +829,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
GoldbreastWaxbill bean = manager.getInstanceByType(GoldbreastWaxbill.class);
assert bean != null;
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -846,13 +847,13 @@
webBeansBootstrap.boot();
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
JavaSparrow bean = manager.getInstanceByType(JavaSparrow.class);
assert bean != null;
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InjectionPointTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InjectionPointTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InjectionPointTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -30,7 +30,6 @@
import javax.webbeans.manager.Bean;
import org.jboss.webbeans.binding.CurrentBinding;
-import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.test.annotations.AnimalStereotype;
import org.jboss.webbeans.test.beans.BeanWithInjectionPointMetadata;
import org.jboss.webbeans.test.beans.ConstructorInjectionPointBean;
@@ -58,7 +57,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -67,7 +66,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -81,7 +80,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -92,7 +91,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -106,7 +105,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -114,7 +113,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -128,7 +127,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -138,7 +137,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -152,7 +151,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -160,7 +159,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -181,7 +180,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
ConstructorInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(ConstructorInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -189,7 +188,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -203,7 +202,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -211,7 +210,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -225,7 +224,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -236,7 +235,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -250,7 +249,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -258,7 +257,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -272,7 +271,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -280,7 +279,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -294,7 +293,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -302,7 +301,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
@@ -316,7 +315,7 @@
// Get an instance of the bean which has another bean injected into it
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
FieldInjectionPointBean beanWithInjectedBean = manager.getInstanceByType(FieldInjectionPointBean.class, new CurrentBinding());
BeanWithInjectionPointMetadata beanWithInjectionPoint = beanWithInjectedBean.getInjectedBean();
assert beanWithInjectionPoint.getInjectedMetadata() != null;
@@ -324,7 +323,7 @@
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
}
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InstantiationByNameTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InstantiationByNameTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/InstantiationByNameTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -4,7 +4,6 @@
import javax.webbeans.manager.Bean;
import org.jboss.webbeans.bean.SimpleBean;
-import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.introspector.AnnotatedClass;
import org.jboss.webbeans.introspector.AnnotatedField;
import org.jboss.webbeans.introspector.jlr.AnnotatedClassImpl;
@@ -73,12 +72,12 @@
try
{
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
assert manager.getInstanceByName("salmon") instanceof Salmon;
}
finally
{
- DependentContext.INSTANCE.setActive(false);
+ deactivateDependentContext();
}
}
Modified: ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ejb/EnterpriseBeanLifecycleTest.java
===================================================================
--- ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ejb/EnterpriseBeanLifecycleTest.java 2009-01-08 23:00:43 UTC (rev 837)
+++ ri/trunk/webbeans-ri/src/test/java/org/jboss/webbeans/test/ejb/EnterpriseBeanLifecycleTest.java 2009-01-09 01:12:11 UTC (rev 838)
@@ -3,7 +3,6 @@
import javax.webbeans.UnremovedException;
import org.jboss.webbeans.bean.EnterpriseBean;
-import org.jboss.webbeans.context.DependentContext;
import org.jboss.webbeans.test.AbstractTest;
import org.jboss.webbeans.test.SpecAssertion;
import org.jboss.webbeans.test.SpecVersion;
@@ -57,7 +56,7 @@
public void testRemoveMethodCalled()
{
visited = false;
- DependentContext.INSTANCE.setActive(true);
+ activateDependentContext();
EnterpriseBean<GoodDoggie> bean = EnterpriseBean.of(GoodDoggie.class, manager);
manager.addBean(bean);
GoodDoggie doggie = manager.getInstance(bean);
16 years
[webbeans-commits] Webbeans SVN: r837 - ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection.
by webbeans-commits@lists.jboss.org
Author: dallen6
Date: 2009-01-08 18:00:43 -0500 (Thu, 08 Jan 2009)
New Revision: 837
Modified:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java
Log:
Modified the provider method so that it is a little more reliable with current instances not being available.
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java 2009-01-08 18:12:02 UTC (rev 836)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java 2009-01-08 23:00:43 UTC (rev 837)
@@ -26,10 +26,10 @@
import org.jboss.webbeans.introspector.AnnotatedMember;
/**
- * Used to create the container provided implementation for the
- * InjectionPoint beans. The instance maintains state information
- * on a stack so that this information is readily available for
- * construction of a new InjectionPoint bean instance.
+ * Used to create the container provided implementation for the InjectionPoint
+ * beans. The instance maintains state information on a stack so that this
+ * information is readily available for construction of a new InjectionPoint
+ * bean instance.
*
* @author David Allen
*
@@ -73,8 +73,8 @@
}
/**
- * Pops the bean from the stack. This should be called
- * whenever all processing is complete for instantiating a bean.
+ * Pops the bean from the stack. This should be called whenever all
+ * processing is complete for instantiating a bean.
*/
public void popBean()
{
@@ -82,8 +82,8 @@
}
/**
- * Pops the current instance from the stack. This should be called
- * whenever all processing is complete for instantiating a bean.
+ * Pops the current instance from the stack. This should be called whenever
+ * all processing is complete for instantiating a bean.
*/
public void popInstance()
{
@@ -91,8 +91,8 @@
}
/**
- * Pops the current injection point being processed. This should be called once
- * the injection point is bound.
+ * Pops the current injection point being processed. This should be called
+ * once the injection point is bound.
*/
public void popInjectionPoint()
{
@@ -100,32 +100,58 @@
}
/**
- * Returns the InjectionPoint where the current bean under construction
- * is being injected.
+ * Returns the InjectionPoint where the current bean under construction is
+ * being injected.
*
* @return a new injection point metadata object
*/
public InjectionPoint getPreviousInjectionPoint()
{
- // When the injected member is a constructor, we are short one instance,
- // so the instance on the top of the stack is the bean instance
- // we want. Otherwise, it is the second to last instance same as
- // the bean stack.
- InjectionPoint injectionPoint = null;
+ return new InjectionPointImpl(getPreviousInjectionMember(), getPreviousBean(), getPreviousInstance());
+ }
+
+ protected Bean<?> getPreviousBean()
+ {
Bean<?> currentBean = beans.pop();
- AnnotatedMember<?, ? extends Member> currentInjection = injectionPoints.pop();
+ Bean<?> result = beans.peek();
+ beans.push(currentBean);
+ return result;
+ }
+
+ protected Object getPreviousInstance()
+ {
+ Object result = null;
if (beanInstances.size() < beans.size())
{
- injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
+ // Return top of stack since this is the previous instance when a
+ // constructor is being invoked with injection points
+ result = beanInstances.peek();
}
else
{
Object currentInstance = beanInstances.pop();
- injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
+ result = beanInstances.peek();
beanInstances.push(currentInstance);
}
- beans.push(currentBean);
- injectionPoints.push(currentInjection);
- return injectionPoint;
+ return result;
}
+
+ protected AnnotatedMember<?, ? extends Member> getPreviousInjectionMember()
+ {
+ AnnotatedMember<?, ? extends Member> result = null;
+ if (injectionPoints.size() < beans.size())
+ {
+ // This case only occurs when some internal RI code wants the
+ // injection point but did not push an injection point that
+ // this metadata goes into.
+ result = injectionPoints.peek();
+ }
+ else
+ {
+ AnnotatedMember<?, ? extends Member> currentMember = injectionPoints.pop();
+ result = injectionPoints.peek();
+ injectionPoints.push(currentMember);
+ }
+ return result;
+ }
}
16 years
[webbeans-commits] Webbeans SVN: r836 - in ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans: bean and 2 other directories.
by webbeans-commits@lists.jboss.org
Author: dallen6
Date: 2009-01-08 13:12:02 -0500 (Thu, 08 Jan 2009)
New Revision: 836
Added:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java
Removed:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java
Modified:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/ManagerImpl.java
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java
Log:
Changed name of injection point factory to provider.
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/ManagerImpl.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/ManagerImpl.java 2009-01-08 17:40:08 UTC (rev 835)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/ManagerImpl.java 2009-01-08 18:12:02 UTC (rev 836)
@@ -56,7 +56,7 @@
import org.jboss.webbeans.ejb.EjbDescriptorCache;
import org.jboss.webbeans.ejb.spi.EjbResolver;
import org.jboss.webbeans.event.EventManager;
-import org.jboss.webbeans.injection.InjectionPointFactory;
+import org.jboss.webbeans.injection.InjectionPointProvider;
import org.jboss.webbeans.introspector.AnnotatedItem;
import org.jboss.webbeans.introspector.AnnotatedMethod;
import org.jboss.webbeans.introspector.jlr.AnnotatedClassImpl;
@@ -87,7 +87,7 @@
// The Web Beans event manager
private transient final EventManager eventManager;
// An injection point metadata beans factory
- private transient final InjectionPointFactory injectionPointFactory;
+ private transient final InjectionPointProvider injectionPointProvider;
// The bean resolver
private transient final Resolver resolver;
@@ -135,7 +135,7 @@
this.contextMap = new ContextMap();
this.eventManager = new EventManager();
this.ejbDescriptorCache = new EjbDescriptorCache();
- this.injectionPointFactory = new InjectionPointFactory();
+ this.injectionPointProvider = new InjectionPointProvider();
List<Class<? extends Annotation>> defaultEnabledDeploymentTypes = new ArrayList<Class<? extends Annotation>>();
defaultEnabledDeploymentTypes.add(0, Standard.class);
@@ -761,9 +761,9 @@
*
* @return the factory
*/
- public InjectionPointFactory getInjectionPointFactory()
+ public InjectionPointProvider getInjectionPointFactory()
{
- return injectionPointFactory;
+ return injectionPointProvider;
}
// Serialization
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 17:40:08 UTC (rev 835)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 18:12:02 UTC (rev 836)
@@ -30,7 +30,7 @@
import org.jboss.webbeans.ManagerImpl;
import org.jboss.webbeans.MetaDataCache;
import org.jboss.webbeans.context.DependentContext;
-import org.jboss.webbeans.injection.InjectionPointFactory;
+import org.jboss.webbeans.injection.InjectionPointProvider;
import org.jboss.webbeans.injection.InjectionPointImpl;
import org.jboss.webbeans.introspector.AnnotatedClass;
import org.jboss.webbeans.introspector.AnnotatedConstructor;
@@ -117,15 +117,15 @@
{
checkProducedInjectionPoints();
}
- InjectionPointFactory injectionPointFactory = manager.getInjectionPointFactory();
- injectionPointFactory.pushBean(this);
+ InjectionPointProvider injectionPointProvider = manager.getInjectionPointFactory();
+ injectionPointProvider.pushBean(this);
T instance = null;
try
{
instance = constructor.newInstance(manager);
try
{
- injectionPointFactory.pushInstance(instance);
+ injectionPointProvider.pushInstance(instance);
bindDecorators();
bindInterceptors();
injectEjbAndCommonFields(instance);
@@ -135,12 +135,12 @@
}
finally
{
- injectionPointFactory.popInstance();
+ injectionPointProvider.popInstance();
}
}
finally
{
- injectionPointFactory.popBean();
+ injectionPointProvider.popBean();
}
return instance;
}
@@ -271,17 +271,17 @@
*/
protected void injectBoundFields(T instance)
{
- InjectionPointFactory injectionPointFactory = manager.getInjectionPointFactory();
+ InjectionPointProvider injectionPointProvider = manager.getInjectionPointFactory();
for (AnnotatedField<?> injectableField : getInjectableFields())
{
- injectionPointFactory.pushInjectionPoint(injectableField);
+ injectionPointProvider.pushInjectionPoint(injectableField);
try
{
injectableField.inject(instance, manager);
}
finally
{
- injectionPointFactory.popInjectionPoint();
+ injectionPointProvider.popInjectionPoint();
}
}
}
Deleted: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java 2009-01-08 17:40:08 UTC (rev 835)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java 2009-01-08 18:12:02 UTC (rev 836)
@@ -1,132 +0,0 @@
-/*
- * JBoss, Home of Professional Open Source
- * Copyright 2008, Red Hat Middleware LLC, and individual contributors
- * by the @authors tag. See the copyright.txt in the distribution for a
- * full listing of individual contributors.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- * http://www.apache.org/licenses/LICENSE-2.0
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package org.jboss.webbeans.injection;
-
-import java.lang.reflect.Member;
-import java.util.Stack;
-
-import javax.webbeans.InjectionPoint;
-import javax.webbeans.manager.Bean;
-
-import org.jboss.webbeans.introspector.AnnotatedMember;
-
-/**
- * Factory used to create the container provided implementation for the
- * InjectionPoint beans. This factory maintains a stack with the current bean
- * and instance being created so that this information is readily available for
- * construction of a new InjectionPoint bean.
- *
- * @author David Allen
- *
- */
-public class InjectionPointFactory
-{
- private final Stack<Bean<?>> beans = new Stack<Bean<?>>();
- private final Stack<Object> beanInstances = new Stack<Object>();
- private final Stack<AnnotatedMember<?, ? extends Member>> injectionPoints = new Stack<AnnotatedMember<?, ? extends Member>>();
-
- /**
- * Pushes the current bean that is being instantiated onto a stack for later
- * use.
- *
- * @param currentBean The bean being instantiated
- */
- public void pushBean(Bean<?> currentBean)
- {
- beans.push(currentBean);
- }
-
- /**
- * Pushes the current bean instance that has been instantiated, but has not
- * yet had any injection points initialized.
- *
- * @param currentInstance The bean instance last instantiated
- */
- public void pushInstance(Object currentInstance)
- {
- beanInstances.push(currentInstance);
- }
-
- /**
- * Pushes the current injection point being processed.
- *
- * @param injectedMember The metadata for the injection point
- */
- public void pushInjectionPoint(AnnotatedMember<?, ? extends Member> injectedMember)
- {
- injectionPoints.push(injectedMember);
- }
-
- /**
- * Pops the bean from the stack. This should be called
- * whenever all processing is complete for instantiating a bean.
- */
- public void popBean()
- {
- beans.pop();
- }
-
- /**
- * Pops the current instance from the stack. This should be called
- * whenever all processing is complete for instantiating a bean.
- */
- public void popInstance()
- {
- beanInstances.pop();
- }
-
- /**
- * Pops the current injection point being processed. This should be called once
- * the injection point is bound.
- */
- public void popInjectionPoint()
- {
- injectionPoints.pop();
- }
-
- /**
- * Creates an InjectionPoint based on the current state of processing as
- * indicated by this factory's stack of injection points and related
- * information.
- *
- * @return a new injection point metadata object
- */
- public InjectionPoint getPreviousInjectionPoint()
- {
- // When the injected member is a constructor, we are short one instance,
- // so the instance on the top of the stack is the bean instance
- // we want. Otherwise, it is the second to last instance same as
- // the bean stack.
- InjectionPoint injectionPoint = null;
- Bean<?> currentBean = beans.pop();
- AnnotatedMember<?, ? extends Member> currentInjection = injectionPoints.pop();
- if (beanInstances.size() < beans.size())
- {
- injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
- }
- else
- {
- Object currentInstance = beanInstances.pop();
- injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
- beanInstances.push(currentInstance);
- }
- beans.push(currentBean);
- injectionPoints.push(currentInjection);
- return injectionPoint;
- }
-}
Copied: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java (from rev 835, ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java)
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java (rev 0)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java 2009-01-08 18:12:02 UTC (rev 836)
@@ -0,0 +1,131 @@
+/*
+ * JBoss, Home of Professional Open Source
+ * Copyright 2008, Red Hat Middleware LLC, and individual contributors
+ * by the @authors tag. See the copyright.txt in the distribution for a
+ * full listing of individual contributors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.jboss.webbeans.injection;
+
+import java.lang.reflect.Member;
+import java.util.Stack;
+
+import javax.webbeans.InjectionPoint;
+import javax.webbeans.manager.Bean;
+
+import org.jboss.webbeans.introspector.AnnotatedMember;
+
+/**
+ * Used to create the container provided implementation for the
+ * InjectionPoint beans. The instance maintains state information
+ * on a stack so that this information is readily available for
+ * construction of a new InjectionPoint bean instance.
+ *
+ * @author David Allen
+ *
+ */
+public class InjectionPointProvider
+{
+ private final Stack<Bean<?>> beans = new Stack<Bean<?>>();
+ private final Stack<Object> beanInstances = new Stack<Object>();
+ private final Stack<AnnotatedMember<?, ? extends Member>> injectionPoints = new Stack<AnnotatedMember<?, ? extends Member>>();
+
+ /**
+ * Pushes the current bean that is being instantiated onto a stack for later
+ * use.
+ *
+ * @param currentBean The bean being instantiated
+ */
+ public void pushBean(Bean<?> currentBean)
+ {
+ beans.push(currentBean);
+ }
+
+ /**
+ * Pushes the current bean instance that has been instantiated, but has not
+ * yet had any injection points initialized.
+ *
+ * @param currentInstance The bean instance last instantiated
+ */
+ public void pushInstance(Object currentInstance)
+ {
+ beanInstances.push(currentInstance);
+ }
+
+ /**
+ * Pushes the current injection point being processed.
+ *
+ * @param injectedMember The metadata for the injection point
+ */
+ public void pushInjectionPoint(AnnotatedMember<?, ? extends Member> injectedMember)
+ {
+ injectionPoints.push(injectedMember);
+ }
+
+ /**
+ * Pops the bean from the stack. This should be called
+ * whenever all processing is complete for instantiating a bean.
+ */
+ public void popBean()
+ {
+ beans.pop();
+ }
+
+ /**
+ * Pops the current instance from the stack. This should be called
+ * whenever all processing is complete for instantiating a bean.
+ */
+ public void popInstance()
+ {
+ beanInstances.pop();
+ }
+
+ /**
+ * Pops the current injection point being processed. This should be called once
+ * the injection point is bound.
+ */
+ public void popInjectionPoint()
+ {
+ injectionPoints.pop();
+ }
+
+ /**
+ * Returns the InjectionPoint where the current bean under construction
+ * is being injected.
+ *
+ * @return a new injection point metadata object
+ */
+ public InjectionPoint getPreviousInjectionPoint()
+ {
+ // When the injected member is a constructor, we are short one instance,
+ // so the instance on the top of the stack is the bean instance
+ // we want. Otherwise, it is the second to last instance same as
+ // the bean stack.
+ InjectionPoint injectionPoint = null;
+ Bean<?> currentBean = beans.pop();
+ AnnotatedMember<?, ? extends Member> currentInjection = injectionPoints.pop();
+ if (beanInstances.size() < beans.size())
+ {
+ injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
+ }
+ else
+ {
+ Object currentInstance = beanInstances.pop();
+ injectionPoint = new InjectionPointImpl(injectionPoints.peek(), beans.peek(), beanInstances.peek());
+ beanInstances.push(currentInstance);
+ }
+ beans.push(currentBean);
+ injectionPoints.push(currentInjection);
+ return injectionPoint;
+ }
+}
Property changes on: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointProvider.java
___________________________________________________________________
Name: svn:mime-type
+ text/plain
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java 2009-01-08 17:40:08 UTC (rev 835)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java 2009-01-08 18:12:02 UTC (rev 836)
@@ -29,7 +29,7 @@
import javax.webbeans.manager.Manager;
import org.jboss.webbeans.ManagerImpl;
-import org.jboss.webbeans.injection.InjectionPointFactory;
+import org.jboss.webbeans.injection.InjectionPointProvider;
import org.jboss.webbeans.introspector.AnnotatedMember;
import org.jboss.webbeans.introspector.AnnotatedParameter;
import org.jboss.webbeans.util.Reflections;
@@ -206,8 +206,8 @@
protected Object[] getParameterValues(List<AnnotatedParameter<Object>> parameters, Object specialVal, Class<? extends Annotation> specialParam, ManagerImpl manager)
{
Object[] parameterValues = new Object[parameters.size()];
- InjectionPointFactory injectionPointFactory = manager.getInjectionPointFactory();
- injectionPointFactory.pushInjectionPoint(this);
+ InjectionPointProvider injectionPointProvider = manager.getInjectionPointFactory();
+ injectionPointProvider.pushInjectionPoint(this);
try
{
Iterator<AnnotatedParameter<Object>> iterator = parameters.iterator();
@@ -226,7 +226,7 @@
}
finally
{
- injectionPointFactory.popInjectionPoint();
+ injectionPointProvider.popInjectionPoint();
}
return parameterValues;
16 years
[webbeans-commits] Webbeans SVN: r835 - in ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans: bean and 2 other directories.
by webbeans-commits@lists.jboss.org
Author: dallen6
Date: 2009-01-08 12:40:08 -0500 (Thu, 08 Jan 2009)
New Revision: 835
Added:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/InjectionPointBean.java
Modified:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/Resolver.java
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java
Log:
Refactored some of the injection point metadata bean code.
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/Resolver.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/Resolver.java 2009-01-08 17:25:51 UTC (rev 834)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/Resolver.java 2009-01-08 17:40:08 UTC (rev 835)
@@ -28,6 +28,7 @@
import java.util.TreeSet;
import java.util.concurrent.Callable;
+import javax.webbeans.InjectionPoint;
import javax.webbeans.NullableDependencyException;
import javax.webbeans.TypeLiteral;
import javax.webbeans.manager.Bean;
@@ -35,6 +36,7 @@
import javax.webbeans.manager.InterceptionType;
import javax.webbeans.manager.Interceptor;
+import org.jboss.webbeans.bean.InjectionPointBean;
import org.jboss.webbeans.introspector.AnnotatedItem;
import org.jboss.webbeans.introspector.ForwardingAnnotatedItem;
import org.jboss.webbeans.model.BindingTypeModel;
@@ -215,6 +217,10 @@
{
beans = new HashSet<Bean<T>>((List) manager.getBeans());
}
+ else if (InjectionPoint.class.isAssignableFrom(element.getType()))
+ {
+ beans.add(InjectionPointBean.of(key, manager));
+ }
else
{
beans = registerInjectionPoint(element);
Added: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/InjectionPointBean.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/InjectionPointBean.java (rev 0)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/InjectionPointBean.java 2009-01-08 17:40:08 UTC (rev 835)
@@ -0,0 +1,66 @@
+/*
+ * JBoss, Home of Professional Open Source
+ * Copyright 2008, Red Hat Middleware LLC, and individual contributors
+ * by the @authors tag. See the copyright.txt in the distribution for a
+ * full listing of individual contributors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.jboss.webbeans.bean;
+
+import org.jboss.webbeans.ManagerImpl;
+import org.jboss.webbeans.introspector.AnnotatedItem;
+
+/**
+ * Bean for InjectionPoint metadata
+ *
+ * @author David Allen
+ *
+ */
+public class InjectionPointBean<T, S> extends AbstractFacadeBean<T, S, Object>
+{
+
+ /**
+ * Creates an InjectionPoint Web Bean for the injection of the containing bean owning
+ * the field, constructor or method for the annotated item
+ *
+ * @param <T> must be InjectionPoint
+ * @param <S>
+ * @param field The annotated member field/parameter for the injection
+ * @param manager The RI manager implementation
+ * @return a new bean for this injection point
+ */
+ public static <T, S> InjectionPointBean<T, S> of(AnnotatedItem<T, S> field, ManagerImpl manager)
+ {
+ return new InjectionPointBean<T, S>(field, manager);
+ }
+
+ protected InjectionPointBean(AnnotatedItem<T, S> field, ManagerImpl manager)
+ {
+ super(field, manager);
+ }
+
+ @SuppressWarnings("unchecked")
+ @Override
+ public T create()
+ {
+ return (T) manager.getInjectionPointFactory().getPreviousInjectionPoint();
+ }
+
+ @Override
+ public void destroy(T instance)
+ {
+ // The instance is always in the Dependent context and can be garbage
+ // collected
+ }
+
+}
Property changes on: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/InjectionPointBean.java
___________________________________________________________________
Name: svn:mime-type
+ text/plain
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 17:25:51 UTC (rev 834)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 17:40:08 UTC (rev 835)
@@ -119,15 +119,29 @@
}
InjectionPointFactory injectionPointFactory = manager.getInjectionPointFactory();
injectionPointFactory.pushBean(this);
- T instance = constructor.newInstance(manager);
- injectionPointFactory.pushInstance(instance);
- bindDecorators();
- bindInterceptors();
- injectEjbAndCommonFields(instance);
- injectBoundFields(instance);
- callInitializers(instance);
- callPostConstruct(instance);
- injectionPointFactory.popBeanAndInstance();
+ T instance = null;
+ try
+ {
+ instance = constructor.newInstance(manager);
+ try
+ {
+ injectionPointFactory.pushInstance(instance);
+ bindDecorators();
+ bindInterceptors();
+ injectEjbAndCommonFields(instance);
+ injectBoundFields(instance);
+ callInitializers(instance);
+ callPostConstruct(instance);
+ }
+ finally
+ {
+ injectionPointFactory.popInstance();
+ }
+ }
+ finally
+ {
+ injectionPointFactory.popBean();
+ }
return instance;
}
finally
@@ -261,15 +275,14 @@
for (AnnotatedField<?> injectableField : getInjectableFields())
{
injectionPointFactory.pushInjectionPoint(injectableField);
- if (InjectionPoint.class.isAssignableFrom(injectableField.getType()))
+ try
{
- injectableField.inject(instance, injectionPointFactory.newInstance());
+ injectableField.inject(instance, manager);
}
- else
+ finally
{
- injectableField.inject(instance, manager);
+ injectionPointFactory.popInjectionPoint();
}
- injectionPointFactory.popInjectionPoint();
}
}
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java 2009-01-08 17:25:51 UTC (rev 834)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointFactory.java 2009-01-08 17:40:08 UTC (rev 835)
@@ -73,12 +73,20 @@
}
/**
- * Pops the bean and its current instance from the stack. This should be called
+ * Pops the bean from the stack. This should be called
* whenever all processing is complete for instantiating a bean.
*/
- public void popBeanAndInstance()
+ public void popBean()
{
beans.pop();
+ }
+
+ /**
+ * Pops the current instance from the stack. This should be called
+ * whenever all processing is complete for instantiating a bean.
+ */
+ public void popInstance()
+ {
beanInstances.pop();
}
@@ -98,7 +106,7 @@
*
* @return a new injection point metadata object
*/
- public InjectionPoint newInstance()
+ public InjectionPoint getPreviousInjectionPoint()
{
// When the injected member is a constructor, we are short one instance,
// so the instance on the top of the stack is the bean instance
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java 2009-01-08 17:25:51 UTC (rev 834)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/introspector/jlr/AbstractAnnotatedMember.java 2009-01-08 17:40:08 UTC (rev 835)
@@ -26,7 +26,6 @@
import java.util.Map;
import javax.webbeans.BindingType;
-import javax.webbeans.InjectionPoint;
import javax.webbeans.manager.Manager;
import org.jboss.webbeans.ManagerImpl;
@@ -138,7 +137,7 @@
{
return Reflections.isTransient(getDelegate());
}
-
+
/**
* Gets the current value of the member
*
@@ -176,16 +175,16 @@
}
toString = "Abstract annotated member " + getName();
return toString;
- }
-
+ }
+
public S getMember()
{
return getDelegate();
}
/**
- * Helper method for getting the current parameter values from a list
- * of annotated parameters.
+ * Helper method for getting the current parameter values from a list of
+ * annotated parameters.
*
* @param parameters The list of annotated parameter to look up
* @param manager The Web Beans manager
@@ -197,8 +196,8 @@
}
/**
- * Helper method for getting the current parameter values from a list
- * of annotated parameters.
+ * Helper method for getting the current parameter values from a list of
+ * annotated parameters.
*
* @param parameters The list of annotated parameter to look up
* @param manager The Web Beans manager
@@ -206,27 +205,30 @@
*/
protected Object[] getParameterValues(List<AnnotatedParameter<Object>> parameters, Object specialVal, Class<? extends Annotation> specialParam, ManagerImpl manager)
{
+ Object[] parameterValues = new Object[parameters.size()];
InjectionPointFactory injectionPointFactory = manager.getInjectionPointFactory();
injectionPointFactory.pushInjectionPoint(this);
- Object[] parameterValues = new Object[parameters.size()];
- Iterator<AnnotatedParameter<Object>> iterator = parameters.iterator();
- for (int i = 0; i < parameterValues.length; i++)
+ try
{
- AnnotatedParameter<Object> param = iterator.next();
- if ( specialParam!=null && param.isAnnotationPresent(specialParam))
+ Iterator<AnnotatedParameter<Object>> iterator = parameters.iterator();
+ for (int i = 0; i < parameterValues.length; i++)
{
- parameterValues[i] = specialVal;
+ AnnotatedParameter<Object> param = iterator.next();
+ if (specialParam != null && param.isAnnotationPresent(specialParam))
+ {
+ parameterValues[i] = specialVal;
+ }
+ else
+ {
+ parameterValues[i] = param.getValue(manager);
+ }
}
- else if ( InjectionPoint.class.isAssignableFrom(param.getType()) )
- {
- parameterValues[i] = injectionPointFactory.newInstance();
- }
- else
- {
- parameterValues[i] = param.getValue(manager);
- }
}
- injectionPointFactory.popInjectionPoint();
+ finally
+ {
+ injectionPointFactory.popInjectionPoint();
+
+ }
return parameterValues;
}
16 years
[webbeans-commits] Webbeans SVN: r834 - ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection.
by webbeans-commits@lists.jboss.org
Author: pete.muir(a)jboss.org
Date: 2009-01-08 12:25:51 -0500 (Thu, 08 Jan 2009)
New Revision: 834
Modified:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointImpl.java
Log:
basic toString
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointImpl.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointImpl.java 2009-01-08 16:49:29 UTC (rev 833)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/injection/InjectionPointImpl.java 2009-01-08 17:25:51 UTC (rev 834)
@@ -95,4 +95,10 @@
{
return this.memberInjectionPoint.isAnnotationPresent(annotationType);
}
+
+ @Override
+ public String toString()
+ {
+ return memberInjectionPoint.toString();
+ }
}
16 years
[webbeans-commits] Webbeans SVN: r833 - ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean.
by webbeans-commits@lists.jboss.org
Author: pete.muir(a)jboss.org
Date: 2009-01-08 11:49:29 -0500 (Thu, 08 Jan 2009)
New Revision: 833
Modified:
ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
Log:
support injection of @PersistenceContext into setters
Modified: ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java
===================================================================
--- ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 16:49:10 UTC (rev 832)
+++ ri/trunk/webbeans-ri/src/main/java/org/jboss/webbeans/bean/SimpleBean.java 2009-01-08 16:49:29 UTC (rev 833)
@@ -238,9 +238,16 @@
for (AnnotatedField<?> field : annotatedItem.getAnnotatedFields(manager.getEjbResolver().getPersistenceContextAnnotation()))
{
InjectionPoint injectionPoint = new InjectionPointImpl(field, this, beanInstance);
- Object persistenceContext = manager.getEjbResolver().resolvePersistenceUnit(injectionPoint, manager.getNaming());
- field.inject(beanInstance, persistenceContext);
+ Object puInstance = manager.getEjbResolver().resolvePersistenceUnit(injectionPoint, manager.getNaming());
+ field.inject(beanInstance, puInstance);
}
+
+ for (AnnotatedMethod<?> method : annotatedItem.getAnnotatedMethods(manager.getEjbResolver().getPersistenceContextAnnotation()))
+ {
+ InjectionPoint injectionPoint = new InjectionPointImpl(method, this, beanInstance);
+ Object puInstance = manager.getEjbResolver().resolvePersistenceUnit(injectionPoint, manager.getNaming());
+ method.invoke(beanInstance, puInstance);
+ }
}
/**
16 years
[webbeans-commits] Webbeans SVN: r832 - ri/trunk/webbeans-ri-spi/src/main/java/org/jboss/webbeans/ejb/spi.
by webbeans-commits@lists.jboss.org
Author: pete.muir(a)jboss.org
Date: 2009-01-08 11:49:10 -0500 (Thu, 08 Jan 2009)
New Revision: 832
Modified:
ri/trunk/webbeans-ri-spi/src/main/java/org/jboss/webbeans/ejb/spi/EjbResolver.java
Log:
minor
Modified: ri/trunk/webbeans-ri-spi/src/main/java/org/jboss/webbeans/ejb/spi/EjbResolver.java
===================================================================
--- ri/trunk/webbeans-ri-spi/src/main/java/org/jboss/webbeans/ejb/spi/EjbResolver.java 2009-01-08 16:47:30 UTC (rev 831)
+++ ri/trunk/webbeans-ri-spi/src/main/java/org/jboss/webbeans/ejb/spi/EjbResolver.java 2009-01-08 16:49:10 UTC (rev 832)
@@ -28,8 +28,7 @@
* The injection point metadata
* @return the JNDI name
* @throws IllegalArgumentException
- * if the injection point is not annotated with
- * @EJB
+ * if the injection point is not annotated with @EJB
* @throws DefinitionException
* if the injection point is not suitable for injection
* @throws IllegalStateException
@@ -46,11 +45,9 @@
* The injection point metadata
* @return the JNDI name
* @throws IllegalArgumentException
- * if the injection point is not annotated with
- * @PersistenceContext
+ * if the injection point is not annotated with @PersistenceContext
* @throws UnsupportedOperationException
- * if the injection point is annotated
- * @PersistenceContext(EXTENTED)
+ * if the injection point is annotated @PersistenceContext(EXTENTED)
* @throws IllegalStateException
* if no suitable persistence units can be resolved for injection
*/
@@ -61,8 +58,7 @@
*
* @EJB injection point
*
- * @return the annotation which defines an
- * @EJB injection point
+ * @return the annotation which defines an @EJB injection point
*/
public Class<? extends Annotation> getEJBAnnotation();
@@ -71,8 +67,7 @@
*
* @PersistenceContext injection point
*
- * @return the annoation which defines a
- * @PersistenceContext injection point
+ * @return the annoation which defines a @PersistenceContext injection point
*/
public Class<? extends Annotation> getPersistenceContextAnnotation();
16 years