You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cxf.apache.org by dk...@apache.org on 2012/12/14 16:51:08 UTC
svn commit: r1421946 -
/cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java
Author: dkulp
Date: Fri Dec 14 15:51:07 2012
New Revision: 1421946
URL: http://svn.apache.org/viewvc?rev=1421946&view=rev
Log:
[CXF-4703] Slight optimization
Modified:
cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java
Modified: cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java
URL: http://svn.apache.org/viewvc/cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java?rev=1421946&r1=1421945&r2=1421946&view=diff
==============================================================================
--- cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java (original)
+++ cxf/trunk/rt/core/src/main/java/org/apache/cxf/bus/CXFBusImpl.java Fri Dec 14 15:51:07 2012
@@ -94,7 +94,11 @@ public class CXFBusImpl extends Abstract
public final <T> T getExtension(Class<T> extensionType) {
Object obj = extensions.get(extensionType);
- if (obj == null && !missingExtensions.contains(extensionType)) {
+ if (obj == null) {
+ if (missingExtensions.contains(extensionType)) {
+ //already know we cannot find it
+ return null;
+ }
ConfiguredBeanLocator loc = (ConfiguredBeanLocator)extensions.get(ConfiguredBeanLocator.class);
if (loc == null) {
loc = createConfiguredBeanLocator();
@@ -113,6 +117,7 @@ public class CXFBusImpl extends Abstract
if (null != obj) {
return extensionType.cast(obj);
} else {
+ //record that it couldn't be found to avoid expensive searches again in the future
missingExtensions.add(extensionType);
}
return null;