OPENJPA-437

git-svn-id: https://svn.apache.org/repos/asf/openjpa/branches/1.0.x@615368 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Patrick Linskey 2008-01-25 21:59:50 +00:00
parent 3a7f54f3d9
commit ce44c20cbd
1 changed files with 4 additions and 3 deletions

View File

@ -46,7 +46,6 @@ import org.apache.openjpa.event.BrokerFactoryEvent;
import org.apache.openjpa.lib.log.Log; import org.apache.openjpa.lib.log.Log;
import org.apache.openjpa.lib.util.J2DoPrivHelper; import org.apache.openjpa.lib.util.J2DoPrivHelper;
import org.apache.openjpa.lib.util.Localizer; import org.apache.openjpa.lib.util.Localizer;
import org.apache.openjpa.lib.util.ReferenceHashSet;
import org.apache.openjpa.lib.util.JavaVersions; import org.apache.openjpa.lib.util.JavaVersions;
import org.apache.openjpa.lib.util.concurrent.ConcurrentHashMap; import org.apache.openjpa.lib.util.concurrent.ConcurrentHashMap;
import org.apache.openjpa.lib.util.concurrent.ConcurrentReferenceHashSet; import org.apache.openjpa.lib.util.concurrent.ConcurrentReferenceHashSet;
@ -134,7 +133,8 @@ public abstract class AbstractBrokerFactory
*/ */
protected AbstractBrokerFactory(OpenJPAConfiguration config) { protected AbstractBrokerFactory(OpenJPAConfiguration config) {
_conf = config; _conf = config;
_pcClassLoaders = new ReferenceHashSet(ReferenceHashSet.WEAK); _pcClassLoaders = new ConcurrentReferenceHashSet(
ConcurrentReferenceHashSet.WEAK);
} }
/** /**
@ -256,7 +256,7 @@ public abstract class AbstractBrokerFactory
if (clss.isEmpty()) if (clss.isEmpty())
_pcClassNames = Collections.EMPTY_SET; _pcClassNames = Collections.EMPTY_SET;
else { else {
_pcClassNames = new ConcurrentReferenceHashSet( Collection c = new ConcurrentReferenceHashSet(
ConcurrentReferenceHashSet.HARD); ConcurrentReferenceHashSet.HARD);
for (Iterator itr = clss.iterator(); itr.hasNext();) { for (Iterator itr = clss.iterator(); itr.hasNext();) {
Class cls = (Class) itr.next(); Class cls = (Class) itr.next();
@ -265,6 +265,7 @@ public abstract class AbstractBrokerFactory
toRedefine.add(cls); toRedefine.add(cls);
} }
_pcClassLoaders.add(loader); _pcClassLoaders.add(loader);
_pcClassNames = c;
} }
_persistentTypesLoaded = true; _persistentTypesLoaded = true;
} else { } else {