39 lines
1.3 KiB
Java
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();
|
|
}
|
|
}
|