1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-01-10 01:10:30 +00:00

Allow registering more generic detail providers

Allow registering details providers matching any super type, not just
the exact type. This is mostly useful for 1.21, where we can have
providers for any DataComponentHolder, not just item stacks.
This commit is contained in:
Jonathan Coates 2024-08-11 11:47:03 +01:00
parent 764e1aa332
commit 5abab982c7
No known key found for this signature in database
GPG Key ID: B9E431FF07C98D06
3 changed files with 13 additions and 16 deletions

View File

@ -13,7 +13,7 @@ import java.util.Map;
import java.util.Objects; import java.util.Objects;
/** /**
* An item detail provider for {@link ItemStack}'s whose {@link Item} has a specific type. * An item detail provider for {@link ItemStack}s whose {@link Item} has a specific type.
* *
* @param <T> The type the stack's item must have. * @param <T> The type the stack's item must have.
*/ */
@ -22,7 +22,7 @@ public abstract class BasicItemDetailProvider<T> implements DetailProvider<ItemS
private final @Nullable String namespace; private final @Nullable String namespace;
/** /**
* Create a new item detail provider. Meta will be inserted into a new sub-map named as per {@code namespace}. * Create a new item detail provider. Details will be inserted into a new sub-map named as per {@code namespace}.
* *
* @param itemType The type the stack's item must have. * @param itemType The type the stack's item must have.
* @param namespace The namespace to use for this provider. * @param namespace The namespace to use for this provider.
@ -34,7 +34,7 @@ public abstract class BasicItemDetailProvider<T> implements DetailProvider<ItemS
} }
/** /**
* Create a new item detail provider. Meta will be inserted directly into the results. * Create a new item detail provider. Details will be inserted directly into the results.
* *
* @param itemType The type the stack's item must have. * @param itemType The type the stack's item must have.
*/ */
@ -53,21 +53,18 @@ public abstract class BasicItemDetailProvider<T> implements DetailProvider<ItemS
* @param stack The item stack to provide details for. * @param stack The item stack to provide details for.
* @param item The item to provide details for. * @param item The item to provide details for.
*/ */
public abstract void provideDetails( public abstract void provideDetails(Map<? super String, Object> data, ItemStack stack, T item);
Map<? super String, Object> data, ItemStack stack, T item
);
@Override @Override
public void provideDetails(Map<? super String, Object> data, ItemStack stack) { public final void provideDetails(Map<? super String, Object> data, ItemStack stack) {
var item = stack.getItem(); var item = stack.getItem();
if (!itemType.isInstance(item)) return; if (!itemType.isInstance(item)) return;
// If `namespace` is specified, insert into a new data map instead of the existing one. if (namespace == null) {
Map<? super String, Object> child = namespace == null ? data : new HashMap<>(); provideDetails(data, stack, itemType.cast(item));
} else {
Map<? super String, Object> child = new HashMap<>();
provideDetails(child, stack, itemType.cast(item)); provideDetails(child, stack, itemType.cast(item));
if (namespace != null) {
data.put(namespace, child); data.put(namespace, child);
} }
} }

View File

@ -26,7 +26,7 @@ public interface DetailRegistry<T> {
* @param provider The detail provider to register. * @param provider The detail provider to register.
* @see DetailProvider * @see DetailProvider
*/ */
void addProvider(DetailProvider<T> provider); void addProvider(DetailProvider<? super T> provider);
/** /**
* Compute basic details about an object. This is cheaper than computing all details operation, and so is suitable * Compute basic details about an object. This is cheaper than computing all details operation, and so is suitable

View File

@ -15,7 +15,7 @@ import java.util.*;
* @param <T> The type of object that this registry provides details for. * @param <T> The type of object that this registry provides details for.
*/ */
public class DetailRegistryImpl<T> implements DetailRegistry<T> { public class DetailRegistryImpl<T> implements DetailRegistry<T> {
private final Collection<DetailProvider<T>> providers = new ArrayList<>(); private final Collection<DetailProvider<? super T>> providers = new ArrayList<>();
private final DetailProvider<T> basic; private final DetailProvider<T> basic;
public DetailRegistryImpl(DetailProvider<T> basic) { public DetailRegistryImpl(DetailProvider<T> basic) {
@ -24,7 +24,7 @@ public class DetailRegistryImpl<T> implements DetailRegistry<T> {
} }
@Override @Override
public synchronized void addProvider(DetailProvider<T> provider) { public synchronized void addProvider(DetailProvider<? super T> provider) {
Objects.requireNonNull(provider, "provider cannot be null"); Objects.requireNonNull(provider, "provider cannot be null");
if (!providers.contains(provider)) providers.add(provider); if (!providers.contains(provider)) providers.add(provider);
} }