/*
* JBoss, Home of Professional Open Source
* Copyright 2005, JBoss Inc., and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.invocation;
import java.lang.ref.ReferenceQueue;
import java.lang.ref.WeakReference;
/** Exists in EJBCA due to MarshalledValue not existing in JBoss 7 and higher.
* This can give upgrade issues from old version of EJBCA (4) to EJBCA 6,
* moving directly from JBoss 5 to JBoss 7.
* See: https://sourceforge.net/p/ejbca/discussion/123123/thread/e88b1c50/?limit=25
* Jira: https://jira.primekey.se/browse/ECA-3687
* All these classes can be removed when we do not support upgrades from EJBCA 4 any longer.
*/
/**
* Weak value ref.
*
* @author Bill Burke
* @author Adrian Brock
* @author Ales Justin
* @param the key type
* @param the value type
*/
class WeakValueRef extends WeakReference implements ValueRef
{
/**
* The key
*/
public K key;
/**
* Safely create a new WeakValueRef
*
* @param the key type
* @param the value type
* @param key the key
* @param val the value
* @param q the reference queue
* @return the reference or null if the value is null
*/
static WeakValueRef create(K key, V val, ReferenceQueue q)
{
if (val == null)
return null;
else
return new WeakValueRef(key, val, q);
}
/**
* Create a new WeakValueRef.
*
* @param key the key
* @param val the value
* @param q the reference queue
*/
private WeakValueRef(K key, V val, ReferenceQueue q)
{
super(val, q);
this.key = key;
}
public K getKey()
{
return key;
}
public V getValue()
{
return get();
}
public V setValue(V value)
{
throw new UnsupportedOperationException("setValue");
}
@Override
public String toString()
{
return String.valueOf(get());
}
}