EntryRegistryImpl.java 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /*
  2. * Copyright (c) 2018, 2019, 2020 shedaniel
  3. * Licensed under the MIT License (the "License").
  4. */
  5. package me.shedaniel.rei.impl;
  6. import com.google.common.collect.Lists;
  7. import com.google.common.collect.Queues;
  8. import me.shedaniel.rei.api.ConfigObject;
  9. import me.shedaniel.rei.api.EntryRegistry;
  10. import me.shedaniel.rei.api.EntryStack;
  11. import me.shedaniel.rei.api.RecipeHelper;
  12. import net.minecraft.item.Item;
  13. import net.minecraft.item.ItemStack;
  14. import net.minecraft.util.DefaultedList;
  15. import net.minecraft.util.Pair;
  16. import org.jetbrains.annotations.ApiStatus;
  17. import org.jetbrains.annotations.Nullable;
  18. import java.util.*;
  19. import java.util.concurrent.CopyOnWriteArrayList;
  20. @ApiStatus.Internal
  21. public class EntryRegistryImpl implements EntryRegistry {
  22. private final CopyOnWriteArrayList<EntryStack> entries = Lists.newCopyOnWriteArrayList();
  23. private final Queue<Pair<EntryStack, Collection<? extends EntryStack>>> queueRegisterEntryStackAfter = Queues.newConcurrentLinkedQueue();
  24. private List<EntryStack> reloadList;
  25. private boolean doingDistinct = false;
  26. public void distinct() {
  27. doingDistinct = true;
  28. TreeSet<EntryStack> set = new TreeSet<>((i, j) -> i.equalsAll(j) ? 0 : 1);
  29. set.addAll(reloadList);
  30. entries.clear();
  31. entries.addAll(set);
  32. entries.removeIf(EntryStack::isEmpty);
  33. reloadList.clear();
  34. while (true) {
  35. Pair<EntryStack, Collection<? extends EntryStack>> pair = queueRegisterEntryStackAfter.poll();
  36. if (pair == null)
  37. break;
  38. registerEntriesAfter(pair.getLeft(), pair.getRight());
  39. }
  40. set.clear();
  41. set.addAll(entries);
  42. set.removeIf(EntryStack::isEmpty);
  43. entries.clear();
  44. entries.addAll(set);
  45. set.clear();
  46. for (EntryStack stack : ConfigObject.getInstance().getFilteredStacks()) {
  47. entries.remove(stack);
  48. }
  49. doingDistinct = false;
  50. }
  51. @Override
  52. public List<EntryStack> getStacksList() {
  53. return RecipeHelper.getInstance().arePluginsLoading() && !doingDistinct ? reloadList : entries;
  54. }
  55. public void reset() {
  56. doingDistinct = false;
  57. reloadList = Lists.newArrayList();
  58. queueRegisterEntryStackAfter.clear();
  59. entries.clear();
  60. reloadList.clear();
  61. }
  62. @Override
  63. public List<ItemStack> appendStacksForItem(Item item) {
  64. DefaultedList<ItemStack> list = new DefaultedLinkedList<>(Lists.newLinkedList(), null);
  65. item.appendStacks(item.getGroup(), list);
  66. if (list.isEmpty())
  67. list.add(item.getStackForRender());
  68. return list;
  69. }
  70. @Override
  71. public ItemStack[] getAllStacksFromItem(Item item) {
  72. List<ItemStack> list = appendStacksForItem(item);
  73. ItemStack[] array = list.toArray(new ItemStack[0]);
  74. Arrays.sort(array, (a, b) -> ItemStack.areEqualIgnoreDamage(a, b) ? 0 : 1);
  75. return array;
  76. }
  77. @Override
  78. @Deprecated
  79. @ApiStatus.Internal
  80. public void registerEntryAfter(EntryStack afterEntry, EntryStack stack, boolean checkAlreadyContains) {
  81. if (stack.isEmpty())
  82. return;
  83. if (afterEntry == null) {
  84. getStacksList().add(stack);
  85. } else {
  86. int last = getStacksList().size();
  87. for (int i = last - 1; i >= 0; i--)
  88. if (getStacksList().get(i).equalsAll(afterEntry)) {
  89. last = i + 1;
  90. break;
  91. }
  92. getStacksList().add(last, stack);
  93. }
  94. }
  95. @Override
  96. public void queueRegisterEntryAfter(EntryStack afterEntry, Collection<? extends EntryStack> stacks) {
  97. if (RecipeHelper.getInstance().arePluginsLoading()) {
  98. queueRegisterEntryStackAfter.add(new Pair<>(afterEntry, stacks));
  99. } else {
  100. registerEntriesAfter(afterEntry, stacks);
  101. }
  102. }
  103. @Override
  104. public void registerEntriesAfter(EntryStack afterStack, Collection<? extends EntryStack> stacks) {
  105. if (afterStack != null) {
  106. int index = getStacksList().size();
  107. for (int i = index - 1; i >= 0; i--) {
  108. if (getStacksList().get(i).equalsAll(afterStack)) {
  109. index = i + 1;
  110. break;
  111. }
  112. }
  113. getStacksList().addAll(index, stacks);
  114. } else
  115. getStacksList().addAll(stacks);
  116. }
  117. private static class DefaultedLinkedList<E> extends DefaultedList<E> {
  118. public DefaultedLinkedList(List<E> delegate, @Nullable E initialElement) {
  119. super(delegate, initialElement);
  120. }
  121. }
  122. }