minecraft-src/net/minecraft/client/telemetry/TelemetryEventLog.java
2025-07-04 02:00:41 +03:00

39 lines
1.3 KiB
Java

package net.minecraft.client.telemetry;
import com.mojang.logging.LogUtils;
import java.io.IOException;
import java.nio.channels.FileChannel;
import java.util.concurrent.Executor;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.util.eventlog.JsonEventLog;
import net.minecraft.util.thread.ConsecutiveExecutor;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
@Environment(EnvType.CLIENT)
public class TelemetryEventLog implements AutoCloseable {
private static final Logger LOGGER = LogUtils.getLogger();
private final JsonEventLog<TelemetryEventInstance> log;
private final ConsecutiveExecutor consecutiveExecutor;
public TelemetryEventLog(FileChannel channel, Executor dispatcher) {
this.log = new JsonEventLog<>(TelemetryEventInstance.CODEC, channel);
this.consecutiveExecutor = new ConsecutiveExecutor(dispatcher, "telemetry-event-log");
}
public TelemetryEventLogger logger() {
return telemetryEventInstance -> this.consecutiveExecutor.schedule(() -> {
try {
this.log.write(telemetryEventInstance);
} catch (IOException var3) {
LOGGER.error("Failed to write telemetry event to log", (Throwable)var3);
}
});
}
public void close() {
this.consecutiveExecutor.schedule(() -> IOUtils.closeQuietly(this.log));
this.consecutiveExecutor.close();
}
}