2025-11-24 22:52:51 +03:00

76 lines
2.0 KiB
Java

/*
* Decompiled with CFR 0.152.
*
* Could not load the following classes:
* com.google.common.collect.Lists
* com.mojang.logging.LogUtils
* org.jspecify.annotations.Nullable
* org.slf4j.Logger
*/
package net.minecraft.gametest.framework;
import com.google.common.collect.Lists;
import com.mojang.logging.LogUtils;
import java.util.Collection;
import net.minecraft.gametest.framework.GameTestInfo;
import net.minecraft.gametest.framework.GameTestRunner;
import net.minecraft.util.Util;
import org.jspecify.annotations.Nullable;
import org.slf4j.Logger;
public class GameTestTicker {
public static final GameTestTicker SINGLETON = new GameTestTicker();
private static final Logger LOGGER = LogUtils.getLogger();
private final Collection<GameTestInfo> testInfos = Lists.newCopyOnWriteArrayList();
private @Nullable GameTestRunner runner;
private State state = State.IDLE;
private GameTestTicker() {
}
public void add(GameTestInfo testInfo) {
this.testInfos.add(testInfo);
}
public void clear() {
if (this.state != State.IDLE) {
this.state = State.HALTING;
return;
}
this.testInfos.clear();
if (this.runner != null) {
this.runner.stop();
this.runner = null;
}
}
public void setRunner(GameTestRunner runner) {
if (this.runner != null) {
Util.logAndPauseIfInIde("The runner was already set in GameTestTicker");
}
this.runner = runner;
}
public void tick() {
if (this.runner == null) {
return;
}
this.state = State.RUNNING;
this.testInfos.forEach(i -> i.tick(this.runner));
this.testInfos.removeIf(GameTestInfo::isDone);
State finishingState = this.state;
this.state = State.IDLE;
if (finishingState == State.HALTING) {
this.clear();
}
}
private static enum State {
IDLE,
RUNNING,
HALTING;
}
}