89 lines
3.8 KiB
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;
|
|
}
|
|
}
|
|
}
|