RoughlyEnoughItemsState.java 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * This file is licensed under the MIT License, part of Roughly Enough Items.
  3. * Copyright (c) 2018, 2019, 2020 shedaniel
  4. *
  5. * Permission is hereby granted, free of charge, to any person obtaining a copy
  6. * of this software and associated documentation files (the "Software"), to deal
  7. * in the Software without restriction, including without limitation the rights
  8. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  9. * copies of the Software, and to permit persons to whom the Software is
  10. * furnished to do so, subject to the following conditions:
  11. *
  12. * The above copyright notice and this permission notice shall be included in all
  13. * copies or substantial portions of the Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  18. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  20. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  21. * SOFTWARE.
  22. */
  23. package me.shedaniel.rei;
  24. import net.fabricmc.api.EnvType;
  25. import net.fabricmc.loader.api.FabricLoader;
  26. import net.minecraft.util.Pair;
  27. import org.apache.logging.log4j.LogManager;
  28. import org.apache.logging.log4j.Logger;
  29. import org.jetbrains.annotations.ApiStatus;
  30. import java.util.ArrayList;
  31. import java.util.LinkedHashSet;
  32. import java.util.List;
  33. import java.util.Set;
  34. @ApiStatus.Internal
  35. public class RoughlyEnoughItemsState {
  36. private RoughlyEnoughItemsState() {}
  37. public static final Logger LOGGER = LogManager.getFormatterLogger("REI");
  38. private static List<Pair<String, String>> errors = new ArrayList<>();
  39. private static List<Pair<String, String>> warnings = new ArrayList<>();
  40. private static Set<String> errorSet = new LinkedHashSet<>();
  41. private static Set<String> warningSet = new LinkedHashSet<>();
  42. private static List<Runnable> continueCallbacks = new ArrayList<>();
  43. public static void error(String reason) {
  44. if (FabricLoader.getInstance().getEnvironmentType() == EnvType.SERVER || FabricLoader.getInstance().isDevelopmentEnvironment())
  45. throw new RuntimeException(reason);
  46. if (RoughlyEnoughItemsState.errorSet.add(reason + " " + null)) {
  47. RoughlyEnoughItemsState.errors.add(new Pair<>(reason, null));
  48. LOGGER.error(reason);
  49. }
  50. }
  51. public static void error(String reason, String link) {
  52. if (FabricLoader.getInstance().getEnvironmentType() == EnvType.SERVER || FabricLoader.getInstance().isDevelopmentEnvironment())
  53. throw new RuntimeException(reason + " " + link);
  54. if (RoughlyEnoughItemsState.errorSet.add(reason + " " + link)) {
  55. RoughlyEnoughItemsState.errors.add(new Pair<>(reason, link));
  56. LOGGER.error(reason + " " + link);
  57. }
  58. }
  59. public static void warn(String reason) {
  60. if (RoughlyEnoughItemsState.warningSet.add(reason + " " + null)) {
  61. RoughlyEnoughItemsState.warnings.add(new Pair<>(reason, null));
  62. LOGGER.warn(reason);
  63. }
  64. }
  65. public static void warn(String reason, String link) {
  66. if (RoughlyEnoughItemsState.warningSet.add(reason + " " + link)) {
  67. RoughlyEnoughItemsState.warnings.add(new Pair<>(reason, link));
  68. LOGGER.warn(reason + " " + link);
  69. }
  70. }
  71. public static void onContinue(Runnable runnable) {
  72. continueCallbacks.add(runnable);
  73. }
  74. public static List<Pair<String, String>> getErrors() {
  75. return errors;
  76. }
  77. public static List<Pair<String, String>> getWarnings() {
  78. return warnings;
  79. }
  80. public static void clear() {
  81. errors.clear();
  82. errorSet.clear();
  83. warnings.clear();
  84. warningSet.clear();
  85. }
  86. public static void continues() {
  87. for (Runnable callback : continueCallbacks) {
  88. try {
  89. callback.run();
  90. } catch (Throwable throwable) {
  91. throwable.printStackTrace();
  92. }
  93. }
  94. continueCallbacks.clear();
  95. }
  96. }