Author: husted Date: Thu Jan 17 03:56:38 2008 New Revision: 612799 URL: http://svn.apache.org/viewvc?rev=612799&view=rev Log: WW-2226 "TextProvider.class should not be registered as a Singleton" Apply patch provided by Darren Shepherd.
Modified: struts/struts2/trunk/core/src/main/java/org/apache/struts2/config/BeanSelectionProvider.java struts/struts2/trunk/core/src/main/resources/struts-default.xml Modified: struts/struts2/trunk/core/src/main/java/org/apache/struts2/config/BeanSelectionProvider.java URL: http://svn.apache.org/viewvc/struts/struts2/trunk/core/src/main/java/org/apache/struts2/config/BeanSelectionProvider.java?rev=612799&r1=612798&r2=612799&view=diff ============================================================================== --- struts/struts2/trunk/core/src/main/java/org/apache/struts2/config/BeanSelectionProvider.java (original) +++ struts/struts2/trunk/core/src/main/java/org/apache/struts2/config/BeanSelectionProvider.java Thu Jan 17 03:56:38 2008 @@ -117,7 +117,7 @@ * <td>com.opensymphony.xwork2.validator.ActionValidatorManager</td> * <td>struts.actionValidatorManager</td> * <td>singleton</td> - * <td>Main interface for validation managers (regular and annotation based). Handles both the loading of + * <td>Main interface for validation managers (regular and annotation based). Handles both the loading of * configuration and the actual validation (since 2.1)</td> * </tr> * <tr> @@ -151,7 +151,7 @@ * <td>Matches patterns, such as action names, generally used in configuration (since 2.1)</td> * </tr> * </table> - * + * * <!-- END SNIPPET: extensionPoints --> * </p> * <p> @@ -174,7 +174,7 @@ public class BeanSelectionProvider implements ConfigurationProvider { public static final String DEFAULT_BEAN_NAME = "struts"; private static final Logger LOG = LoggerFactory.getLogger(BeanSelectionProvider.class); - + public void destroy() { // NO-OP } @@ -182,10 +182,10 @@ public void loadPackages() throws ConfigurationException { // NO-OP } - + public void init(Configuration configuration) throws ConfigurationException { // NO-OP - + } public boolean needsReload() { @@ -195,7 +195,7 @@ public void register(ContainerBuilder builder, LocatableProperties props) { alias(ObjectFactory.class, StrutsConstants.STRUTS_OBJECTFACTORY, builder, props); alias(XWorkConverter.class, StrutsConstants.STRUTS_XWORKCONVERTER, builder, props); - alias(TextProvider.class, StrutsConstants.STRUTS_XWORKTEXTPROVIDER, builder, props); + alias(TextProvider.class, StrutsConstants.STRUTS_XWORKTEXTPROVIDER, builder, props, Scope.DEFAULT); alias(ActionProxyFactory.class, StrutsConstants.STRUTS_ACTIONPROXYFACTORY, builder, props); alias(ObjectTypeDeterminer.class, StrutsConstants.STRUTS_OBJECTTYPEDETERMINER, builder, props); alias(ActionMapper.class, StrutsConstants.STRUTS_MAPPER_CLASS, builder, props); @@ -208,7 +208,7 @@ alias(ReflectionProvider.class, StrutsConstants.STRUTS_REFLECTIONPROVIDER, builder, props); alias(ReflectionContextFactory.class, StrutsConstants.STRUTS_REFLECTIONCONTEXTFACTORY, builder, props); alias(PatternMatcher.class, StrutsConstants.STRUTS_PATTERNMATCHER, builder, props); - + if ("true".equalsIgnoreCase(props.getProperty(StrutsConstants.STRUTS_DEVMODE))) { props.setProperty(StrutsConstants.STRUTS_I18N_RELOAD, "true"); props.setProperty(StrutsConstants.STRUTS_CONFIGURATION_XML_RELOAD, "true"); @@ -218,21 +218,21 @@ } else { props.setProperty("devMode", "false"); } - + String val = props.getProperty(StrutsConstants.STRUTS_ALLOW_STATIC_METHOD_ACCESS); if (val != null) { props.setProperty("allowStaticMethodAccess", val); } - + // TODO: This should be moved to XWork after 2.0.4 // struts.custom.i18n.resources LocalizedTextUtil.addDefaultResourceBundle("org/apache/struts2/struts-messages"); - + String bundles = props.getProperty(StrutsConstants.STRUTS_CUSTOM_I18N_RESOURCES); - if (bundles != null && bundles.length() > 0) { + if (bundles != null && bundles.length() > 0) { StringTokenizer customBundles = new StringTokenizer(props.getProperty(StrutsConstants.STRUTS_CUSTOM_I18N_RESOURCES), ", "); - + while (customBundles.hasMoreTokens()) { String name = customBundles.nextToken(); try { @@ -241,14 +241,14 @@ } catch (Exception e) { LOG.error("Could not find messages file " + name + ".properties. Skipping"); } - } + } } } - + void alias(Class type, String key, ContainerBuilder builder, Properties props) { alias(type, key, builder, props, Scope.SINGLETON); } - + void alias(Class type, String key, ContainerBuilder builder, Properties props, Scope scope) { if (!builder.contains(type)) { String foundName = props.getProperty(key, DEFAULT_BEAN_NAME); @@ -284,7 +284,7 @@ LOG.warn("Unable to alias bean type "+type+", default mapping already assigned."); } } - + static class ObjectFactoryDelegateFactory implements Factory { String name; Class type; @@ -292,7 +292,7 @@ this.name = name; this.type = type; } - + public Object create(Context context) throws Exception { ObjectFactory objFactory = context.getContainer().getInstance(ObjectFactory.class); try { Modified: struts/struts2/trunk/core/src/main/resources/struts-default.xml URL: http://svn.apache.org/viewvc/struts/struts2/trunk/core/src/main/resources/struts-default.xml?rev=612799&r1=612798&r2=612799&view=diff ============================================================================== --- struts/struts2/trunk/core/src/main/resources/struts-default.xml (original) +++ struts/struts2/trunk/core/src/main/resources/struts-default.xml Thu Jan 17 03:56:38 2008 @@ -38,7 +38,7 @@ <bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="struts" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/> <bean type="com.opensymphony.xwork2.util.PatternMatcher" name="struts" class="com.opensymphony.xwork2.util.WildcardHelper" /> - + <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="struts" class="org.apache.struts2.dispatcher.mapper.DefaultActionMapper" /> <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="composite" class="org.apache.struts2.dispatcher.mapper.CompositeActionMapper" /> <bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="restful" class="org.apache.struts2.dispatcher.mapper.RestfulActionMapper" /> @@ -61,8 +61,8 @@ <bean type="com.opensymphony.xwork2.conversion.impl.XWorkConverter" name="xwork1" class="com.opensymphony.xwork2.conversion.impl.XWorkConverter" /> <bean class="com.opensymphony.xwork2.conversion.impl.XWorkBasicConverter" /> - <bean type="com.opensymphony.xwork2.TextProvider" name="xwork1" class="com.opensymphony.xwork2.TextProviderSupport" /> - <bean type="com.opensymphony.xwork2.TextProvider" name="struts" class="com.opensymphony.xwork2.TextProviderSupport" /> + <bean type="com.opensymphony.xwork2.TextProvider" name="xwork1" class="com.opensymphony.xwork2.TextProviderSupport" scope="default" /> + <bean type="com.opensymphony.xwork2.TextProvider" name="struts" class="com.opensymphony.xwork2.TextProviderSupport" scope="default" /> <bean type="org.apache.struts2.components.UrlRenderer" name="struts" class="org.apache.struts2.components.ServletUrlRenderer"/> @@ -100,7 +100,7 @@ <bean type="ognl.PropertyAccessor" name="java.util.ArrayList" class="com.opensymphony.xwork2.ognl.accessor.XWorkListPropertyAccessor" /> <bean type="ognl.PropertyAccessor" name="java.util.HashSet" class="com.opensymphony.xwork2.ognl.accessor.XWorkCollectionPropertyAccessor" /> <bean type="ognl.PropertyAccessor" name="java.util.HashMap" class="com.opensymphony.xwork2.ognl.accessor.XWorkMapPropertyAccessor" /> - + <package name="struts-default" abstract="true"> <result-types> <result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/> @@ -167,7 +167,7 @@ <interceptor-ref name="validation"/> <interceptor-ref name="workflow"/> </interceptor-stack> - + <!-- Sample JSON validation stack --> <interceptor-stack name="jsonValidationWorkflowStack"> <interceptor-ref name="basicStack"/>