From 9716205a0dfb1b6b31a0806e6eebf2fc6011e2fc Mon Sep 17 00:00:00 2001 From: Waterpicker Date: Tue, 2 Feb 2021 04:55:33 -0600 Subject: [PATCH] Push DimensionalDoorModifier --- .../modifier/DimensionalDoorModifier.java | 53 +++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 src/main/java/org/dimdev/dimdoors/pockets/virtual/modifier/DimensionalDoorModifier.java diff --git a/src/main/java/org/dimdev/dimdoors/pockets/virtual/modifier/DimensionalDoorModifier.java b/src/main/java/org/dimdev/dimdoors/pockets/virtual/modifier/DimensionalDoorModifier.java new file mode 100644 index 00000000..eccaa877 --- /dev/null +++ b/src/main/java/org/dimdev/dimdoors/pockets/virtual/modifier/DimensionalDoorModifier.java @@ -0,0 +1,53 @@ +package org.dimdev.dimdoors.pockets.virtual.modifier; + +import com.google.common.collect.ImmutableMap; + +import java.util.Map; +import java.util.function.Function; + +import net.minecraft.nbt.CompoundTag; +import net.minecraft.util.math.BlockPos; + +import com.flowpowered.math.vector.Vector3i; +import org.dimdev.dimdoors.util.PocketGenerationParameters; +import org.dimdev.dimdoors.util.math.StringEquationParser; +import org.dimdev.dimdoors.world.pocket.Pocket; + +public class DimensionalDoorModifier implements Modifier { + StringEquationParser.Equation x; + StringEquationParser.Equation y; + StringEquationParser.Equation z; + + @Override + public Modifier fromTag(CompoundTag tag) { + try { + x = StringEquationParser.parse(tag.getString("x")); + y = StringEquationParser.parse(tag.getString("y")); + z = StringEquationParser.parse(tag.getString("z")); + } catch (StringEquationParser.EquationParseException e) { + e.printStackTrace(); + } + return this; + + } + + @Override + public ModifierType getType() { + return ModifierType.DIMENSIONAL_DOOR_MODIFIER_TYPE; + } + + @Override + public String getKey() { + return "dimensional_doors"; + } + + @Override + public void apply(Pocket pocket, PocketGenerationParameters parameters) { + Vector3i size = pocket.getSize(); + Map variables = ImmutableMap.of("width", (double) size.getX(), "height", (double) size.getY(), "length", (double) size.getZ()); + + BlockPos pos = new BlockPos(x.apply(variables), y.apply(variables), z.apply(variables)); + + + } +}