@Override public void register(final BeanDefinition beanDefinition, final Object bean) { instances.put(beanDefinition.name(), new BeanData(pc, beanDefinition, bean)); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { Map<String, BeanData> threadLocalMap = context.get(); threadLocalMap.put(beanDefinition.name(), new BeanData(pc, beanDefinition, bean)); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { HttpServletRequest servletRequest = getCurrentHttpRequest(); Map<String, TransientBeanData> map = getRequestMap(servletRequest); if (map == null) { map = createRequestMap(servletRequest); } map.put(beanDefinition.name(), new TransientBeanData(new BeanData(pc, beanDefinition, bean))); }
/** * Adds object instance to the container as singleton bean. */ public void addBean(final String name, final Object bean, WiringMode wiringMode) { wiringMode = petiteConfig.resolveWiringMode(wiringMode); registerPetiteBean(bean.getClass(), name, SingletonScope.class, wiringMode, false, null); BeanDefinition def = lookupExistingBeanDefinition(name); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(new BeanData(this, def, bean)); }
/** * Wires provided bean with the container and optionally invokes init methods. * Bean is <b>not</b> registered withing container. */ public void wire(final Object bean, final WiringMode wiringMode) { final WiringMode finalWiringMode = petiteConfig.resolveWiringMode(wiringMode); final BeanDefinition def = externalsCache.get( bean.getClass(), () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(bean.getClass(), finalWiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(new BeanData(this, def, bean)); }
/** * Invokes the method of some bean with the container, when its parameters requires to be injected into. * The bean is <b>not</b> registered within container. */ public <T> T invokeMethod(final Object bean, final Method method) { final WiringMode wiringMode = petiteConfig.resolveWiringMode(null); final BeanDefinition def = externalsCache.get( bean.getClass(), () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(bean.getClass(), wiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); final BeanData beanData = new BeanData(this, def, bean); for (MethodInjectionPoint methodInjectionPoint : def.methods) { if (methodInjectionPoint.method.equals(method)) { return (T) beanData.invokeMethodInjectionPoint(methodInjectionPoint); } } try { return (T) method.invoke(bean); } catch (Exception e) { throw new PetiteException(e); } }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { HttpSession session = getCurrentHttpSession(); Map<String, BeanData> map = getSessionMap(session); if (map == null) { map = registerSessionBeans(session); } final BeanData beanData = new BeanData(pc, beanDefinition, bean); map.put(beanDefinition.name(), beanData); registerDestroyableBeans(beanData); }
/** * Returns Petite bean instance. * Petite container will find the bean in corresponding scope and all its dependencies, * either by constructor or property injection. When using constructor injection, cyclic dependencies * can not be prevented, but at least they are detected. * * @see PetiteContainer#createBean(Class) */ public <T> T getBean(final String name) { // Lookup for registered bean definition. BeanDefinition def = lookupBeanDefinition(name); if (def == null) { // try provider ProviderDefinition providerDefinition = providers.get(name); if (providerDefinition != null) { return (T) invokeProvider(providerDefinition); } return null; } // Find the bean in its scope Object bean = def.scopeLookup(); if (bean == null) { // Create new bean in the scope initBeanDefinition(def); final BeanData beanData = new BeanData(this, def); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(beanData); bean = beanData.bean(); } return (T) bean; }
/** * Creates and wires a bean within the container and optionally invokes init methods. However, bean is * <b>not</b> registered. */ @SuppressWarnings({"unchecked"}) public <E> E createBean(final Class<E> type, final WiringMode wiringMode) { final WiringMode finalWiringMode = petiteConfig.resolveWiringMode(wiringMode); final BeanDefinition def = externalsCache.get( type, () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(type, finalWiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); final BeanData<E> beanData = new BeanData(this, def); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(beanData); return beanData.bean(); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { Map<String, BeanData> threadLocalMap = context.get(); threadLocalMap.put(beanDefinition.name(), new BeanData(pc, beanDefinition, bean)); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { instances.put(beanDefinition.name(), new BeanData(pc, beanDefinition, bean)); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { HttpServletRequest servletRequest = getCurrentHttpRequest(); Map<String, TransientBeanData> map = getRequestMap(servletRequest); if (map == null) { map = createRequestMap(servletRequest); } map.put(beanDefinition.name(), new TransientBeanData(new BeanData(pc, beanDefinition, bean))); }
/** * Adds object instance to the container as singleton bean. */ public void addBean(final String name, final Object bean, WiringMode wiringMode) { wiringMode = petiteConfig.resolveWiringMode(wiringMode); registerPetiteBean(bean.getClass(), name, SingletonScope.class, wiringMode, false, null); BeanDefinition def = lookupExistingBeanDefinition(name); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(new BeanData(this, def, bean)); }
/** * Wires provided bean with the container and optionally invokes init methods. * Bean is <b>not</b> registered withing container. */ public void wire(final Object bean, final WiringMode wiringMode) { final WiringMode finalWiringMode = petiteConfig.resolveWiringMode(wiringMode); final BeanDefinition def = externalsCache.get( bean.getClass(), () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(bean.getClass(), finalWiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(new BeanData(this, def, bean)); }
@Override public void register(final BeanDefinition beanDefinition, final Object bean) { HttpSession session = getCurrentHttpSession(); Map<String, BeanData> map = getSessionMap(session); if (map == null) { map = registerSessionBeans(session); } final BeanData beanData = new BeanData(pc, beanDefinition, bean); map.put(beanDefinition.name(), beanData); registerDestroyableBeans(beanData); }
/** * Invokes the method of some bean with the container, when its parameters requires to be injected into. * The bean is <b>not</b> registered within container. */ public <T> T invokeMethod(final Object bean, final Method method) { final WiringMode wiringMode = petiteConfig.resolveWiringMode(null); final BeanDefinition def = externalsCache.get( bean.getClass(), () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(bean.getClass(), wiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); final BeanData beanData = new BeanData(this, def, bean); for (MethodInjectionPoint methodInjectionPoint : def.methods) { if (methodInjectionPoint.method.equals(method)) { return (T) beanData.invokeMethodInjectionPoint(methodInjectionPoint); } } try { return (T) method.invoke(bean); } catch (Exception e) { throw new PetiteException(e); } }
/** * Returns Petite bean instance. * Petite container will find the bean in corresponding scope and all its dependencies, * either by constructor or property injection. When using constructor injection, cyclic dependencies * can not be prevented, but at least they are detected. * * @see PetiteContainer#createBean(Class) */ public <T> T getBean(final String name) { // Lookup for registered bean definition. BeanDefinition def = lookupBeanDefinition(name); if (def == null) { // try provider ProviderDefinition providerDefinition = providers.get(name); if (providerDefinition != null) { return (T) invokeProvider(providerDefinition); } return null; } // Find the bean in its scope Object bean = def.scopeLookup(); if (bean == null) { // Create new bean in the scope initBeanDefinition(def); final BeanData beanData = new BeanData(this, def); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(beanData); bean = beanData.bean(); } return (T) bean; }
/** * Creates and wires a bean within the container and optionally invokes init methods. However, bean is * <b>not</b> registered. */ @SuppressWarnings({"unchecked"}) public <E> E createBean(final Class<E> type, final WiringMode wiringMode) { final WiringMode finalWiringMode = petiteConfig.resolveWiringMode(wiringMode); final BeanDefinition def = externalsCache.get( type, () -> { final BeanDefinition beanDefinition = createBeandDefinitionForExternalBeans(type, finalWiringMode); initBeanDefinition(beanDefinition); return beanDefinition; }); final BeanData<E> beanData = new BeanData(this, def); registerBeanAndWireAndInjectParamsAndInvokeInitMethods(beanData); return beanData.bean(); }