From 09fdc02e7a412927582fe8b46080b44b0d63ba35 Mon Sep 17 00:00:00 2001 From: rfeng Date: Sat, 21 May 2011 04:35:44 +0000 Subject: Allows pass -by-reference for self references git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1125636 13f79535-47bb-0310-9956-ffa450edef68 --- .../sca/binding/sca/provider/RuntimeSCAReferenceBindingProvider.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'sca-java-2.x/trunk/modules/binding-sca-runtime') diff --git a/sca-java-2.x/trunk/modules/binding-sca-runtime/src/main/java/org/apache/tuscany/sca/binding/sca/provider/RuntimeSCAReferenceBindingProvider.java b/sca-java-2.x/trunk/modules/binding-sca-runtime/src/main/java/org/apache/tuscany/sca/binding/sca/provider/RuntimeSCAReferenceBindingProvider.java index dc2337ef8d..122959d935 100644 --- a/sca-java-2.x/trunk/modules/binding-sca-runtime/src/main/java/org/apache/tuscany/sca/binding/sca/provider/RuntimeSCAReferenceBindingProvider.java +++ b/sca-java-2.x/trunk/modules/binding-sca-runtime/src/main/java/org/apache/tuscany/sca/binding/sca/provider/RuntimeSCAReferenceBindingProvider.java @@ -148,7 +148,9 @@ public class RuntimeSCAReferenceBindingProvider implements EndpointReferenceAsyn } else { Reference ref = epr.getReference().getReference(); // The spec says both ref and service needs to allowsPassByReference - boolean allowsPBR = (ref != null && ref.isAllowsPassByReference()) && chain.allowsPassByReference(); + boolean allowsPBR = + (epr.getReference().isAllowsPassByReference() || (ref != null && ref.isAllowsPassByReference())) && chain + .allowsPassByReference(); if (allowsPBR && interfaceContractMapper.isCompatibleByReference(operation, targetOp, -- cgit v1.2.3