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"/>


Reply via email to