Author: hlship
Date: Tue Jul 13 22:13:56 2010
New Revision: 963878
URL: http://svn.apache.org/viewvc?rev=963878&view=rev
Log:
TAP5-1197: Introduce a level of indirection concerning FieldAccess that allows
for optimized access in some circumstances
Added:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java
(with props)
Modified:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalClassTransformationImpl.java
Added:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java
URL:
http://svn.apache.org/viewvc/tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java?rev=963878&view=auto
==============================================================================
---
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java
(added)
+++
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java
Tue Jul 13 22:13:56 2010
@@ -0,0 +1,45 @@
+// Copyright 2010 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.tapestry5.internal.services;
+
+import org.apache.tapestry5.ioc.services.FieldValueConduit;
+import org.apache.tapestry5.services.FieldAccess;
+import org.apache.tapestry5.services.TransformField;
+
+/**
+ * A temporary version of {...@link FieldAccess} returned in some
circumstances from {...@link TransformField#getAccess()}.
+ * {...@linkplain
TransformField#replaceAccess(org.apache.tapestry5.ioc.services.FieldValueConduit)
replaced} (with a
+ * {...@link FieldValueConduit}), the delegate of this class may be pointed
directly at the FieldValueConduit (through an
+ * adapter) and no extra classes or static methods (on the component class)
will need to be constructed.
+ *
+ * @since 5.2.0
+ */
+class DelegateFieldAccess implements FieldAccess
+{
+ // Technically, this field should be volatile or synchronized; I hope it
falls under the proper
+ // synchronization umbrella by the time its actually used in a live
component class.
+
+ FieldAccess delegate;
+
+ public Object read(Object instance)
+ {
+ return delegate.read(instance);
+ }
+
+ public void write(Object instance, Object value)
+ {
+ delegate.write(instance, value);
+ }
+}
Propchange:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/DelegateFieldAccess.java
------------------------------------------------------------------------------
svn:eol-style = native
Modified:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalClassTransformationImpl.java
URL:
http://svn.apache.org/viewvc/tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalClassTransformationImpl.java?rev=963878&r1=963877&r2=963878&view=diff
==============================================================================
---
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalClassTransformationImpl.java
(original)
+++
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalClassTransformationImpl.java
Tue Jul 13 22:13:56 2010
@@ -433,6 +433,8 @@ public final class InternalClassTransfor
String readValueBody, writeValueBody;
+ private DelegateFieldAccess delegateFieldAccess;
+
private org.apache.tapestry5.services.FieldAccess access;
TransformFieldImpl(CtField field, boolean added)
@@ -452,6 +454,16 @@ public final class InternalClassTransfor
}
}
+ void doFinish()
+ {
+ if (delegateFieldAccess != null)
+ {
+ access = createAccess();
+ delegateFieldAccess.delegate = access;
+ delegateFieldAccess = null;
+ }
+ }
+
@Override
public String toString()
{
@@ -550,18 +562,23 @@ public final class InternalClassTransfor
{
failIfFrozen();
- if (access == null)
- createAccess();
+ if (access != null)
+ return access;
- return access;
+ if (delegateFieldAccess == null)
+ {
+ delegateFieldAccess = new DelegateFieldAccess();
+ }
+
+ return delegateFieldAccess;
}
- private void createAccess()
+ private org.apache.tapestry5.services.FieldAccess createAccess()
{
TransformMethod reader = createReader();
TransformMethod writer = createWriter();
- access = createFieldAccess(reader, writer);
+ return createFieldAccess(reader, writer);
}
private org.apache.tapestry5.services.FieldAccess
createFieldAccess(TransformMethod reader,
@@ -646,6 +663,16 @@ public final class InternalClassTransfor
{
String fieldName =
addInjectedFieldUncached(FieldValueConduit.class, name + "$conduit", conduit);
+ // TODO: If access != null?
+
+ access = toFieldAccess(conduit);
+
+ if (delegateFieldAccess != null)
+ {
+ delegateFieldAccess.delegate = access;
+ delegateFieldAccess = null;
+ }
+
replaceAccess(getTransformFieldImpl(fieldName));
}
@@ -1807,6 +1834,14 @@ public final class InternalClassTransfor
{
failIfFrozen();
+ // Finishing fields may sometimes create new methods, so finish the
fields
+ // first.
+
+ for (TransformFieldImpl tfi : fields.values())
+ {
+ tfi.doFinish();
+ }
+
// doFinish() will sometimes create new methods on the
ClassTransformation, yielding
// a concurrent modification exception, so do a defensive copy.
@@ -2344,4 +2379,21 @@ public final class InternalClassTransfor
}
};
}
+
+ private static org.apache.tapestry5.services.FieldAccess
toFieldAccess(final FieldValueConduit conduit)
+ {
+ return new org.apache.tapestry5.services.FieldAccess()
+ {
+
+ public void write(Object instance, Object value)
+ {
+ conduit.set(value);
+ }
+
+ public Object read(Object instance)
+ {
+ return conduit.get();
+ }
+ };
+ }
}