hytale-server/com/hypixel/hytale/builtin/hytalegenerator/assets/positionproviders/PositionProviderAsset.java

89 lines
3.8 KiB
Java

package com.hypixel.hytale.builtin.hytalegenerator.assets.positionproviders;
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.positionproviders.PositionProvider;
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 PositionProviderAsset implements Cleanable, JsonAssetWithMap<String, DefaultAssetMap<String, PositionProviderAsset>> {
public static final AssetCodecMapCodec<String, PositionProviderAsset> 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, PositionProviderAsset> exportedNodes = new ConcurrentHashMap<>();
public static final Codec<String> CHILD_ASSET_CODEC = new ContainedAssetCodec<>(PositionProviderAsset.class, CODEC);
public static final Codec<String[]> CHILD_ASSET_CODEC_ARRAY = new ArrayCodec<>(CHILD_ASSET_CODEC, String[]::new);
public static final BuilderCodec<PositionProviderAsset> ABSTRACT_CODEC = BuilderCodec.abstractBuilder(PositionProviderAsset.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 PositionProviderAsset() {
}
public abstract PositionProvider build(@Nonnull PositionProviderAsset.Argument var1);
public boolean skip() {
return this.skip;
}
public static PositionProviderAsset 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 ReferenceBundle referenceBundle;
public WorkerIndexer workerIndexer;
public Argument(@Nonnull SeedBox parentSeed, @Nonnull ReferenceBundle referenceBundle, @Nonnull WorkerIndexer workerIndexer) {
this.parentSeed = parentSeed;
this.referenceBundle = referenceBundle;
this.workerIndexer = workerIndexer;
}
public Argument(@Nonnull PositionProviderAsset.Argument argument) {
this.parentSeed = argument.parentSeed;
this.referenceBundle = argument.referenceBundle;
this.workerIndexer = argument.workerIndexer;
}
}
}