Author: bwallace
Date: Mon Apr 24 23:09:08 2006
New Revision: 396779

URL: http://svn.apache.org/viewcvs?rev=396779&view=rev
Log:
[TAPESTRY-617] Added context class loader parameter to Ognl.getValue call

Added:
    
tapestry/tapestry4/branches/branch-3-0/framework/src/org/apache/tapestry/util/prop/OgnlClassResolver.java
Modified:
    
tapestry/tapestry4/branches/branch-3-0/contrib/src/org/apache/tapestry/contrib/table/model/ognl/OgnlTableColumnEvaluator.java

Modified: 
tapestry/tapestry4/branches/branch-3-0/contrib/src/org/apache/tapestry/contrib/table/model/ognl/OgnlTableColumnEvaluator.java
URL: 
http://svn.apache.org/viewcvs/tapestry/tapestry4/branches/branch-3-0/contrib/src/org/apache/tapestry/contrib/table/model/ognl/OgnlTableColumnEvaluator.java?rev=396779&r1=396778&r2=396779&view=diff
==============================================================================
--- 
tapestry/tapestry4/branches/branch-3-0/contrib/src/org/apache/tapestry/contrib/table/model/ognl/OgnlTableColumnEvaluator.java
 (original)
+++ 
tapestry/tapestry4/branches/branch-3-0/contrib/src/org/apache/tapestry/contrib/table/model/ognl/OgnlTableColumnEvaluator.java
 Mon Apr 24 23:09:08 2006
@@ -14,6 +14,9 @@
 
 package org.apache.tapestry.contrib.table.model.ognl;
 
+import java.util.Map;
+
+import ognl.ClassResolver;
 import ognl.Ognl;
 import ognl.OgnlException;
 
@@ -21,6 +24,7 @@
 import org.apache.commons.logging.LogFactory;
 import org.apache.tapestry.contrib.table.model.ITableColumn;
 import org.apache.tapestry.contrib.table.model.simple.ITableColumnEvaluator;
+import org.apache.tapestry.util.prop.OgnlClassResolver;
 import org.apache.tapestry.util.prop.OgnlUtils;
 
 /**
@@ -32,6 +36,8 @@
        private static final Log LOG =
                LogFactory.getLog(ExpressionTableColumn.class);
 
+    private final ClassResolver _ognlResolver = new OgnlClassResolver();
+
        private String m_strExpression;
        transient private Object m_objParsedExpression = null;
 
@@ -58,7 +64,8 @@
 
                try
                {
-                       Object objValue = Ognl.getValue(m_objParsedExpression, 
objRow);
+            Map context = Ognl.createDefaultContext(objRow, _ognlResolver);
+                       Object objValue = Ognl.getValue(m_objParsedExpression, 
context, objRow);
                        return objValue;
                }
                catch (OgnlException e)

Added: 
tapestry/tapestry4/branches/branch-3-0/framework/src/org/apache/tapestry/util/prop/OgnlClassResolver.java
URL: 
http://svn.apache.org/viewcvs/tapestry/tapestry4/branches/branch-3-0/framework/src/org/apache/tapestry/util/prop/OgnlClassResolver.java?rev=396779&view=auto
==============================================================================
--- 
tapestry/tapestry4/branches/branch-3-0/framework/src/org/apache/tapestry/util/prop/OgnlClassResolver.java
 (added)
+++ 
tapestry/tapestry4/branches/branch-3-0/framework/src/org/apache/tapestry/util/prop/OgnlClassResolver.java
 Mon Apr 24 23:09:08 2006
@@ -0,0 +1,58 @@
+// Copyright 2004, 2005 The Apache Software Foundation
+//
+// 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.apache.tapestry.util.prop;
+
+import java.util.Map;
+
+import ognl.ClassResolver;
+
+/**
+ * Implementation of OGNL's ClassResolver (which is unfortunately, named
+ * the same as HiveMind's ClassResolver).
+ *
+ * @author Howard Lewis Ship
+ */
+public class OgnlClassResolver implements ClassResolver
+{
+    private ClassLoader _loader;
+
+    /**
+     * Creates a new ClassResolver with the current thread's context class 
loader
+     *
+     */
+    public OgnlClassResolver()
+    {
+        this(Thread.currentThread().getContextClassLoader());
+    }
+
+    /**
+     * Creates a new ClassResolver with the specified class loader
+     * @param loader ClassLoader to use for class resolution
+     */
+    public OgnlClassResolver(ClassLoader loader)
+    {
+        _loader = loader;
+    }
+
+    /**
+     * 
+     * @see ognl.ClassResolver#classForName(java.lang.String, java.util.Map)
+     */
+    public Class classForName(String name, Map context) throws 
ClassNotFoundException
+    {
+        return Class.forName(name, true, _loader);
+    }
+
+}



---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to