More dungeon features
- Set dungeon weights - Implement warp door - Enable monoliths in dungeons - Set correct author on schematics (from file name) - Make grass in pockets less dark - Fix lighting bug
This commit is contained in:
parent
8fbd238fae
commit
b7095dcec4
22 changed files with 586 additions and 656 deletions
|
@ -30,7 +30,7 @@ public class Schematic {
|
||||||
|
|
||||||
public int version = 1;
|
public int version = 1;
|
||||||
public String author = null;
|
public String author = null;
|
||||||
public String name = "Unknown";
|
public String name = null;
|
||||||
public long creationDate;
|
public long creationDate;
|
||||||
public String[] requiredMods = {};
|
public String[] requiredMods = {};
|
||||||
public short width;
|
public short width;
|
||||||
|
@ -43,7 +43,7 @@ public class Schematic {
|
||||||
public List<NBTTagCompound> tileEntities = new ArrayList<>();
|
public List<NBTTagCompound> tileEntities = new ArrayList<>();
|
||||||
public List<NBTTagCompound> entities = new ArrayList<>(); // Not in the specification, but we need this
|
public List<NBTTagCompound> entities = new ArrayList<>(); // Not in the specification, but we need this
|
||||||
|
|
||||||
public static Schematic loadFromNBT(NBTTagCompound nbt, String name) {
|
public static Schematic loadFromNBT(NBTTagCompound nbt) {
|
||||||
Schematic schematic = new Schematic();
|
Schematic schematic = new Schematic();
|
||||||
schematic.version = nbt.getInteger("Version"); //Version is required
|
schematic.version = nbt.getInteger("Version"); //Version is required
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ public class Schematic {
|
||||||
schematic.author = metadataCompound.getString("Author");
|
schematic.author = metadataCompound.getString("Author");
|
||||||
}
|
}
|
||||||
//Name is not required (may be null)
|
//Name is not required (may be null)
|
||||||
schematic.name = (name == null || name.equals("")) && nbt.hasKey("Name") ? metadataCompound.getString("Name") : name;
|
schematic.name = metadataCompound.getString("Name");
|
||||||
|
|
||||||
if (nbt.hasKey("Date")) { //Date is not required
|
if (nbt.hasKey("Date")) { //Date is not required
|
||||||
schematic.creationDate = metadataCompound.getLong("Date");
|
schematic.creationDate = metadataCompound.getLong("Date");
|
||||||
|
@ -131,8 +131,8 @@ public class Schematic {
|
||||||
if (nbt.hasKey("Entities")) { //Entities is not required
|
if (nbt.hasKey("Entities")) { //Entities is not required
|
||||||
NBTTagList entitiesTagList = (NBTTagList) nbt.getTag("Entities");
|
NBTTagList entitiesTagList = (NBTTagList) nbt.getTag("Entities");
|
||||||
for (int i = 0; i < entitiesTagList.tagCount(); i++) {
|
for (int i = 0; i < entitiesTagList.tagCount(); i++) {
|
||||||
NBTTagCompound tileEntityTagCompound = entitiesTagList.getCompoundTagAt(i);
|
NBTTagCompound entityTagCompound = entitiesTagList.getCompoundTagAt(i);
|
||||||
schematic.tileEntities.add(tileEntityTagCompound);
|
schematic.entities.add(entityTagCompound);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -279,6 +279,7 @@ public class Schematic {
|
||||||
// Relight changed chunks
|
// Relight changed chunks
|
||||||
for (Chunk chunk : changedChunks) {
|
for (Chunk chunk : changedChunks) {
|
||||||
chunk.setLightPopulated(false);
|
chunk.setLightPopulated(false);
|
||||||
|
chunk.setTerrainPopulated(true);
|
||||||
chunk.resetRelightChecks();
|
chunk.resetRelightChecks();
|
||||||
chunk.checkLight();
|
chunk.checkLight();
|
||||||
}
|
}
|
||||||
|
@ -310,17 +311,19 @@ public class Schematic {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set Entity data
|
// Spawn entities
|
||||||
for (NBTTagCompound entityNBT : schematic.entities) {
|
for (NBTTagCompound entityNBT : schematic.entities) {
|
||||||
|
// Correct the position and UUID
|
||||||
NBTTagList posNBT = (NBTTagList) entityNBT.getTag("Pos");
|
NBTTagList posNBT = (NBTTagList) entityNBT.getTag("Pos");
|
||||||
NBTTagList newPosNBT = new NBTTagList();
|
NBTTagList newPosNBT = new NBTTagList();
|
||||||
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(0) + xBase));
|
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(0) + xBase));
|
||||||
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(1) + yBase));
|
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(1) + yBase));
|
||||||
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(2) + zBase));
|
newPosNBT.appendTag(new NBTTagDouble(posNBT.getDoubleAt(2) + zBase));
|
||||||
entityNBT.setTag("Pos", newPosNBT);
|
NBTTagCompound adjustedEntityNBT = entityNBT.copy();
|
||||||
entityNBT.setUniqueId("UUID", UUID.randomUUID());
|
adjustedEntityNBT.setTag("Pos", newPosNBT);
|
||||||
|
adjustedEntityNBT.setUniqueId("UUID", UUID.randomUUID());
|
||||||
|
|
||||||
Entity entity = EntityList.createEntityFromNBT(entityNBT, world);
|
Entity entity = EntityList.createEntityFromNBT(adjustedEntityNBT, world);
|
||||||
world.spawnEntity(entity);
|
world.spawnEntity(entity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,12 @@ public class DimDoors {
|
||||||
if (/* TODO: config option && */ entity instanceof EntityPlayerMP) {
|
if (/* TODO: config option && */ entity instanceof EntityPlayerMP) {
|
||||||
EntityPlayerMP player = (EntityPlayerMP) entity;
|
EntityPlayerMP player = (EntityPlayerMP) entity;
|
||||||
player.sendStatusMessage(new TextComponentString(text), true);
|
player.sendStatusMessage(new TextComponentString(text), true);
|
||||||
} else
|
} else {
|
||||||
entity.sendMessage(new TextComponentString("[DimDoors] " + text));
|
chat(entity, text);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void chat(Entity entity, String text) {
|
||||||
|
entity.sendMessage(new TextComponentString("[DimDoors] " + text));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
|
||||||
IBlockState doorState = world.getBlockState(state.getValue(HALF) == EnumDoorHalf.UPPER ? pos.down() : pos); // .down() because only the bottom block has open=true
|
IBlockState doorState = world.getBlockState(state.getValue(HALF) == EnumDoorHalf.UPPER ? pos.down() : pos); // .down() because only the bottom block has open=true
|
||||||
|
|
||||||
// Check that it's a door and that the entity portal timer is 0
|
// Check that it's a door and that the entity portal timer is 0
|
||||||
if (doorState.getValue(BlockDoor.OPEN) && entity.timeUntilPortal == 0) {
|
if (doorState.getBlock().equals(this) && doorState.getValue(BlockDoor.OPEN) && entity.timeUntilPortal == 0) {
|
||||||
entity.timeUntilPortal = 50; // Disable another teleport for that entity for 2.5s
|
entity.timeUntilPortal = 50; // Disable another teleport for that entity for 2.5s
|
||||||
TileEntityEntranceRift rift = getRift(world, pos, state);
|
TileEntityEntranceRift rift = getRift(world, pos, state);
|
||||||
boolean successful = rift.teleport(entity);
|
boolean successful = rift.teleport(entity);
|
||||||
|
@ -99,7 +99,7 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
|
||||||
return (state.isSideSolid(world, pos, EnumFacing.UP)
|
return (state.isSideSolid(world, pos, EnumFacing.UP)
|
||||||
|| state.getBlockFaceShape(world, pos.down(), EnumFacing.UP) == BlockFaceShape.SOLID)
|
|| state.getBlockFaceShape(world, pos.down(), EnumFacing.UP) == BlockFaceShape.SOLID)
|
||||||
&& (world.getBlockState(pos).getBlock().isReplaceable(world, pos) || world.getBlockState(pos).getBlock().equals(ModBlocks.RIFT))
|
&& (world.getBlockState(pos).getBlock().isReplaceable(world, pos) || world.getBlockState(pos).getBlock().equals(ModBlocks.RIFT))
|
||||||
&& world.getBlockState(pos).getBlock().isReplaceable(world, pos.up());
|
&& world.getBlockState(pos.up()).getBlock().isReplaceable(world, pos.up());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return super.canPlaceBlockAt(world, pos);
|
return super.canPlaceBlockAt(world, pos);
|
||||||
|
@ -135,7 +135,6 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
|
||||||
TileEntityFloatingRift newRift = (TileEntityFloatingRift) world.getTileEntity(pos);
|
TileEntityFloatingRift newRift = (TileEntityFloatingRift) world.getTileEntity(pos);
|
||||||
newRift.copyFrom(rift);
|
newRift.copyFrom(rift);
|
||||||
newRift.updateType();
|
newRift.updateType();
|
||||||
//world.notifyBlockUpdate(rift.getPos(), state, world.getBlockState(pos), 0); // TODO: does this work?
|
|
||||||
} else {
|
} else {
|
||||||
rift.unregister();
|
rift.unregister();
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import org.dimdev.dimdoors.shared.rifts.destinations.PocketEntranceDestination;
|
|
||||||
|
|
||||||
public class BlockDimensionalDoorTransient extends BlockDimensionalDoor { // TODO: convert to a more general entrances block (like nether portals)
|
public class BlockDimensionalDoorTransient extends BlockDimensionalDoor { // TODO: convert to a more general entrances block (like nether portals)
|
||||||
|
|
||||||
|
@ -35,15 +34,12 @@ public class BlockDimensionalDoorTransient extends BlockDimensionalDoor { // TOD
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AxisAlignedBB getBoundingBox(IBlockState state, IBlockAccess source, BlockPos pos) {
|
public AxisAlignedBB getBoundingBox(IBlockState state, IBlockAccess source, BlockPos pos) {
|
||||||
return new AxisAlignedBB(0,0,0,0,0,0); //patches entities trying to pathfind through this block, however makes them spin like crazy if they end up in this block.
|
// Patches entities trying to pathfind through this block, however makes them spin like crazy if they end up in this block.
|
||||||
//NULL_AABB, the same as BlockAir, or straight up null seem to crash the server.
|
return new AxisAlignedBB(0, 0, 0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setupRift(TileEntityEntranceRift rift) {
|
public void setupRift(TileEntityEntranceRift rift) {}
|
||||||
// TODO
|
|
||||||
PocketEntranceDestination destination = PocketEntranceDestination.builder().build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canBePlacedOnRift() {
|
public boolean canBePlacedOnRift() {
|
||||||
|
|
|
@ -1,14 +1,16 @@
|
||||||
package org.dimdev.dimdoors.shared.blocks;
|
package org.dimdev.dimdoors.shared.blocks;
|
||||||
|
|
||||||
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.init.Blocks;
|
import net.minecraft.init.Blocks;
|
||||||
import org.dimdev.dimdoors.DimDoors;
|
|
||||||
import org.dimdev.dimdoors.shared.items.ModItems;
|
|
||||||
import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift;
|
|
||||||
import net.minecraft.block.material.Material;
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
import org.dimdev.dimdoors.DimDoors;
|
||||||
|
import org.dimdev.dimdoors.shared.items.ModItems;
|
||||||
|
import org.dimdev.dimdoors.shared.rifts.destinations.AvailableLinkDestination;
|
||||||
|
import org.dimdev.dimdoors.shared.tileentities.TileEntityEntranceRift;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
public class BlockDimensionalDoorWood extends BlockDimensionalDoor {
|
public class BlockDimensionalDoorWood extends BlockDimensionalDoor {
|
||||||
|
@ -34,7 +36,13 @@ public class BlockDimensionalDoorWood extends BlockDimensionalDoor {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setupRift(TileEntityEntranceRift rift) {
|
public void setupRift(TileEntityEntranceRift rift) {
|
||||||
// TODO
|
rift.setDestination(AvailableLinkDestination.builder()
|
||||||
|
.acceptedGroups(Collections.singleton(0))
|
||||||
|
.coordFactor(1)
|
||||||
|
.negativeDepthFactor(80)
|
||||||
|
.positiveDepthFactor(Double.MAX_VALUE)
|
||||||
|
.weightMaximum(100)
|
||||||
|
.noLink(false).newRiftWeight(1).build());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -73,16 +73,16 @@ public class CommandPocket extends CommandBase {
|
||||||
EntityPlayerMP player = getCommandSenderAsPlayer(sender);
|
EntityPlayerMP player = getCommandSenderAsPlayer(sender);
|
||||||
// Make sure the player is in a pocket world
|
// Make sure the player is in a pocket world
|
||||||
if (!ModDimensions.isDimDoorsPocketDimension(player.world)) {
|
if (!ModDimensions.isDimDoorsPocketDimension(player.world)) {
|
||||||
DimDoors.sendMessage(player, "You must be in a pocket dimension to use this command!");
|
DimDoors.chat(player, "You must be in a pocket dimension to use this command!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if the schematic exists
|
// Check if the schematic exists
|
||||||
if (!SchematicHandler.INSTANCE.getTemplateGroups().contains(group)) {
|
if (!SchematicHandler.INSTANCE.getTemplateGroups().contains(group)) {
|
||||||
DimDoors.sendMessage(player, "Group " + group + " not found");
|
DimDoors.chat(player, "Group " + group + " not found");
|
||||||
return;
|
return;
|
||||||
} else if (!SchematicHandler.INSTANCE.getTemplateNames(group).contains(name)) {
|
} else if (!SchematicHandler.INSTANCE.getTemplateNames(group).contains(name)) {
|
||||||
DimDoors.sendMessage(player, "Schematic " + name + " not found in group " + group);
|
DimDoors.chat(player, "Schematic " + name + " not found in group " + group);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ import java.util.Random;
|
||||||
public final class PocketGenerator {
|
public final class PocketGenerator {
|
||||||
|
|
||||||
public static Pocket generatePocketFromTemplate(int dim, PocketTemplate pocketTemplate, VirtualLocation virtualLocation) {
|
public static Pocket generatePocketFromTemplate(int dim, PocketTemplate pocketTemplate, VirtualLocation virtualLocation) {
|
||||||
DimDoors.log.info("Generating pocket from template " + pocketTemplate.getName() + " at virtual location " + virtualLocation);
|
DimDoors.log.info("Generating pocket from template " + pocketTemplate.getId() + " at virtual location " + virtualLocation);
|
||||||
|
|
||||||
PocketRegistry registry = PocketRegistry.instance(dim);
|
PocketRegistry registry = PocketRegistry.instance(dim);
|
||||||
Pocket pocket = registry.newPocket();
|
Pocket pocket = registry.newPocket();
|
||||||
|
@ -23,6 +23,7 @@ public final class PocketGenerator {
|
||||||
return generatePocketFromTemplate(ModDimensions.getPrivateDim(), pocketTemplate, virtualLocation);
|
return generatePocketFromTemplate(ModDimensions.getPrivateDim(), pocketTemplate, virtualLocation);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: size of public pocket should increase with depth
|
||||||
public static Pocket generatePublicPocket(VirtualLocation virtualLocation) {
|
public static Pocket generatePublicPocket(VirtualLocation virtualLocation) {
|
||||||
PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getPublicPocketTemplate();
|
PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getPublicPocketTemplate();
|
||||||
return generatePocketFromTemplate(ModDimensions.getPublicDim(), pocketTemplate, virtualLocation);
|
return generatePocketFromTemplate(ModDimensions.getPublicDim(), pocketTemplate, virtualLocation);
|
||||||
|
@ -36,7 +37,7 @@ public final class PocketGenerator {
|
||||||
*/
|
*/
|
||||||
public static Pocket generateDungeonPocket(VirtualLocation virtualLocation) {
|
public static Pocket generateDungeonPocket(VirtualLocation virtualLocation) {
|
||||||
int depth = virtualLocation.getDepth();
|
int depth = virtualLocation.getDepth();
|
||||||
float netherProbability = virtualLocation.getDim() == -1 ? 1 : (float) depth / 50; // TODO: improve nether probability
|
float netherProbability = virtualLocation.getDim() == -1 ? 1 : (float) depth / 200; // TODO: improve nether probability
|
||||||
Random random = new Random();
|
Random random = new Random();
|
||||||
String group = random.nextFloat() < netherProbability ? "nether" : "ruins";
|
String group = random.nextFloat() < netherProbability ? "nether" : "ruins";
|
||||||
PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getRandomTemplate(group, depth, Config.getMaxPocketSize(), false);
|
PocketTemplate pocketTemplate = SchematicHandler.INSTANCE.getRandomTemplate(group, depth, Config.getMaxPocketSize(), false);
|
||||||
|
|
|
@ -19,26 +19,25 @@ import net.minecraft.world.WorldServer;
|
||||||
/**
|
/**
|
||||||
* @author Robijnvogel
|
* @author Robijnvogel
|
||||||
*/
|
*/
|
||||||
@AllArgsConstructor @RequiredArgsConstructor// TODO: use @Builder?
|
@AllArgsConstructor @RequiredArgsConstructor
|
||||||
public class PocketTemplate {
|
public class PocketTemplate {
|
||||||
|
|
||||||
@Getter private final String groupName;
|
@Getter private final String group;
|
||||||
|
@Getter private final String id;
|
||||||
|
@Getter private final String type;
|
||||||
@Getter private final String name;
|
@Getter private final String name;
|
||||||
|
@Getter private final String author;
|
||||||
@Getter @Setter private Schematic schematic;
|
@Getter @Setter private Schematic schematic;
|
||||||
@Getter private final int size; // size in chunks (n*n chunks)
|
@Getter private final int size; // size in chunks (n*n chunks)
|
||||||
@Getter private final int minDepth;
|
|
||||||
@Getter private final int maxDepth;
|
|
||||||
@Getter private final int baseWeight;
|
@Getter private final int baseWeight;
|
||||||
//private final float[] weights; // weight per-level
|
|
||||||
|
|
||||||
public float getWeight(int depth) {
|
public float getWeight(int depth) {
|
||||||
/*if (depth < 0) return 100; // TODO: get rid of this line later
|
//noinspection IfStatementWithIdenticalBranches
|
||||||
if (maxDepth - minDepth + 1 != weights.length) throw new IllegalStateException("This PocketTemplate wasn't set up correctly!");
|
if (depth == -1) {
|
||||||
if (depth < minDepth) return 0;
|
return baseWeight;
|
||||||
if (depth > maxDepth) return weights[weights.length - 1];
|
} else {
|
||||||
return weights[depth - minDepth];*/
|
return baseWeight; // TODO: make this actually dependend on the depth
|
||||||
return baseWeight;
|
}
|
||||||
// TODO: make this actually dependend on the depth
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void place(Pocket pocket) {
|
public void place(Pocket pocket) {
|
||||||
|
|
|
@ -31,14 +31,13 @@ import org.dimdev.dimdoors.shared.world.ModDimensions;
|
||||||
/**
|
/**
|
||||||
* @author Robijnvogel
|
* @author Robijnvogel
|
||||||
*/
|
*/
|
||||||
public class SchematicHandler { // TODO: make this more general (not dimdoors-related)
|
public class SchematicHandler {
|
||||||
|
|
||||||
public static final SchematicHandler INSTANCE = new SchematicHandler(); // TODO: make static
|
public static final SchematicHandler INSTANCE = new SchematicHandler(); // TODO: make static
|
||||||
|
|
||||||
private List<PocketTemplate> templates;
|
private List<PocketTemplate> templates;
|
||||||
private Map<String, Map<String, Integer>> nameMap; // group -> name -> index in templates
|
private Map<String, Map<String, Integer>> nameMap; // group -> name -> index in templates
|
||||||
|
|
||||||
// LOADING CODE STARTS HERE <editor-fold>
|
|
||||||
public void loadSchematics() {
|
public void loadSchematics() {
|
||||||
templates = new ArrayList<>();
|
templates = new ArrayList<>();
|
||||||
|
|
||||||
|
@ -91,7 +90,7 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
String subDirectory = jsonTemplate.get("group").getAsString(); //get the subfolder in which the schematics are stored
|
String subDirectory = jsonTemplate.get("group").getAsString(); //get the subfolder in which the schematics are stored
|
||||||
|
|
||||||
for (PocketTemplate template : validTemplates) { //it's okay to "tap" this for-loop, even if validTemplates is empty.
|
for (PocketTemplate template : validTemplates) { //it's okay to "tap" this for-loop, even if validTemplates is empty.
|
||||||
String extendedTemplatelocation = subDirectory.equals("") ? template.getName() : subDirectory + "/" + template.getName(); //transform the filename accordingly
|
String extendedTemplatelocation = subDirectory.equals("") ? template.getId() : subDirectory + "/" + template.getId(); //transform the filename accordingly
|
||||||
|
|
||||||
//Initialising the possible locations/formats for the schematic file
|
//Initialising the possible locations/formats for the schematic file
|
||||||
InputStream schematicStream = DimDoors.class.getResourceAsStream(schematicJarDirectory + extendedTemplatelocation + ".schem");
|
InputStream schematicStream = DimDoors.class.getResourceAsStream(schematicJarDirectory + extendedTemplatelocation + ".schem");
|
||||||
|
@ -113,17 +112,17 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
schematicDataStream = new DataInputStream(new FileInputStream(schematicFile));
|
schematicDataStream = new DataInputStream(new FileInputStream(schematicFile));
|
||||||
streamOpened = true;
|
streamOpened = true;
|
||||||
} catch (FileNotFoundException ex) {
|
} catch (FileNotFoundException ex) {
|
||||||
DimDoors.log.error("Schematic file " + template.getName() + ".schem did not load correctly from config folder.", ex);
|
DimDoors.log.error("Schematic file " + template.getId() + ".schem did not load correctly from config folder.", ex);
|
||||||
}
|
}
|
||||||
} else if (oldVersionSchematicFile.exists()) {
|
} else if (oldVersionSchematicFile.exists()) {
|
||||||
try {
|
try {
|
||||||
schematicDataStream = new DataInputStream(new FileInputStream(oldVersionSchematicFile));
|
schematicDataStream = new DataInputStream(new FileInputStream(oldVersionSchematicFile));
|
||||||
streamOpened = true;
|
streamOpened = true;
|
||||||
} catch (FileNotFoundException ex) {
|
} catch (FileNotFoundException ex) {
|
||||||
DimDoors.log.error("Schematic file " + template.getName() + ".schematic did not load correctly from config folder.", ex);
|
DimDoors.log.error("Schematic file " + template.getId() + ".schematic did not load correctly from config folder.", ex);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
DimDoors.log.warn("Schematic '" + template.getName() + "' was not found in the jar or config directory, neither with the .schem extension, nor with the .schematic extension.");
|
DimDoors.log.warn("Schematic '" + template.getId() + "' was not found in the jar or config directory, neither with the .schem extension, nor with the .schematic extension.");
|
||||||
}
|
}
|
||||||
|
|
||||||
NBTTagCompound schematicNBT;
|
NBTTagCompound schematicNBT;
|
||||||
|
@ -132,13 +131,13 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
try {
|
try {
|
||||||
schematicNBT = CompressedStreamTools.readCompressed(schematicDataStream);
|
schematicNBT = CompressedStreamTools.readCompressed(schematicDataStream);
|
||||||
if (!schematicNBT.hasKey("Version")) {
|
if (!schematicNBT.hasKey("Version")) {
|
||||||
schematic = SchematicConverter.convertSchematic(schematicNBT, template.getName());
|
schematic = SchematicConverter.convertSchematic(schematicNBT, template.getName(), template.getAuthor());
|
||||||
} else {
|
} else {
|
||||||
schematic = Schematic.loadFromNBT(schematicNBT, template.getName());
|
schematic = Schematic.loadFromNBT(schematicNBT);
|
||||||
}
|
}
|
||||||
schematicDataStream.close();
|
schematicDataStream.close();
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
Logger.getLogger(SchematicHandler.class.getName()).log(Level.SEVERE, "Schematic file for " + template.getName() + " could not be read as a valid schematic NBT file.", ex); // TODO: consistently use one type of logger for this.
|
Logger.getLogger(SchematicHandler.class.getName()).log(Level.SEVERE, "Schematic file for " + template.getId() + " could not be read as a valid schematic NBT file.", ex); // TODO: consistently use one type of logger for this.
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
schematicDataStream.close();
|
schematicDataStream.close();
|
||||||
|
@ -151,10 +150,9 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
if (schematic != null
|
if (schematic != null
|
||||||
&& (schematic.width > (template.getSize() + 1) * 16 || schematic.length > (template.getSize() + 1) * 16)) {
|
&& (schematic.width > (template.getSize() + 1) * 16 || schematic.length > (template.getSize() + 1) * 16)) {
|
||||||
schematic = null;
|
schematic = null;
|
||||||
DimDoors.log.warn("Schematic " + template.getName() + " was bigger than specified in its json file and therefore wasn't loaded");
|
DimDoors.log.warn("Schematic " + template.getId() + " was bigger than specified in its json file and therefore wasn't loaded");
|
||||||
}
|
}
|
||||||
template.setSchematic(schematic);
|
template.setSchematic(schematic);
|
||||||
// TODO: delete from validTemplates if schematic is null
|
|
||||||
}
|
}
|
||||||
return validTemplates;
|
return validTemplates;
|
||||||
}
|
}
|
||||||
|
@ -162,37 +160,21 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
private static List<PocketTemplate> getAllValidVariations(JsonObject jsonTemplate) {
|
private static List<PocketTemplate> getAllValidVariations(JsonObject jsonTemplate) {
|
||||||
List<PocketTemplate> pocketTemplates = new ArrayList<>();
|
List<PocketTemplate> pocketTemplates = new ArrayList<>();
|
||||||
|
|
||||||
final String directory = jsonTemplate.get("group").getAsString();
|
final String group = jsonTemplate.get("group").getAsString();
|
||||||
int maxSize = -1;
|
|
||||||
if (!Config.isLoadAllSchematics()) {
|
|
||||||
switch (directory) {
|
|
||||||
case "public":
|
|
||||||
maxSize = Config.getPublicPocketSize(); // TODO: hardcode?¿
|
|
||||||
break;
|
|
||||||
case "private":
|
|
||||||
maxSize = Config.getPrivatePocketSize();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
maxSize = Config.getMaxPocketSize();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
final JsonArray variations = jsonTemplate.getAsJsonArray("variations");
|
final JsonArray pockets = jsonTemplate.getAsJsonArray("pockets");
|
||||||
|
|
||||||
//convert the variations arraylist to a list of pocket templates
|
//convert the variations arraylist to a list of pocket templates
|
||||||
for (JsonElement variationElement : variations) {
|
for (JsonElement pocketElement : pockets) {
|
||||||
JsonObject variation = variationElement.getAsJsonObject();
|
JsonObject pocket = pocketElement.getAsJsonObject();
|
||||||
String variantName = variation.get("variantName").getAsString();
|
String id = pocket.get("id").getAsString();
|
||||||
int variationSize = variation.get("size").getAsInt();
|
String type = pocket.has("type") ? pocket.get("type").getAsString() : null;
|
||||||
if (maxSize >= 0 && variationSize > maxSize) {
|
String name = pocket.has("name") ? pocket.get("name").getAsString() : null;
|
||||||
continue;
|
String author = pocket.has("author") ? pocket.get("author").getAsString() : null;
|
||||||
}
|
int size = pocket.get("size").getAsInt();
|
||||||
int minDepth = variation.get("minDepth").getAsInt();
|
if (Config.isLoadAllSchematics() && size > Config.getMaxPocketSize()) continue;
|
||||||
int maxDepth = variation.get("maxDepth").getAsInt();
|
int baseWeight = pocket.has("baseWeight") ? pocket.get("baseWeight").getAsInt() : 100;
|
||||||
int baseWeight = variation.get("baseWeight").getAsInt();
|
pocketTemplates.add(new PocketTemplate(group, id, type, name, author, size, baseWeight));
|
||||||
PocketTemplate pocketTemplate = new PocketTemplate(directory, variantName, variationSize, minDepth, maxDepth, baseWeight);
|
|
||||||
pocketTemplates.add(pocketTemplate);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return pocketTemplates;
|
return pocketTemplates;
|
||||||
|
@ -205,24 +187,23 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
Map<String, Integer> bufferedMap = null;
|
Map<String, Integer> bufferedMap = null;
|
||||||
|
|
||||||
for (PocketTemplate template : templates) {
|
for (PocketTemplate template : templates) {
|
||||||
String dirName = template.getGroupName();
|
String dirName = template.getGroup();
|
||||||
if (dirName != null && dirName.equals(bufferedDirectory)) { //null check not needed
|
if (dirName != null && dirName.equals(bufferedDirectory)) { //null check not needed
|
||||||
bufferedMap.put(template.getName(), templates.indexOf(template));
|
bufferedMap.put(template.getId(), templates.indexOf(template));
|
||||||
} else {
|
} else {
|
||||||
bufferedDirectory = dirName;
|
bufferedDirectory = dirName;
|
||||||
if (nameMap.containsKey(dirName)) { //this will only happen if you have two json files referring to the same directory being loaded non-consecutively
|
if (nameMap.containsKey(dirName)) { //this will only happen if you have two json files referring to the same directory being loaded non-consecutively
|
||||||
bufferedMap = nameMap.get(dirName);
|
bufferedMap = nameMap.get(dirName);
|
||||||
bufferedMap.put(template.getName(), templates.indexOf(template));
|
bufferedMap.put(template.getId(), templates.indexOf(template));
|
||||||
} else {
|
} else {
|
||||||
bufferedMap = new HashMap<>();
|
bufferedMap = new HashMap<>();
|
||||||
bufferedMap.put(template.getName(), templates.indexOf(template));
|
bufferedMap.put(template.getId(), templates.indexOf(template));
|
||||||
nameMap.put(dirName, bufferedMap);
|
nameMap.put(dirName, bufferedMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// LOADING CODE ENDS HERE </editor-fold>
|
|
||||||
public Set<String> getTemplateGroups() {
|
public Set<String> getTemplateGroups() {
|
||||||
return nameMap.keySet();
|
return nameMap.keySet();
|
||||||
}
|
}
|
||||||
|
@ -257,29 +238,18 @@ public class SchematicHandler { // TODO: make this more general (not dimdoors-re
|
||||||
/**
|
/**
|
||||||
* Gets a random template matching certain criteria.
|
* Gets a random template matching certain criteria.
|
||||||
*
|
*
|
||||||
* @return A random template matching those criteria, or null if none were found
|
* @param group The template group to choose from.
|
||||||
*/
|
|
||||||
public PocketTemplate getRandomTemplate(Map<String, Float> groupWeights, int depth, int maxSize, boolean getLargest) { // TODO: useful?
|
|
||||||
String group = MathUtils.weightedRandom(groupWeights);
|
|
||||||
return getRandomTemplate(group, depth, maxSize, getLargest);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a random template matching certain criteria.
|
|
||||||
*
|
|
||||||
* @param maxSize Maximum size the template can be.
|
* @param maxSize Maximum size the template can be.
|
||||||
* @param getLargest Setting this to true will always get the largest template size in that group,
|
* @param getLargest Setting this to true will always get the largest template size in that group,
|
||||||
* but still randomly out of the templates with that size (ex. for private and public pockets)
|
* but still randomly out of the templates with that size (ex. for private and public pockets)
|
||||||
* @return A random template matching those criteria, or null if none were found
|
* @return A random template matching those criteria, or null if none were found
|
||||||
*/
|
*/
|
||||||
public PocketTemplate getRandomTemplate(String group, int depth, int maxSize, boolean getLargest) {
|
public PocketTemplate getRandomTemplate(String group, int depth, int maxSize, boolean getLargest) { // TODO: multiple groups
|
||||||
// TODO: cache this for faster calls:
|
// TODO: cache this for faster calls:
|
||||||
Map<PocketTemplate, Float> weightedTemplates = new HashMap<>();
|
Map<PocketTemplate, Float> weightedTemplates = new HashMap<>();
|
||||||
int largestSize = 0;
|
int largestSize = 0;
|
||||||
for (PocketTemplate template : templates) {
|
for (PocketTemplate template : templates) {
|
||||||
if (template.getGroupName().equals(group)
|
if (template.getGroup().equals(group) && (maxSize == -1 || template.getSize() <= maxSize)) {
|
||||||
&& (depth == -1 || depth >= template.getMinDepth() && (depth <= template.getMaxDepth() || template.getMaxDepth() == -1))
|
|
||||||
&& (maxSize == -1 || template.getSize() <= maxSize)) {
|
|
||||||
if (getLargest && template.getSize() > largestSize) {
|
if (getLargest && template.getSize() > largestSize) {
|
||||||
weightedTemplates = new HashMap<>();
|
weightedTemplates = new HashMap<>();
|
||||||
largestSize = template.getSize();
|
largestSize = template.getSize();
|
||||||
|
|
|
@ -3,7 +3,6 @@ package org.dimdev.dimdoors.shared.rifts;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.network.NetworkManager;
|
import net.minecraft.network.NetworkManager;
|
||||||
import net.minecraft.network.play.server.SPacketUpdateTileEntity;
|
import net.minecraft.network.play.server.SPacketUpdateTileEntity;
|
||||||
|
@ -25,7 +24,6 @@ import org.dimdev.dimdoors.shared.blocks.BlockFloatingRift;
|
||||||
import org.dimdev.dimdoors.shared.rifts.registry.LinkProperties;
|
import org.dimdev.dimdoors.shared.rifts.registry.LinkProperties;
|
||||||
import org.dimdev.dimdoors.shared.rifts.registry.Rift;
|
import org.dimdev.dimdoors.shared.rifts.registry.Rift;
|
||||||
import org.dimdev.dimdoors.shared.rifts.registry.RiftRegistry;
|
import org.dimdev.dimdoors.shared.rifts.registry.RiftRegistry;
|
||||||
import org.dimdev.dimdoors.shared.world.ModDimensions;
|
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
|
@ -53,6 +51,7 @@ import javax.annotation.Nonnull;
|
||||||
yaw = oldRift.yaw;
|
yaw = oldRift.yaw;
|
||||||
pitch = oldRift.pitch;
|
pitch = oldRift.pitch;
|
||||||
properties = oldRift.properties;
|
properties = oldRift.properties;
|
||||||
|
destination = oldRift.destination;
|
||||||
if (oldRift.isFloating() != isFloating()) updateType();
|
if (oldRift.isFloating() != isFloating()) updateType();
|
||||||
|
|
||||||
markDirty();
|
markDirty();
|
||||||
|
@ -212,7 +211,7 @@ import javax.annotation.Nonnull;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
DimDoors.sendMessage(entity, "There was an exception while teleporting!");
|
DimDoors.chat(entity, "There was an exception while teleporting, please report this bug.");
|
||||||
DimDoors.log.error("Teleporting failed with the following exception: ", e);
|
DimDoors.log.error("Teleporting failed with the following exception: ", e);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -37,7 +37,7 @@ import org.dimdev.dimdoors.shared.rifts.RiftDestination;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean teleport(RotatedLocation loc, Entity entity) {
|
public boolean teleport(RotatedLocation loc, Entity entity) {
|
||||||
if (entity instanceof EntityPlayer) DimDoors.sendMessage(entity, "The entrances of this dungeon has not been linked. Either this is a bug or you are in dungeon-building mode.");
|
if (entity instanceof EntityPlayer) DimDoors.chat(entity, "The entrances of this dungeon has not been linked. Either this is a bug or you are in dungeon-building mode.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,7 @@ public class PocketExitDestination extends RiftDestination { // TODO: not exactl
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean teleport(RotatedLocation loc, Entity entity) {
|
public boolean teleport(RotatedLocation loc, Entity entity) {
|
||||||
if (entity instanceof EntityPlayer) DimDoors.sendMessage(entity, "The exit of this dungeon has not been linked. Either this is a bug or you are in dungeon-building mode.");
|
if (entity instanceof EntityPlayer) DimDoors.chat(entity, "The exit of this dungeon has not been linked. Either this is a bug or you are in dungeon-building mode.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ import org.dimdev.dimdoors.shared.pockets.Pocket;
|
||||||
import org.dimdev.dimdoors.shared.pockets.PocketGenerator;
|
import org.dimdev.dimdoors.shared.pockets.PocketGenerator;
|
||||||
|
|
||||||
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
|
@Getter @AllArgsConstructor @Builder(toBuilder = true) @ToString
|
||||||
public class PublicPocketDestination extends LinkingDestination {
|
public class PublicPocketDestination extends RestoringDestination {
|
||||||
// public PublicPocketDestination() {}
|
// public PublicPocketDestination() {}
|
||||||
|
|
||||||
@Override public void readFromNBT(NBTTagCompound nbt) { super.readFromNBT(nbt); }
|
@Override public void readFromNBT(NBTTagCompound nbt) { super.readFromNBT(nbt); }
|
||||||
|
|
|
@ -7,7 +7,7 @@ import org.dimdev.ddutils.RGBA;
|
||||||
import org.dimdev.ddutils.RotatedLocation;
|
import org.dimdev.ddutils.RotatedLocation;
|
||||||
import org.dimdev.dimdoors.shared.rifts.RiftDestination;
|
import org.dimdev.dimdoors.shared.rifts.RiftDestination;
|
||||||
|
|
||||||
public abstract class LinkingDestination extends RiftDestination {
|
public abstract class RestoringDestination extends RiftDestination {
|
||||||
|
|
||||||
private RiftDestination wrappedDestination;
|
private RiftDestination wrappedDestination;
|
||||||
|
|
|
@ -2,11 +2,13 @@ package org.dimdev.dimdoors.shared.tools;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.BlockDoor;
|
import net.minecraft.block.BlockDoor;
|
||||||
|
import net.minecraft.block.BlockEndPortalFrame;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.init.Blocks;
|
import net.minecraft.init.Blocks;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.nbt.NBTTagList;
|
import net.minecraft.nbt.NBTTagList;
|
||||||
import net.minecraft.tileentity.*;
|
import net.minecraft.tileentity.*;
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
|
@ -16,6 +18,7 @@ import org.dimdev.ddutils.schem.Schematic;
|
||||||
import org.dimdev.dimdoors.DimDoors;
|
import org.dimdev.dimdoors.DimDoors;
|
||||||
import org.dimdev.dimdoors.shared.blocks.BlockFabric;
|
import org.dimdev.dimdoors.shared.blocks.BlockFabric;
|
||||||
import org.dimdev.dimdoors.shared.blocks.ModBlocks;
|
import org.dimdev.dimdoors.shared.blocks.ModBlocks;
|
||||||
|
import org.dimdev.dimdoors.shared.entities.EntityMonolith;
|
||||||
import org.dimdev.dimdoors.shared.rifts.destinations.AvailableLinkDestination;
|
import org.dimdev.dimdoors.shared.rifts.destinations.AvailableLinkDestination;
|
||||||
import org.dimdev.dimdoors.shared.rifts.destinations.PocketEntranceDestination;
|
import org.dimdev.dimdoors.shared.rifts.destinations.PocketEntranceDestination;
|
||||||
import org.dimdev.dimdoors.shared.rifts.destinations.PocketExitDestination;
|
import org.dimdev.dimdoors.shared.rifts.destinations.PocketExitDestination;
|
||||||
|
@ -41,12 +44,12 @@ public final class SchematicConverter {
|
||||||
stateMap.put("minecraft:wooden_door", ModBlocks.WARP_DIMENSIONAL_DOOR.getDefaultState());
|
stateMap.put("minecraft:wooden_door", ModBlocks.WARP_DIMENSIONAL_DOOR.getDefaultState());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Schematic convertSchematic(NBTTagCompound nbt, String name) {
|
public static Schematic convertSchematic(NBTTagCompound nbt, String name, String author) {
|
||||||
Schematic schematic = new Schematic();
|
Schematic schematic = new Schematic();
|
||||||
|
|
||||||
schematic.version = 1; //already the default value
|
schematic.version = 1; //already the default value
|
||||||
schematic.author = "DimDoors"; // Old schematics didn't have an author
|
schematic.author = author;
|
||||||
schematic.name = name.equals("") ? "Unknown" : name;
|
schematic.name = name;
|
||||||
schematic.creationDate = System.currentTimeMillis();
|
schematic.creationDate = System.currentTimeMillis();
|
||||||
schematic.requiredMods = new String[]{DimDoors.MODID};
|
schematic.requiredMods = new String[]{DimDoors.MODID};
|
||||||
|
|
||||||
|
@ -55,6 +58,13 @@ public final class SchematicConverter {
|
||||||
schematic.length = nbt.getShort("Length");
|
schematic.length = nbt.getShort("Length");
|
||||||
schematic.offset = new int[]{0, 0, 0};
|
schematic.offset = new int[]{0, 0, 0};
|
||||||
|
|
||||||
|
// Schematic info
|
||||||
|
int ironDoors = 0;
|
||||||
|
int woodDoors = 0;
|
||||||
|
int sandstoneDoors = 0;
|
||||||
|
int monoliths = 0;
|
||||||
|
int chests = 0;
|
||||||
|
|
||||||
byte[] blockIntArray = nbt.getByteArray("Blocks");
|
byte[] blockIntArray = nbt.getByteArray("Blocks");
|
||||||
if (nbt.hasKey("Palette")) {
|
if (nbt.hasKey("Palette")) {
|
||||||
NBTTagList paletteNBT = (NBTTagList) nbt.getTag("Palette");
|
NBTTagList paletteNBT = (NBTTagList) nbt.getTag("Palette");
|
||||||
|
@ -149,6 +159,8 @@ public final class SchematicConverter {
|
||||||
blockInt = schematic.pallette.size() - 1;
|
blockInt = schematic.pallette.size() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (baseState.getBlock().equals(Blocks.CHEST)) chests++;
|
||||||
|
|
||||||
if (baseState.getBlock().equals(ModBlocks.DIMENSIONAL_DOOR) || baseState.getBlock().equals(ModBlocks.WARP_DIMENSIONAL_DOOR)) {
|
if (baseState.getBlock().equals(ModBlocks.DIMENSIONAL_DOOR) || baseState.getBlock().equals(ModBlocks.WARP_DIMENSIONAL_DOOR)) {
|
||||||
//DimDoors.log.info("Door found: " + baseState.getBlock().getUnlocalizedName());
|
//DimDoors.log.info("Door found: " + baseState.getBlock().getUnlocalizedName());
|
||||||
if (blockState.getProperties().get(BlockDoor.HALF).equals(BlockDoor.EnumDoorHalf.LOWER)) {
|
if (blockState.getProperties().get(BlockDoor.HALF).equals(BlockDoor.EnumDoorHalf.LOWER)) {
|
||||||
|
@ -160,6 +172,7 @@ public final class SchematicConverter {
|
||||||
.linksRemaining(1).build());
|
.linksRemaining(1).build());
|
||||||
|
|
||||||
if (baseState.equals(ModBlocks.DIMENSIONAL_DOOR)) {
|
if (baseState.equals(ModBlocks.DIMENSIONAL_DOOR)) {
|
||||||
|
ironDoors++;
|
||||||
rift.setDestination(AvailableLinkDestination.builder()
|
rift.setDestination(AvailableLinkDestination.builder()
|
||||||
.acceptedGroups(Collections.singleton(0))
|
.acceptedGroups(Collections.singleton(0))
|
||||||
.coordFactor(1)
|
.coordFactor(1)
|
||||||
|
@ -171,10 +184,12 @@ public final class SchematicConverter {
|
||||||
} else { //if (baseState.equals(ModBlocks.WARP_DIMENSIONAL_DOOR))
|
} else { //if (baseState.equals(ModBlocks.WARP_DIMENSIONAL_DOOR))
|
||||||
IBlockState stateBelow = schematic.pallette.get(schematic.blockData[x][y - 1][z]);
|
IBlockState stateBelow = schematic.pallette.get(schematic.blockData[x][y - 1][z]);
|
||||||
if (stateBelow.getBlock().equals(Blocks.SANDSTONE)) {
|
if (stateBelow.getBlock().equals(Blocks.SANDSTONE)) {
|
||||||
|
sandstoneDoors++;
|
||||||
|
rift.setProperties(null); // TODO: this should be removed once the linking equations are made symmetric
|
||||||
rift.setDestination(AvailableLinkDestination.builder()
|
rift.setDestination(AvailableLinkDestination.builder()
|
||||||
.acceptedGroups(Collections.singleton(0))
|
.acceptedGroups(Collections.singleton(0))
|
||||||
.coordFactor(1)
|
.coordFactor(1)
|
||||||
.negativeDepthFactor(0.00000000001)
|
.negativeDepthFactor(0.00000000001) // The division result is cast to an int, so Double.MIN_VALUE would cause an overflow
|
||||||
.positiveDepthFactor(Double.POSITIVE_INFINITY)
|
.positiveDepthFactor(Double.POSITIVE_INFINITY)
|
||||||
.weightMaximum(100)
|
.weightMaximum(100)
|
||||||
.noLink(false)
|
.noLink(false)
|
||||||
|
@ -186,6 +201,7 @@ public final class SchematicConverter {
|
||||||
DimDoors.log.error("Someone placed a door on a sandstone block at the bottom of a schematic. This causes problems and should be remedied. Schematic name: " + schematic.name);
|
DimDoors.log.error("Someone placed a door on a sandstone block at the bottom of a schematic. This causes problems and should be remedied. Schematic name: " + schematic.name);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
woodDoors++;
|
||||||
rift.setDestination(PocketEntranceDestination.builder()
|
rift.setDestination(PocketEntranceDestination.builder()
|
||||||
.weight(1)
|
.weight(1)
|
||||||
.ifDestination(PocketExitDestination.builder().build())
|
.ifDestination(PocketExitDestination.builder().build())
|
||||||
|
@ -201,6 +217,17 @@ public final class SchematicConverter {
|
||||||
|
|
||||||
schematic.tileEntities.add(rift.serializeNBT());
|
schematic.tileEntities.add(rift.serializeNBT());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (blockState.getBlock().equals(Blocks.END_PORTAL_FRAME)) {
|
||||||
|
monoliths++;
|
||||||
|
// I think it's safe to assume that air is present
|
||||||
|
blockInt = schematic.pallette.indexOf(Blocks.AIR.getDefaultState());
|
||||||
|
EntityMonolith monolith = new EntityMonolith(null);
|
||||||
|
EnumFacing facing = blockState.getValue(BlockEndPortalFrame.FACING);
|
||||||
|
monolith.setLocationAndAngles(x + 0.5d, y, z + 0.5d, facing.getHorizontalAngle(), 0);
|
||||||
|
schematic.entities.add(monolith.serializeNBT());
|
||||||
}
|
}
|
||||||
} else { // if this is ancient fabric
|
} else { // if this is ancient fabric
|
||||||
blockInt = schematic.pallette.indexOf(baseState);
|
blockInt = schematic.pallette.indexOf(baseState);
|
||||||
|
@ -210,9 +237,10 @@ public final class SchematicConverter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!nbt.getTag("Entities").hasNoTags()) throw new RuntimeException("Schematic contains entities, but those aren't implemented in the conversion code");
|
||||||
schematic.paletteMax = schematic.pallette.size() - 1;
|
schematic.paletteMax = schematic.pallette.size() - 1;
|
||||||
|
|
||||||
// TODO: entities (and replace end portal frame with monoliths)
|
DimDoors.log.info(schematic.name + "," + ironDoors + "," + woodDoors + "," + sandstoneDoors + "," + monoliths + "," + chests);
|
||||||
|
|
||||||
return schematic;
|
return schematic;
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ public abstract class BaseSchematicGateway extends BaseGateway {
|
||||||
if (streamOpened) {
|
if (streamOpened) {
|
||||||
try {
|
try {
|
||||||
schematicNBT = CompressedStreamTools.readCompressed(schematicDataStream);
|
schematicNBT = CompressedStreamTools.readCompressed(schematicDataStream);
|
||||||
schematic = SchematicConverter.convertSchematic(schematicNBT, name);
|
schematic = SchematicConverter.convertSchematic(schematicNBT, name, null);
|
||||||
schematicDataStream.close();
|
schematicDataStream.close();
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
DimDoors.log.error("Schematic file for " + name + " could not be read as a valid schematic NBT file.", ex);
|
DimDoors.log.error("Schematic file for " + name + " could not be read as a valid schematic NBT file.", ex);
|
||||||
|
|
|
@ -20,7 +20,7 @@ public class BiomeBlank extends Biome {
|
||||||
.setHeightVariation(0F)
|
.setHeightVariation(0F)
|
||||||
.setRainDisabled()
|
.setRainDisabled()
|
||||||
.setRainfall(0)
|
.setRainfall(0)
|
||||||
.setWaterColor(white ? 0xFFFFFF : 0x111111));
|
.setWaterColor(white ? 0xFFFFFF : 0x000055));
|
||||||
this.white = white;
|
this.white = white;
|
||||||
|
|
||||||
topBlock = Blocks.AIR.getDefaultState();
|
topBlock = Blocks.AIR.getDefaultState();
|
||||||
|
@ -60,12 +60,12 @@ public class BiomeBlank extends Biome {
|
||||||
@Override
|
@Override
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public int getGrassColorAtPos(BlockPos pos) {
|
public int getGrassColorAtPos(BlockPos pos) {
|
||||||
return getModdedBiomeGrassColor(white ? 0xFFFFFF : 0x111111);
|
return getModdedBiomeGrassColor(white ? 0xFFFFFF : 0x003300);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public int getFoliageColorAtPos(BlockPos pos) {
|
public int getFoliageColorAtPos(BlockPos pos) {
|
||||||
return getModdedBiomeFoliageColor(white ? 0xFFFFFF : 0x111111);
|
return getModdedBiomeFoliageColor(white ? 0xFFFFFF : 0x003300);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ public abstract class WorldProviderPocket extends WorldProvider {
|
||||||
@Override
|
@Override
|
||||||
public void init() {
|
public void init() {
|
||||||
// TODO: save pocket registry nbt here? (see WorldProviderEnd)
|
// TODO: save pocket registry nbt here? (see WorldProviderEnd)
|
||||||
//hasSkyLight = false; // TODO: this is only a temporary fix
|
hasSkyLight = true; // TODO: this is only a temporary fix
|
||||||
generateLightBrightnessTable();
|
generateLightBrightnessTable();
|
||||||
DimDoors.proxy.setCloudRenderer(this, new CloudRenderBlank());
|
DimDoors.proxy.setCloudRenderer(this, new CloudRenderBlank());
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,125 +1,152 @@
|
||||||
{
|
{
|
||||||
"group": "nether",
|
"group": "nether",
|
||||||
"pocketType" : 2,
|
"pockets": [
|
||||||
"variations": [
|
|
||||||
{
|
{
|
||||||
"variantName": "ComplexHall_SK-CourtyardAmbush_Open_100",
|
"id": "ComplexHall_SK-CourtyardAmbush_Open_100",
|
||||||
|
"type": "complex_hall",
|
||||||
|
"name": "Courtyard Ambush",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 4,
|
"size": 4,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "ComplexHall_SK-Intersection_Open_100",
|
"id": "ComplexHall_SK-Intersection_Open_100",
|
||||||
|
"type": "complex_hall",
|
||||||
|
"name": "Intersection",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 2,
|
"size": 2,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "ComplexHall_SK-SoulWastes_Open_100",
|
"id": "ComplexHall_SK-SoulWastes_Open_100",
|
||||||
|
"type": "complex_hall",
|
||||||
|
"name": "Soul Wastes",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 5,
|
"size": 5,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "ComplexHall_SK-Starfall_Open_100",
|
"id": "ComplexHall_SK-Starfall_Open_100",
|
||||||
|
"type": "complex_hall",
|
||||||
|
"name": "Starfall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 3,
|
"size": 3,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "ComplexHall_SK-TheCauldron_Open_100",
|
"id": "ComplexHall_SK-TheCauldron_Open_100",
|
||||||
|
"type": "complex_hall",
|
||||||
|
"name": "The Cauldron",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 4,
|
"size": 4,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "Maze_SK-BrimstoneMines_Open_80",
|
"id": "Maze_SK-BrimstoneMines_Open_80",
|
||||||
|
"type": "maze",
|
||||||
|
"name": "Brimstone Mines",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 6,
|
"size": 6,
|
||||||
"minDepth": 1,
|
"baseWeight": 80
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "Maze_SK-QuartzfoldCave_Open_40",
|
"id": "Maze_SK-QuartzfoldCave_Open_40",
|
||||||
|
"type": "maze",
|
||||||
|
"name": "Quartzfold Cave",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 5,
|
"size": 5,
|
||||||
"minDepth": 1,
|
"baseWeight": 40
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "Maze_SK-SwirlsUponSwirls_Open_40",
|
"id": "Maze_SK-SwirlsUponSwirls_Open_40",
|
||||||
|
"type": "maze",
|
||||||
|
"name": "Swirls Upon Swirls",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 5,
|
"size": 5,
|
||||||
"minDepth": 1,
|
"baseWeight": 40
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "Maze_SK-Tangle_Open_80",
|
"id": "Maze_SK-Tangle_Open_80",
|
||||||
|
"type": "maze",
|
||||||
|
"name": "Tangle",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 3,
|
"size": 3,
|
||||||
"minDepth": 1,
|
"baseWeight": 80
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-AnvilValley_Open_100",
|
"id": "SimpleHall_SK-AnvilValley_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"name": "Anvil Valley",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 5,
|
"size": 5,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-Arena_Open_100",
|
"id": "SimpleHall_SK-Arena_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"name": "Arena",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 3,
|
"size": 3,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-DarkPathLeft_Open_50",
|
"id": "SimpleHall_SK-DarkPathLeft_Open_50",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 1,
|
"size": 1,
|
||||||
"minDepth": 1,
|
"baseWeight": 50
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-DarkPathRight_Open_50",
|
"id": "SimpleHall_SK-DarkPathRight_Open_50",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 1,
|
"size": 1,
|
||||||
"minDepth": 1,
|
"baseWeight": 50
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-DiamondRoom_Open_100",
|
"id": "SimpleHall_SK-DiamondRoom_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 1,
|
"size": 1,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-LongBridge_Open_100",
|
"id": "SimpleHall_SK-LongBridge_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 4,
|
"size": 4,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-SpiralStairsDown_Open_100",
|
"id": "SimpleHall_SK-SpiralStairsDown_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 0,
|
"size": 0,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "SimpleHall_SK-TheFurnace_Open_100",
|
"id": "SimpleHall_SK-TheFurnace_Open_100",
|
||||||
|
"type": "simple_hall",
|
||||||
|
"author": "SK",
|
||||||
|
"open": true,
|
||||||
"size": 3,
|
"size": 3,
|
||||||
"minDepth": 1,
|
"baseWeight": 100
|
||||||
"maxDepth": 1000,
|
|
||||||
"baseWeight": 10
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,62 +1,37 @@
|
||||||
{
|
{
|
||||||
"group": "private",
|
"group": "private",
|
||||||
"pocketType" : 0,
|
"pockets": [
|
||||||
"variations": [
|
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_0",
|
"id": "private_pocket_0",
|
||||||
"size": 0,
|
"size": 0
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_1",
|
"id": "private_pocket_1",
|
||||||
"size": 1,
|
"size": 1
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_2",
|
"id": "private_pocket_2",
|
||||||
"size": 2,
|
"size": 2
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_3",
|
"id": "private_pocket_3",
|
||||||
"size": 3,
|
"size": 3
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_4",
|
"id": "private_pocket_4",
|
||||||
"size": 4,
|
"size": 4
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_5",
|
"id": "private_pocket_5",
|
||||||
"size": 5,
|
"size": 5
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_6",
|
"id": "private_pocket_6",
|
||||||
"size": 6,
|
"size": 6
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "private_pocket_7",
|
"id": "private_pocket_7",
|
||||||
"size": 7,
|
"size": 7
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,62 +1,37 @@
|
||||||
{
|
{
|
||||||
"group": "public",
|
"group": "public",
|
||||||
"pocketType" : 1,
|
"pockets": [
|
||||||
"variations": [
|
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_0",
|
"id": "public_pocket_0",
|
||||||
"size": 0,
|
"size": 0
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_1",
|
"id": "public_pocket_1",
|
||||||
"size": 1,
|
"size": 1
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_2",
|
"id": "public_pocket_2",
|
||||||
"size": 2,
|
"size": 2
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_3",
|
"id": "public_pocket_3",
|
||||||
"size": 3,
|
"size": 3
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_4",
|
"id": "public_pocket_4",
|
||||||
"size": 4,
|
"size": 4
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_5",
|
"id": "public_pocket_5",
|
||||||
"size": 5,
|
"size": 5
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_6",
|
"id": "public_pocket_6",
|
||||||
"size": 6,
|
"size": 6
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"variantName": "public_pocket_7",
|
"id": "public_pocket_7",
|
||||||
"size": 7,
|
"size": 7
|
||||||
"minDepth": 0,
|
|
||||||
"maxDepth": 0,
|
|
||||||
"baseWeight": 1
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue