[infinispan-issues] [JBoss JIRA] (ISPN-4506) Fix types on AdvancedCacheLoader to be friendlier for loader implementors
William Burns (JIRA)
issues at jboss.org
Fri Jul 11 08:21:26 EDT 2014
William Burns created ISPN-4506:
-----------------------------------
Summary: Fix types on AdvancedCacheLoader to be friendlier for loader implementors
Key: ISPN-4506
URL: https://issues.jboss.org/browse/ISPN-4506
Project: Infinispan
Issue Type: Bug
Security Level: Public (Everyone can see)
Reporter: William Burns
Assignee: Mircea Markus
Currently AdvancedCacheLoader has the following method
{code}
void process(KeyFilter<? super K> filter, CacheLoaderTask<? super K, ? super V> task, Executor executor, boolean fetchValue, boolean fetchMetadata);
{code}
The issue is that the CacheLoaderTask doesn't use the lower bound wildcard types directly. Instead it has an argument of MarshalledEntry<K, V> which means the lower bounds are applied to this Entry. Unfortunately the JVM compiler cannot do lower bounds properly on a nested type like this so it can cause issues when passing this as an argument.
Instead we should change the process method to have strong types for the CacheLoaderTask which would allow for implementors to easily implement this. This does lose the ability to pass super types for the CacheLoaderTask types, however this is unlikely to be used often and can easily be worked around while maintaining type safety. On the inverse the implementors of AdvancedCacheLoader have to resort to raw types to get it to compile.
--
This message was sent by Atlassian JIRA
(v6.2.6#6264)
More information about the infinispan-issues
mailing list