hytale-server/com/hypixel/hytale/builtin/hytalegenerator/assets/propassignments/AssignmentsAsset.java

102 lines
4.2 KiB
Java

package com.hypixel.hytale.builtin.hytalegenerator.assets.propassignments;
import com.hypixel.hytale.assetstore.AssetExtraInfo;
import com.hypixel.hytale.assetstore.codec.AssetCodecMapCodec;
import com.hypixel.hytale.assetstore.codec.ContainedAssetCodec;
import com.hypixel.hytale.assetstore.map.DefaultAssetMap;
import com.hypixel.hytale.assetstore.map.JsonAssetWithMap;
import com.hypixel.hytale.builtin.hytalegenerator.LoggerUtil;
import com.hypixel.hytale.builtin.hytalegenerator.assets.Cleanable;
import com.hypixel.hytale.builtin.hytalegenerator.material.MaterialCache;
import com.hypixel.hytale.builtin.hytalegenerator.propdistributions.Assignments;
import com.hypixel.hytale.builtin.hytalegenerator.referencebundle.ReferenceBundle;
import com.hypixel.hytale.builtin.hytalegenerator.seed.SeedBox;
import com.hypixel.hytale.builtin.hytalegenerator.threadindexer.WorkerIndexer;
import com.hypixel.hytale.codec.Codec;
import com.hypixel.hytale.codec.KeyedCodec;
import com.hypixel.hytale.codec.builder.BuilderCodec;
import com.hypixel.hytale.codec.codecs.array.ArrayCodec;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import javax.annotation.Nonnull;
public abstract class AssignmentsAsset implements Cleanable, JsonAssetWithMap<String, DefaultAssetMap<String, AssignmentsAsset>> {
public static final AssetCodecMapCodec<String, AssignmentsAsset> CODEC = new AssetCodecMapCodec<>(
Codec.STRING, (t, k) -> t.id = k, t -> t.id, (t, data) -> t.data = data, t -> t.data
);
private static final Map<String, AssignmentsAsset> exportedNodes = new ConcurrentHashMap<>();
public static final Codec<String> CHILD_ASSET_CODEC = new ContainedAssetCodec<>(AssignmentsAsset.class, CODEC);
public static final Codec<String[]> CHILD_ASSET_CODEC_ARRAY = new ArrayCodec<>(CHILD_ASSET_CODEC, String[]::new);
public static final BuilderCodec<AssignmentsAsset> ABSTRACT_CODEC = BuilderCodec.abstractBuilder(AssignmentsAsset.class)
.append(new KeyedCodec<>("Skip", Codec.BOOLEAN, false), (t, k) -> t.skip = k, t -> t.skip)
.add()
.append(new KeyedCodec<>("ExportAs", Codec.STRING, false), (t, k) -> t.exportName = k, t -> t.exportName)
.add()
.afterDecode(asset -> {
if (asset.exportName != null && !asset.exportName.isEmpty()) {
if (exportedNodes.containsKey(asset.exportName)) {
LoggerUtil.getLogger().warning("Duplicate export name for asset: " + asset.exportName);
}
exportedNodes.put(asset.exportName, asset);
LoggerUtil.getLogger().fine("Registered imported position provider asset with name '" + asset.exportName + "' with asset id '" + asset.id);
}
})
.build();
private String id;
private AssetExtraInfo.Data data;
private boolean skip = false;
private String exportName = "";
protected AssignmentsAsset() {
}
public abstract Assignments build(@Nonnull AssignmentsAsset.Argument var1);
public boolean skip() {
return this.skip;
}
public static AssignmentsAsset getExportedAsset(@Nonnull String name) {
return exportedNodes.get(name);
}
public String getId() {
return this.id;
}
@Override
public void cleanUp() {
}
public static class Argument {
public SeedBox parentSeed;
public MaterialCache materialCache;
public ReferenceBundle referenceBundle;
public int runtime;
public WorkerIndexer workerIndexer;
public Argument(
@Nonnull SeedBox parentSeed,
@Nonnull MaterialCache materialCache,
@Nonnull ReferenceBundle referenceBundle,
int runtime,
@Nonnull WorkerIndexer workerIndexer
) {
this.parentSeed = parentSeed;
this.materialCache = materialCache;
this.referenceBundle = referenceBundle;
this.runtime = runtime;
this.workerIndexer = workerIndexer;
}
public Argument(@Nonnull AssignmentsAsset.Argument argument) {
this.parentSeed = argument.parentSeed;
this.materialCache = argument.materialCache;
this.referenceBundle = argument.referenceBundle;
this.runtime = argument.runtime;
this.workerIndexer = argument.workerIndexer;
}
}
}