mirror of
https://github.com/Sollace/Unicopia.git
synced 2025-04-03 09:45:29 +02:00
Merge branch 'Sollace:1.20.1' into 1.20.1
This commit is contained in:
commit
9eeeea06ad
40 changed files with 542 additions and 202 deletions
.github/workflows
BlockusAddonbuild.gradlegradle/wrapper
src/main
java/com/minelittlepony/unicopia
InteractionManager.java
ability
block
client
command
datagen/providers
entity
item
mixin
util
resources
4
.github/workflows/gradle-publish.yml
vendored
4
.github/workflows/gradle-publish.yml
vendored
|
@ -17,6 +17,10 @@ jobs:
|
|||
uses: actions/setup-java@v1
|
||||
with:
|
||||
java-version: 17
|
||||
- name: Prepare Datagen
|
||||
uses: eskatos/gradle-command-action@v1
|
||||
with:
|
||||
arguments: rundatagen
|
||||
- name: Publish Modrinth Jar
|
||||
env:
|
||||
MODRINTH_KEY: ${{ secrets.MODRINTH_KEY }}
|
||||
|
|
|
@ -1 +1 @@
|
|||
Subproject commit ec6ea81ed5f0862ab2dfa6201c66504287e3ef76
|
||||
Subproject commit 7170edad67426756e2383bd9464a8615e9bb4b3a
|
|
@ -5,7 +5,7 @@ buildscript {
|
|||
}
|
||||
plugins {
|
||||
id 'java-library'
|
||||
id 'fabric-loom' version '0.12-SNAPSHOT'
|
||||
id 'fabric-loom' version '1.5-SNAPSHOT'
|
||||
id 'com.modrinth.minotaur' version '2.+'
|
||||
id 'org.ajoberstar.reckon' version '0.13.0'
|
||||
}
|
||||
|
|
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
|
@ -1,5 +1,5 @@
|
|||
distributionBase=GRADLE_USER_HOME
|
||||
distributionPath=wrapper/dists
|
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3-bin.zip
|
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.3-bin.zip
|
||||
zipStoreBase=GRADLE_USER_HOME
|
||||
zipStorePath=wrapper/dists
|
||||
|
|
|
@ -14,6 +14,8 @@ import net.minecraft.entity.Entity;
|
|||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
public class InteractionManager {
|
||||
|
@ -90,4 +92,8 @@ public class InteractionManager {
|
|||
public void sendPlayerLookAngles(PlayerEntity player) {
|
||||
|
||||
}
|
||||
|
||||
public void addBlockBreakingParticles(BlockPos pos, Direction direction) {
|
||||
|
||||
}
|
||||
}
|
||||
|
|
|
@ -27,6 +27,7 @@ import net.minecraft.sound.SoundCategory;
|
|||
import net.minecraft.text.Text;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import net.minecraft.util.math.Vec3d;
|
||||
import net.minecraft.util.shape.VoxelShape;
|
||||
import net.minecraft.world.World;
|
||||
|
@ -89,8 +90,10 @@ public class UnicornTeleportAbility implements Ability<Pos> {
|
|||
return trace.getBlockOrEntityPos().map(pos -> {
|
||||
final BlockPos originalPos = pos;
|
||||
|
||||
Direction globalUp = player.getPhysics().isGravityNegative() ? Direction.DOWN : Direction.UP;
|
||||
|
||||
boolean originalPosHasSupport = exception(w, pos, player.asEntity());
|
||||
boolean originalPosValid = enterable(w, pos.up()) && enterable(w, pos.up(2));
|
||||
boolean originalPosValid = enterable(w, pos.offset(globalUp)) && enterable(w, pos.offset(globalUp, 2));
|
||||
|
||||
if (w.getBlockState(pos).isOf(Blocks.POWDER_SNOW) && !PowderSnowBlock.canWalkOnPowderSnow(player.asEntity())) {
|
||||
return null;
|
||||
|
@ -111,11 +114,11 @@ public class UnicornTeleportAbility implements Ability<Pos> {
|
|||
if (pos.getX() != originalPos.getX() || pos.getZ() != originalPos.getZ()) {
|
||||
// check support
|
||||
int steps = 0;
|
||||
while (enterable(w, pos.down())) {
|
||||
pos = pos.down();
|
||||
while (enterable(w, pos.offset(globalUp.getOpposite()))) {
|
||||
pos = pos.offset(globalUp.getOpposite());
|
||||
if (++steps > 2) {
|
||||
if (originalPosValid) {
|
||||
pos = originalPos.up();
|
||||
pos = originalPos.offset(globalUp);
|
||||
break;
|
||||
} else {
|
||||
return null;
|
||||
|
@ -125,7 +128,7 @@ public class UnicornTeleportAbility implements Ability<Pos> {
|
|||
}
|
||||
|
||||
if ((!enterable(w, pos) && exception(w, pos, player.asEntity()))
|
||||
|| (!enterable(w, pos.up()) && exception(w, pos.up(), player.asEntity()))) {
|
||||
|| (!enterable(w, pos.offset(globalUp)) && exception(w, pos.offset(globalUp), player.asEntity()))) {
|
||||
return null;
|
||||
}
|
||||
|
||||
|
|
|
@ -330,7 +330,7 @@ public interface UBlocks {
|
|||
FlammableBlockRegistry.getDefaultInstance().add(BANANAS, 5, 20);
|
||||
FlammableBlockRegistry.getDefaultInstance().add(CURING_JOKE, 60, 100);
|
||||
|
||||
CompostingChanceRegistry.INSTANCE.add(WORM_BLOCK, 8F);
|
||||
CompostingChanceRegistry.INSTANCE.add(WORM_BLOCK, 1F);
|
||||
|
||||
UBlockEntities.bootstrap();
|
||||
EdibleBlock.bootstrap();
|
||||
|
|
|
@ -41,6 +41,8 @@ import net.minecraft.network.PacketByteBuf;
|
|||
import net.minecraft.network.packet.c2s.play.PlayerMoveC2SPacket;
|
||||
import net.minecraft.sound.SoundCategory;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import net.minecraft.util.math.random.Random;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
|
@ -161,4 +163,9 @@ public class ClientInteractionManager extends InteractionManager {
|
|||
c.networkHandler.sendPacket(new PlayerMoveC2SPacket.LookAndOnGround(player.getYaw(), player.getPitch(), player.isOnGround()));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addBlockBreakingParticles(BlockPos pos, Direction direction) {
|
||||
client.particleManager.addBlockBreakingParticles(pos, direction);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -175,43 +175,39 @@ public class WorldRenderDelegate {
|
|||
|
||||
boolean negative = pony.getPhysics().isGravityNegative();
|
||||
|
||||
float roll = negative ? 180 : 0;
|
||||
|
||||
roll = pony instanceof Pony ? ((Pony)pony).getInterpolator().interpolate("g_roll", roll, 15) : roll;
|
||||
|
||||
matrices.translate(x, y + owner.getHeight() / 2, z);
|
||||
|
||||
matrices.multiply(RotationAxis.POSITIVE_X.rotationDegrees(roll));
|
||||
matrices.multiply(RotationAxis.POSITIVE_Y.rotationDegrees(roll));
|
||||
|
||||
if (pony instanceof Pony p) {
|
||||
roll = p.getCamera().calculateRoll();
|
||||
if (negative) {
|
||||
roll -= 180;
|
||||
}
|
||||
float sidewaysRoll = p.getCamera().calculateRoll();
|
||||
|
||||
if (p.getAcrobatics().isFloppy()) {
|
||||
matrices.translate(0, -0.5, 0);
|
||||
p.asEntity().setBodyYaw(0);
|
||||
p.asEntity().setYaw(0);
|
||||
matrices.multiply(RotationAxis.NEGATIVE_X.rotationDegrees(90));
|
||||
sidewaysRoll += 90;
|
||||
}
|
||||
|
||||
matrices.multiply(RotationAxis.NEGATIVE_Y.rotationDegrees(yaw));
|
||||
matrices.multiply(RotationAxis.POSITIVE_Z.rotationDegrees(roll));
|
||||
matrices.multiply(RotationAxis.POSITIVE_Y.rotationDegrees(90));
|
||||
matrices.multiply(RotationAxis.POSITIVE_X.rotationDegrees(sidewaysRoll));
|
||||
matrices.multiply(RotationAxis.POSITIVE_Y.rotationDegrees(-90));
|
||||
|
||||
float diveAngle = p.getInterpolator().interpolate("g_kdive", p.getMotion().isDiving() ? 80 : 0, 15);
|
||||
float forwardPitch = p.getInterpolator().interpolate("g_kdive", p.getMotion().isDiving() ? 80 : 0, 15);
|
||||
|
||||
matrices.multiply(RotationAxis.POSITIVE_X.rotationDegrees(diveAngle));
|
||||
matrices.multiply(RotationAxis.POSITIVE_Y.rotationDegrees(yaw));
|
||||
matrices.multiply(RotationAxis.POSITIVE_X.rotationDegrees(forwardPitch));
|
||||
|
||||
if (p.getCompositeRace().includes(Race.SEAPONY)
|
||||
&& pony.asEntity().isSubmergedInWater()
|
||||
&& MineLPDelegate.getInstance().getPlayerPonyRace(p.asEntity()) != Race.SEAPONY) {
|
||||
ModelPartHooks.startCollecting();
|
||||
}
|
||||
} else if (pony instanceof Creature creature && smittenEyesRenderer.isSmitten(creature)) {
|
||||
ModelPartHooks.startCollecting();
|
||||
} else {
|
||||
float roll = negative ? 180 : 0;
|
||||
|
||||
matrices.multiply(RotationAxis.POSITIVE_Z.rotationDegrees(roll));
|
||||
|
||||
if (pony instanceof Creature creature && smittenEyesRenderer.isSmitten(creature)) {
|
||||
ModelPartHooks.startCollecting();
|
||||
}
|
||||
}
|
||||
|
||||
matrices.translate(-x, -y - owner.getHeight() / 2, -z);
|
||||
|
@ -224,7 +220,7 @@ public class WorldRenderDelegate {
|
|||
}
|
||||
|
||||
private void flipAngles(Entity entity) {
|
||||
if (entity instanceof PlayerEntity) {
|
||||
if (entity instanceof PlayerEntity player) {
|
||||
entity.prevYaw *= -1;
|
||||
entity.setYaw(entity.getYaw() * -1);
|
||||
|
||||
|
|
|
@ -2,8 +2,7 @@ package com.minelittlepony.unicopia.client.render.shader;
|
|||
|
||||
import java.io.IOException;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
import org.slf4j.Logger;
|
||||
|
||||
import com.google.common.collect.*;
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
package com.minelittlepony.unicopia.command;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import com.google.common.collect.Streams;
|
||||
import com.minelittlepony.unicopia.entity.player.Pony;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
import com.minelittlepony.unicopia.entity.Living;
|
||||
import com.mojang.brigadier.arguments.FloatArgumentType;
|
||||
import com.mojang.brigadier.builder.LiteralArgumentBuilder;
|
||||
import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
||||
|
||||
import net.minecraft.command.argument.EntityArgumentType;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.server.command.CommandManager;
|
||||
import net.minecraft.server.command.ServerCommandSource;
|
||||
|
@ -22,45 +22,48 @@ class GravityCommand {
|
|||
return CommandManager.literal("gravity").requires(s -> s.hasPermissionLevel(2))
|
||||
.then(CommandManager.literal("get")
|
||||
.executes(context -> get(context.getSource(), context.getSource().getPlayer(), true))
|
||||
.then(CommandManager.argument("target", EntityArgumentType.player())
|
||||
.executes(context -> get(context.getSource(), EntityArgumentType.getPlayer(context, "target"), false))
|
||||
.then(CommandManager.argument("target", EntityArgumentType.entity())
|
||||
.executes(context -> get(context.getSource(), EntityArgumentType.getEntity(context, "target"), false))
|
||||
))
|
||||
.then(CommandManager.literal("set")
|
||||
.then(CommandManager.argument("gravity", FloatArgumentType.floatArg(-99, 99))
|
||||
.executes(context -> set(context.getSource(), context.getSource().getPlayer(), FloatArgumentType.getFloat(context, "gravity"), true))
|
||||
.then(CommandManager.argument("target", EntityArgumentType.player())
|
||||
.executes(context -> set(context.getSource(), EntityArgumentType.getPlayer(context, "target"), FloatArgumentType.getFloat(context, "gravity"), false))
|
||||
.executes(context -> set(context.getSource(), List.of(context.getSource().getPlayer()), FloatArgumentType.getFloat(context, "gravity"), true))
|
||||
.then(CommandManager.argument("target", EntityArgumentType.entities())
|
||||
.executes(context -> set(context.getSource(), EntityArgumentType.getEntities(context, "target"), FloatArgumentType.getFloat(context, "gravity"), false))
|
||||
)));
|
||||
}
|
||||
|
||||
static int get(ServerCommandSource source, PlayerEntity player, boolean isSelf) throws CommandSyntaxException {
|
||||
sendFeedback(source, player, "get", false, Pony.of(player).getPhysics().getGravityModifier());
|
||||
return 0;
|
||||
}
|
||||
static int get(ServerCommandSource source, Entity target, boolean isSelf) throws CommandSyntaxException {
|
||||
Living<?> l = Living.living(target);
|
||||
|
||||
static int set(ServerCommandSource source, PlayerEntity player, float gravity, boolean isSelf) {
|
||||
|
||||
Pony iplayer = Pony.of(player);
|
||||
|
||||
iplayer.getPhysics().setBaseGravityModifier(gravity);
|
||||
iplayer.setDirty();
|
||||
|
||||
sendFeedback(source, player, "set", true, gravity);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
static void sendFeedback(ServerCommandSource source, PlayerEntity player, String key, boolean notifyTarget, Object...arguments) {
|
||||
String translationKey = "commands.gravity." + key;
|
||||
|
||||
if (source.getEntity() == player) {
|
||||
source.sendFeedback(() -> Text.translatable(translationKey + ".self", arguments), true);
|
||||
float gravity = l == null ? 1 : l.getPhysics().getGravityModifier();
|
||||
if (source.getEntity() == target) {
|
||||
source.sendFeedback(() -> Text.translatable("commands.gravity.get.self", gravity), true);
|
||||
} else {
|
||||
if (notifyTarget && source.getWorld().getGameRules().getBoolean(GameRules.SEND_COMMAND_FEEDBACK)) {
|
||||
player.sendMessage(Text.translatable(translationKey, arguments));
|
||||
}
|
||||
|
||||
source.sendFeedback(() -> Text.translatable(translationKey + ".other", Streams.concat(Stream.of(player.getDisplayName()), Arrays.stream(arguments)).toArray()), true);
|
||||
source.sendFeedback(() -> Text.translatable("commands.gravity.get.other", target.getDisplayName(), gravity), true);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int set(ServerCommandSource source, Collection<? extends Entity> targets, float gravity, boolean isSelf) {
|
||||
List<Entity> affected = targets.stream().map(Living::living).filter(Objects::nonNull).map(l -> {
|
||||
l.getPhysics().setBaseGravityModifier(gravity);
|
||||
l.setDirty();
|
||||
if (l.asEntity() instanceof PlayerEntity player) {
|
||||
if (source.getEntity() == player) {
|
||||
player.sendMessage(Text.translatable("commands.gravity.set.self", gravity));
|
||||
} else if (source.getWorld().getGameRules().getBoolean(GameRules.SEND_COMMAND_FEEDBACK)) {
|
||||
player.sendMessage(Text.translatable("commands.gravity.set.other", l.asEntity().getDisplayName(), gravity));
|
||||
}
|
||||
}
|
||||
return (Entity)l.asEntity();
|
||||
}).toList();
|
||||
|
||||
if (affected.size() == 1) {
|
||||
source.sendFeedback(() -> Text.translatable("commands.gravity.set.other", affected.get(0).getDisplayName()), true);
|
||||
} else {
|
||||
source.sendFeedback(() -> Text.translatable("commands.gravity.set.multiple", affected.size()), true);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -57,7 +57,7 @@ public class UModelProvider extends FabricModelProvider {
|
|||
public void generateItemModels(ItemModelGenerator itemModelGenerator) {
|
||||
ItemModels.register(itemModelGenerator,
|
||||
UItems.ACORN, UItems.APPLE_PIE_HOOF, UItems.APPLE_PIE_SLICE, UItems.APPLE_PIE,
|
||||
UItems.BANANA, UItems.BOTCHED_GEM, UItems.BROKEN_SUNGLASSES, UItems.BURNED_JUICE, UItems.BURNED_TOAST,
|
||||
UItems.BANANA, UItems.BOTCHED_GEM, UItems.BOWL_OF_NUTS, UItems.BROKEN_SUNGLASSES, UItems.BURNED_JUICE, UItems.BURNED_TOAST,
|
||||
UItems.CARAPACE, UItems.CLAM_SHELL, UItems.COOKED_ZAP_APPLE, UItems.CLOUD_LUMP, UItems.CRISPY_HAY_FRIES, UItems.CRYSTAL_HEART, UItems.CRYSTAL_SHARD,
|
||||
UItems.DAFFODIL_DAISY_SANDWICH, UItems.DRAGON_BREATH_SCROLL,
|
||||
UItems.EMPTY_JAR,
|
||||
|
@ -69,8 +69,8 @@ public class UModelProvider extends FabricModelProvider {
|
|||
UItems.JAM_TOAST, UItems.JUICE,
|
||||
UItems.LIGHTNING_JAR,
|
||||
UItems.MANGO, UItems.MUFFIN,
|
||||
UItems.OATMEAL,
|
||||
UItems.PEBBLES, UItems.PEGASUS_FEATHER, UItems.PINECONE, UItems.PINEAPPLE_CROWN,
|
||||
UItems.OATMEAL, UItems.OATMEAL_COOKIE,
|
||||
UItems.PEBBLES, UItems.PEGASUS_FEATHER, UItems.PINECONE, UItems.PINECONE_COOKIE, UItems.PINEAPPLE_CROWN,
|
||||
UItems.RAIN_CLOUD_JAR, UItems.ROCK_STEW, UItems.ROCK, UItems.ROTTEN_APPLE,
|
||||
UItems.SALT_CUBE, UItems.SCALLOP_SHELL, UItems.SHELLY, UItems.SOUR_APPLE_SEEDS, UItems.SOUR_APPLE, UItems.SPELLBOOK, UItems.STORM_CLOUD_JAR,
|
||||
UItems.SWEET_APPLE_SEEDS, UItems.SWEET_APPLE,
|
||||
|
|
|
@ -11,6 +11,7 @@ import net.minecraft.block.Block;
|
|||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.data.server.loottable.BlockLootTableGenerator;
|
||||
import net.minecraft.enchantment.Enchantments;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.loot.LootPool;
|
||||
import net.minecraft.loot.LootTable;
|
||||
import net.minecraft.loot.condition.LootCondition;
|
||||
|
@ -54,18 +55,29 @@ public class UBlockAdditionsLootTableProvider extends FabricBlockLootTableProvid
|
|||
addVanillaDrop(Blocks.PODZOL, block -> wormDrops(block, 4, 0.06F, 0.062222223F, 0.065F, 0.077777776F, 0.2F));
|
||||
addVanillaDrop(Blocks.DIAMOND_ORE, this::crystalShardDrops);
|
||||
addVanillaDrop(Blocks.DEEPSLATE_DIAMOND_ORE, this::crystalShardDrops);
|
||||
addVanillaDrop(Blocks.OAK_LEAVES, block -> chanceDropWithShears(block, UItems.ACORN, GEMSTONES_FORTUNE_CHANCE));
|
||||
addVanillaDrop(Blocks.SPRUCE_LEAVES, block -> chanceDropWithShears(block, UItems.PINECONE, GEMSTONES_FORTUNE_CHANCE));
|
||||
}
|
||||
|
||||
private void addVanillaDrop(Block block, Function<Block, LootTable.Builder> lootTableFunction) {
|
||||
lootTables.put(new Identifier("unicopiamc", block.getLootTableId().getPath()), lootTableFunction.apply(block));
|
||||
}
|
||||
|
||||
public LootTable.Builder chanceDropWithShears(Block block, ItemConvertible drop, float...chance) {
|
||||
return LootTable.builder()
|
||||
.pool(LootPool.builder()
|
||||
.rolls(ConstantLootNumberProvider.create(1))
|
||||
.conditionally(WITHOUT_SILK_TOUCH.and(WITH_SHEARS))
|
||||
.with(chanceDrops(block, drop, 1, chance))
|
||||
);
|
||||
}
|
||||
|
||||
public LootTable.Builder wormDrops(Block block, int max, float...chance) {
|
||||
return LootTable.builder()
|
||||
.pool(LootPool.builder()
|
||||
.rolls(ConstantLootNumberProvider.create(1))
|
||||
.conditionally(WITHOUT_SILK_TOUCH)
|
||||
.with(wheatwormDrops(block, max, chance))
|
||||
.with(chanceDrops(block, UItems.WHEAT_WORMS, max, chance))
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -75,7 +87,7 @@ public class UBlockAdditionsLootTableProvider extends FabricBlockLootTableProvid
|
|||
.rolls(ConstantLootNumberProvider.create(1))
|
||||
.conditionally(WITHOUT_SILK_TOUCH)
|
||||
.with(gemstoneDrops(block, 0.1F))
|
||||
.with(wheatwormDrops(block, max, chance))
|
||||
.with(chanceDrops(block, UItems.WHEAT_WORMS, max, chance))
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -111,16 +123,14 @@ public class UBlockAdditionsLootTableProvider extends FabricBlockLootTableProvid
|
|||
.conditionally(TableBonusLootCondition.builder(Enchantments.FORTUNE, GEMSTONES_FORTUNE_CHANCE));
|
||||
}
|
||||
|
||||
public LootPoolEntry.Builder<?> wheatwormDrops(Block block, int max, float...chance) {
|
||||
return applyExplosionDecay(block, ItemEntry.builder(UItems.WHEAT_WORMS)
|
||||
public LootPoolEntry.Builder<?> chanceDrops(Block block, ItemConvertible drop, int max, float...chance) {
|
||||
return applyExplosionDecay(block, ItemEntry.builder(drop)
|
||||
.apply(SetCountLootFunction.builder(UniformLootNumberProvider.create(1, max)))
|
||||
)
|
||||
.conditionally(TableBonusLootCondition.builder(Enchantments.FORTUNE, chance));
|
||||
}
|
||||
|
||||
|
||||
public static LootTable.Builder dropsWithGemfinding(Block drop, LootPoolEntry.Builder<?> child) {
|
||||
return BlockLootTableGenerator.drops(drop, WITHOUT_SILK_TOUCH_AND_GEM_FINDER, child);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -315,6 +315,17 @@ public class URecipeProvider extends FabricRecipeProvider {
|
|||
.input(UItems.ROCK, 3).criterion(hasItem(UItems.ROCK), conditionsFromItem(UItems.ROCK))
|
||||
.input(Items.BOWL)
|
||||
.offerTo(exporter);
|
||||
ShapelessRecipeJsonBuilder.create(RecipeCategory.FOOD, UItems.BOWL_OF_NUTS)
|
||||
.input(UItems.ACORN, 3).criterion(hasItem(UItems.ACORN), conditionsFromItem(UItems.ACORN))
|
||||
.input(Items.BOWL)
|
||||
.offerTo(exporter);
|
||||
ShapelessRecipeJsonBuilder.create(RecipeCategory.FOOD, UItems.OATMEAL_COOKIE)
|
||||
.input(UItems.OATS, 3).criterion(hasItem(UItems.OATS), conditionsFromItem(UItems.OATS))
|
||||
.offerTo(exporter);
|
||||
ShapelessRecipeJsonBuilder.create(RecipeCategory.FOOD, UItems.PINECONE_COOKIE)
|
||||
.input(UItems.PINECONE).criterion(hasItem(UItems.PINECONE), conditionsFromItem(UItems.PINECONE))
|
||||
.input(Items.WHEAT, 2)
|
||||
.offerTo(exporter);
|
||||
ShapelessRecipeJsonBuilder.create(RecipeCategory.FOOD, UItems.ROCK_CANDY, 3)
|
||||
.input(Items.SUGAR, 6).criterion(hasItem(Items.SUGAR), conditionsFromItem(Items.SUGAR))
|
||||
.input(UItems.PEBBLES, 3)
|
||||
|
|
|
@ -4,18 +4,13 @@ import com.minelittlepony.unicopia.entity.mob.UEntityAttributes;
|
|||
import com.minelittlepony.unicopia.util.Copyable;
|
||||
import com.minelittlepony.unicopia.util.Tickable;
|
||||
|
||||
import net.minecraft.block.BlockRenderType;
|
||||
import net.minecraft.block.BlockState;
|
||||
import net.minecraft.block.FenceGateBlock;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.EntityPose;
|
||||
import net.minecraft.entity.LivingEntity;
|
||||
import net.minecraft.entity.MovementType;
|
||||
import net.minecraft.entity.data.TrackedData;
|
||||
import net.minecraft.entity.mob.MobEntity;
|
||||
import net.minecraft.nbt.NbtCompound;
|
||||
import net.minecraft.particle.BlockStateParticleEffect;
|
||||
import net.minecraft.particle.ParticleTypes;
|
||||
import net.minecraft.registry.tag.BlockTags;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.MathHelper;
|
||||
|
@ -37,22 +32,12 @@ public class EntityPhysics<T extends Entity> implements Physics, Copyable<Entity
|
|||
@Override
|
||||
public void tick() {
|
||||
if (isGravityNegative()) {
|
||||
if (isGravityNegative() && !entity.isSneaking() && entity.isInSneakingPose()) {
|
||||
float currentHeight = entity.getDimensions(entity.getPose()).height;
|
||||
float sneakingHeight = entity.getDimensions(EntityPose.STANDING).height;
|
||||
|
||||
entity.move(MovementType.SELF, new Vec3d(0, -(currentHeight - sneakingHeight), 0));
|
||||
entity.setPose(EntityPose.STANDING);
|
||||
}
|
||||
|
||||
if (entity.getY() > entity.getWorld().getHeight() + 64) {
|
||||
entity.damage(entity.getDamageSources().outOfWorld(), 4.0F);
|
||||
}
|
||||
|
||||
entity.setOnGround(entity.verticalCollision && entity.getVelocity().getY() > 0);
|
||||
}
|
||||
|
||||
float gravity = this.getGravityModifier();
|
||||
float gravity = getGravityModifier();
|
||||
if (gravity != lastGravity) {
|
||||
lastGravity = gravity;
|
||||
|
||||
|
@ -87,8 +72,6 @@ public class EntityPhysics<T extends Entity> implements Physics, Copyable<Entity
|
|||
@Override
|
||||
public BlockPos getHeadPosition() {
|
||||
|
||||
entity.setOnGround(false);
|
||||
|
||||
BlockPos pos = new BlockPos(
|
||||
MathHelper.floor(entity.getX()),
|
||||
MathHelper.floor(entity.getY() + entity.getHeight() + 0.20000000298023224D),
|
||||
|
@ -99,29 +82,13 @@ public class EntityPhysics<T extends Entity> implements Physics, Copyable<Entity
|
|||
BlockPos below = pos.down();
|
||||
BlockState block = entity.getWorld().getBlockState(below);
|
||||
if (block.isIn(BlockTags.FENCES) || block.isIn(BlockTags.WALLS) || block.getBlock() instanceof FenceGateBlock) {
|
||||
entity.setOnGround(true);
|
||||
return below;
|
||||
}
|
||||
} else {
|
||||
entity.setOnGround(true);
|
||||
}
|
||||
|
||||
return pos;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void spawnSprintingParticles() {
|
||||
BlockState state = entity.getWorld().getBlockState(getHeadPosition());
|
||||
if (state.getRenderType() != BlockRenderType.INVISIBLE) {
|
||||
Vec3d vel = entity.getVelocity();
|
||||
entity.getWorld().addParticle(new BlockStateParticleEffect(ParticleTypes.BLOCK, state),
|
||||
entity.getX() + (entity.getWorld().random.nextFloat() - 0.5D) * entity.getWidth(),
|
||||
entity.getY() + entity.getHeight() - 0.1D,
|
||||
entity.getZ() + (entity.getWorld().random.nextFloat() - 0.5D) * entity.getWidth(),
|
||||
vel.x * -4, -1.5D, vel.z * -4);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setBaseGravityModifier(float constant) {
|
||||
entity.getDataTracker().set(gravity, constant);
|
||||
|
|
|
@ -476,12 +476,6 @@ public abstract class Living<T extends LivingEntity> implements Equine<T>, Caste
|
|||
return false;
|
||||
}
|
||||
|
||||
public void onJump() {
|
||||
if (getPhysics().isGravityNegative()) {
|
||||
entity.setVelocity(entity.getVelocity().multiply(1, -1, 1));
|
||||
}
|
||||
}
|
||||
|
||||
@Nullable
|
||||
public final Caster<?> getAttacker() {
|
||||
return attacker;
|
||||
|
|
|
@ -21,8 +21,6 @@ public interface Physics extends NbtSerialisable {
|
|||
|
||||
BlockPos getHeadPosition();
|
||||
|
||||
void spawnSprintingParticles();
|
||||
|
||||
default boolean isGravityNegative() {
|
||||
return getGravityModifier() < 0;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
package com.minelittlepony.unicopia.entity.player;
|
||||
|
||||
import com.minelittlepony.unicopia.entity.mob.StormCloudEntity;
|
||||
import com.minelittlepony.unicopia.util.MutableVector;
|
||||
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
|
||||
public class FlightStuntUtil {
|
||||
public static boolean isPerformingDive(Pony pony, MutableVector velocity) {
|
||||
double horizontalSpeed = velocity.horizontalLengthSquared();
|
||||
double verticalSpeed = velocity.y;
|
||||
return horizontalSpeed != 0 && verticalSpeed < -0.3F && (verticalSpeed / horizontalSpeed) < -0.3F;
|
||||
}
|
||||
|
||||
public static boolean isFlyingLow(Pony pony, MutableVector velocity) {
|
||||
BlockPos pos = pony.asEntity().getBlockPos();
|
||||
return velocity.horizontalLengthSquared() > 0.005F && (pos.getY() - StormCloudEntity.findSurfaceBelow(pony.asWorld(), pos).getY()) < 6;
|
||||
}
|
||||
}
|
|
@ -25,11 +25,7 @@ public final class PlayerDimensions {
|
|||
.or(() -> physics.isFlyingSurvival ? FLYING_EYE_HEIGHT : physics.isGravityNegative() ? Optional.of(dimensions.height) : Optional.empty())
|
||||
.map(h -> {
|
||||
if (physics.isGravityNegative()) {
|
||||
if (pony.asEntity().isSneaking()) {
|
||||
h += 0.2F;
|
||||
}
|
||||
|
||||
return dimensions.height - h;
|
||||
return dimensions.height - h + 0.1F;
|
||||
}
|
||||
return h;
|
||||
});
|
||||
|
|
|
@ -60,6 +60,7 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
private int ticksInAir;
|
||||
private int ticksToGlide;
|
||||
private int ticksDiving;
|
||||
private int ticksFlyingLow;
|
||||
|
||||
private float thrustScale = 0;
|
||||
private float prevThrustScale;
|
||||
|
@ -301,10 +302,6 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
if (entity.isOnGround() || (!creative && entity.horizontalCollision)) {
|
||||
cancelFlight(false);
|
||||
}
|
||||
|
||||
if (entity.isClimbing() && (entity.horizontalCollision || ((LivingEntityDuck)entity).isJumping())) {
|
||||
velocity.y = -0.2F;
|
||||
}
|
||||
}
|
||||
|
||||
isFlyingSurvival = entity.getAbilities().flying && !creative;
|
||||
|
@ -339,28 +336,9 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
velocity.y /= 2F;
|
||||
}
|
||||
|
||||
double horizontalSpeed = this.getHorizontalMotion();
|
||||
double verticalSpeed = velocity.y;
|
||||
|
||||
if (Abilities.RAINBOOM.canUse(pony.getCompositeRace()) && horizontalSpeed != 0 && verticalSpeed < -0.3F && (verticalSpeed / horizontalSpeed) < -0.3F) {
|
||||
ticksDiving++;
|
||||
} else {
|
||||
ticksDiving = 0;
|
||||
}
|
||||
|
||||
if (ticksDiving > 0 && ticksDiving % 25 == 0) {
|
||||
pony.getMagicalReserves().getCharge().addPercent(12.5F);
|
||||
}
|
||||
tickStunts(velocity);
|
||||
} else {
|
||||
prevStrafe = 0;
|
||||
strafe = 0;
|
||||
ticksInAir = 0;
|
||||
wallHitCooldown = MAX_WALL_HIT_CALLDOWN;
|
||||
soundPlaying = false;
|
||||
descentRate = 0;
|
||||
ticksDiving = 0;
|
||||
updraft.update(0, 100);
|
||||
windStrength.update(0, 100);
|
||||
tickGrounded();
|
||||
|
||||
if (Abilities.RAINBOOM.canUse(pony.getCompositeRace()) && entity.isOnGround()) {
|
||||
pony.getMagicalReserves().getCharge().set(0);
|
||||
|
@ -371,10 +349,7 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
}
|
||||
}
|
||||
} else {
|
||||
descentRate = 0;
|
||||
soundPlaying = false;
|
||||
updraft.update(0, 100);
|
||||
windStrength.update(0, 100);
|
||||
tickGrounded();
|
||||
}
|
||||
|
||||
if (!entity.isOnGround()) {
|
||||
|
@ -383,6 +358,10 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
velocity.z /= heavyness;
|
||||
}
|
||||
|
||||
float maximum = 1.5F;
|
||||
velocity.x = MathHelper.clamp(velocity.x, -maximum, maximum);
|
||||
velocity.y = MathHelper.clamp(velocity.y, -maximum, maximum);
|
||||
velocity.z = MathHelper.clamp(velocity.z, -maximum, maximum);
|
||||
entity.setVelocity(velocity.toImmutable());
|
||||
|
||||
if (isFlying() && !entity.isFallFlying() && !pony.getAcrobatics().isHanging() && pony.isClient()) {
|
||||
|
@ -401,6 +380,46 @@ public class PlayerPhysics extends EntityPhysics<PlayerEntity> implements Tickab
|
|||
}
|
||||
}
|
||||
|
||||
private void tickGrounded() {
|
||||
prevStrafe = 0;
|
||||
strafe = 0;
|
||||
ticksInAir = 0;
|
||||
wallHitCooldown = MAX_WALL_HIT_CALLDOWN;
|
||||
soundPlaying = false;
|
||||
descentRate = 0;
|
||||
ticksDiving = 0;
|
||||
ticksFlyingLow = 0;
|
||||
updraft.update(0, 0);
|
||||
windStrength.update(0, 0);
|
||||
}
|
||||
|
||||
private void tickStunts(MutableVector velocity) {
|
||||
boolean canPerformStunts = Abilities.RAINBOOM.canUse(pony.getCompositeRace());
|
||||
ticksDiving = canPerformStunts && FlightStuntUtil.isPerformingDive(pony, velocity) ? (ticksDiving + 1) : 0;
|
||||
ticksFlyingLow = canPerformStunts && FlightStuntUtil.isFlyingLow(pony, velocity) ? (ticksFlyingLow + 1) : 0;
|
||||
|
||||
if (ticksDiving > 0) {
|
||||
float horDiveScale = MathHelper.clamp(ticksDiving / 100F, 0, 10);
|
||||
float verDiveScale = MathHelper.clamp(ticksDiving / 90F, 0, 5);
|
||||
velocity.multiply(1 + horDiveScale, 1 + verDiveScale, 1 + horDiveScale);
|
||||
}
|
||||
|
||||
if (ticksFlyingLow > 0) {
|
||||
float horDiveScale = MathHelper.clamp(ticksFlyingLow / 1000F, 0, 0.9F);
|
||||
float verDiveScale = MathHelper.clamp(ticksFlyingLow / 900F, 0, 0.5F);
|
||||
velocity.multiply(1 + horDiveScale, 1 + verDiveScale, 1 + horDiveScale);
|
||||
}
|
||||
|
||||
if (pony.asEntity().age % 2 == 0) {
|
||||
if (ticksDiving > 0) {
|
||||
pony.getMagicalReserves().getCharge().addPercent(1F);
|
||||
}
|
||||
if (ticksFlyingLow > 0) {
|
||||
pony.getMagicalReserves().getCharge().addPercent(ticksFlyingLow / 200F);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void tickFlight(FlightType type, MutableVector velocity) {
|
||||
if (type.isArtifical()) {
|
||||
tickArtificialFlight(velocity);
|
||||
|
|
|
@ -631,7 +631,7 @@ public class Pony extends Living<PlayerEntity> implements Copyable<Pony>, Update
|
|||
float max = 0.6F;
|
||||
return Optional.of(new Vec3d(
|
||||
MathHelper.clamp(speed.x * factor, -max, max),
|
||||
speed.y * ((speed.y * getPhysics().getGravitySignum()) > 0 ? 1.2 : 1.101),
|
||||
speed.y * (speed.y > 0 ? 1.2 : 1.101),
|
||||
MathHelper.clamp(speed.z * factor, -max, max)
|
||||
));
|
||||
}
|
||||
|
@ -715,11 +715,8 @@ public class Pony extends Living<PlayerEntity> implements Copyable<Pony>, Update
|
|||
}
|
||||
|
||||
public Optional<Float> onImpact(float distance, float damageMultiplier, DamageSource cause) {
|
||||
|
||||
float originalDistance = distance;
|
||||
|
||||
distance *= gravity.getGravityModifier();
|
||||
|
||||
boolean extraProtection = getSpellSlot().get(SpellType.SHIELD, false).isPresent();
|
||||
|
||||
if (!entity.isCreative() && !entity.isSpectator()) {
|
||||
|
|
|
@ -5,7 +5,7 @@ import java.util.List;
|
|||
import java.util.Map;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import javax.annotation.Nullable;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import com.minelittlepony.unicopia.USounds;
|
||||
import com.minelittlepony.unicopia.ability.magic.Caster;
|
||||
|
|
|
@ -0,0 +1,93 @@
|
|||
package com.minelittlepony.unicopia.item;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.function.Supplier;
|
||||
|
||||
import com.minelittlepony.unicopia.InteractionManager;
|
||||
import com.minelittlepony.unicopia.item.enchantment.EnchantmentUtil;
|
||||
import com.minelittlepony.unicopia.server.world.BlockDestructionManager;
|
||||
|
||||
import net.fabricmc.fabric.api.event.player.UseBlockCallback;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.block.BlockState;
|
||||
import net.minecraft.enchantment.EnchantmentHelper;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.item.HoeItem;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.ToolMaterials;
|
||||
import net.minecraft.registry.tag.BlockTags;
|
||||
import net.minecraft.registry.tag.ItemTags;
|
||||
import net.minecraft.sound.SoundCategory;
|
||||
import net.minecraft.util.ActionResult;
|
||||
import net.minecraft.util.Hand;
|
||||
import net.minecraft.util.hit.BlockHitResult;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.MathHelper;
|
||||
import net.minecraft.world.World;
|
||||
import net.minecraft.world.WorldEvents;
|
||||
|
||||
public class ForageableItem extends Item {
|
||||
private static final List<ForageableItem> REGISTRY = new ArrayList<>();
|
||||
static {
|
||||
UseBlockCallback.EVENT.register((PlayerEntity player, World world, Hand hand, BlockHitResult hitResult) -> {
|
||||
if (player.shouldCancelInteraction()) {
|
||||
return ActionResult.PASS;
|
||||
}
|
||||
|
||||
ItemStack stack = player.getStackInHand(hand);
|
||||
if (!stack.isIn(ItemTags.HOES)) {
|
||||
return ActionResult.PASS;
|
||||
}
|
||||
|
||||
BlockPos pos = hitResult.getBlockPos();
|
||||
BlockState state = world.getBlockState(pos);
|
||||
|
||||
ActionResult result = ActionResult.PASS;
|
||||
|
||||
if (state.isIn(BlockTags.LEAVES)) {
|
||||
player.swingHand(hand);
|
||||
world.playSound(player, pos, state.getSoundGroup().getHitSound(), SoundCategory.BLOCKS);
|
||||
InteractionManager.instance().addBlockBreakingParticles(pos, hitResult.getSide());
|
||||
|
||||
int miningLevel = (stack.getItem() instanceof HoeItem hoe ? hoe.getMaterial().getMiningLevel() : 59);
|
||||
|
||||
for (ForageableItem item : REGISTRY) {
|
||||
if ((result = item.onTryForage(world, pos, state, stack, player, miningLevel)).isAccepted()) {
|
||||
stack.damage(1, player, p -> p.sendToolBreakStatus(hand));
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return result.isAccepted() ? ActionResult.SUCCESS : ActionResult.PASS;
|
||||
});
|
||||
}
|
||||
|
||||
private final Supplier<Block> targetBlock;
|
||||
|
||||
public ForageableItem(Settings settings, Supplier<Block> targetBlock) {
|
||||
super(settings);
|
||||
this.targetBlock = targetBlock;
|
||||
REGISTRY.add(this);
|
||||
}
|
||||
|
||||
public ActionResult onTryForage(World world, BlockPos pos, BlockState state, ItemStack stack, PlayerEntity player, int miningLevel) {
|
||||
if (state.isOf(targetBlock.get())) {
|
||||
int spawnChance = (int)((1F - MathHelper.clamp(miningLevel / (float)ToolMaterials.NETHERITE.getMiningLevel(), 0, 1)) * 32);
|
||||
spawnChance -= EnchantmentUtil.getLuck(1, player);
|
||||
|
||||
if (spawnChance <= 0 || world.random.nextInt(spawnChance) == 0) {
|
||||
Block.dropStack(world, pos, new ItemStack(this, 1 + EnchantmentHelper.getLooting(player)));
|
||||
world.syncWorldEvent(WorldEvents.BLOCK_BROKEN, pos, Block.getRawIdFromState(state));
|
||||
if (BlockDestructionManager.of(world).damageBlock(pos, world.getRandom().nextBetween(3, 7)) >= BlockDestructionManager.MAX_DAMAGE) {
|
||||
world.breakBlock(pos, true);
|
||||
}
|
||||
return ActionResult.SUCCESS;
|
||||
}
|
||||
return ActionResult.FAIL;
|
||||
}
|
||||
return ActionResult.PASS;
|
||||
}
|
||||
}
|
|
@ -16,6 +16,7 @@ import com.terraformersmc.terraform.boat.api.TerraformBoatType;
|
|||
import com.terraformersmc.terraform.boat.api.TerraformBoatTypeRegistry;
|
||||
import com.terraformersmc.terraform.boat.api.item.TerraformBoatItemHelper;
|
||||
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.entity.attribute.EntityAttributeModifier;
|
||||
import net.minecraft.entity.attribute.EntityAttributes;
|
||||
import net.minecraft.entity.vehicle.BoatEntity;
|
||||
|
@ -74,6 +75,10 @@ public interface UItems {
|
|||
Item IMPORTED_OATS = register("imported_oats", new Item(new Item.Settings().food(UFoodComponents.IMPORTED_OATS)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item OATMEAL = register("oatmeal", new OatmealItem(new Item.Settings().recipeRemainder(Items.BOWL).maxCount(1).food(UFoodComponents.OATMEAL)), ItemGroups.FOOD_AND_DRINK);
|
||||
|
||||
Item OATMEAL_COOKIE = register("oatmeal_cookie", new Item(new Item.Settings().food(FoodComponents.COOKIE)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item PINECONE_COOKIE = register("pinecone_cookie", new Item(new Item.Settings().food(FoodComponents.COOKIE)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item BOWL_OF_NUTS = register("bowl_of_nuts", new StewItem(new Item.Settings().food(FoodComponents.BAKED_POTATO).recipeRemainder(Items.BOWL)), ItemGroups.FOOD_AND_DRINK);
|
||||
|
||||
Item DAFFODIL_DAISY_SANDWICH = register("daffodil_daisy_sandwich", new Item(new Item.Settings().food(UFoodComponents.DAFODIL_DAISY_SANDWICH)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item HAY_BURGER = register("hay_burger", new Item(new Item.Settings().maxCount(1).food(UFoodComponents.HAY_BURGER)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item HAY_FRIES = register("hay_fries", new Item(new Item.Settings().maxCount(16).food(UFoodComponents.HAY_FRIES)), ItemGroups.FOOD_AND_DRINK);
|
||||
|
@ -85,8 +90,8 @@ public interface UItems {
|
|||
|
||||
Item WHEAT_WORMS = register("wheat_worms", new Item(new Item.Settings().maxCount(16).food(UFoodComponents.WORMS)), ItemGroups.NATURAL);
|
||||
Item MUFFIN = register("muffin", new MuffinItem(new Item.Settings().maxCount(32).food(FoodComponents.BREAD), 0), ItemGroups.FOOD_AND_DRINK);
|
||||
Item PINECONE = register("pinecone", new Item(new Item.Settings().food(UFoodComponents.PINECONE).maxCount(3)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item ACORN = register("acorn", new Item(new Item.Settings().food(UFoodComponents.ACORN).maxCount(16)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item PINECONE = register("pinecone", new ForageableItem(new Item.Settings().food(UFoodComponents.PINECONE).maxCount(16), () -> Blocks.SPRUCE_LEAVES), ItemGroups.FOOD_AND_DRINK);
|
||||
Item ACORN = register("acorn", new ForageableItem(new Item.Settings().food(UFoodComponents.ACORN).maxCount(16), () -> Blocks.OAK_LEAVES), ItemGroups.FOOD_AND_DRINK);
|
||||
Item MANGO = register("mango", new Item(new Item.Settings().food(UFoodComponents.MANGO)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item BANANA = register("banana", new Item(new Item.Settings().food(UFoodComponents.BANANA)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item CURING_JOKE = register("curing_joke", new CuringJokeItem(UBlocks.CURING_JOKE, new Item.Settings().food(UFoodComponents.POISON_JOKE)), ItemGroups.NATURAL);
|
||||
|
@ -101,7 +106,7 @@ public interface UItems {
|
|||
Item TOM = register("tom", new BluntWeaponItem(new Item.Settings(), ImmutableMultimap.of(
|
||||
EntityAttributes.GENERIC_KNOCKBACK_RESISTANCE, new EntityAttributeModifier(BluntWeaponItem.KNOCKBACK_MODIFIER_ID, "Weapon modifier", 0.9, EntityAttributeModifier.Operation.ADDITION)
|
||||
)), ItemGroups.NATURAL);
|
||||
Item ROCK_STEW = register("rock_stew", new Item(new Item.Settings().food(FoodComponents.MUSHROOM_STEW)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item ROCK_STEW = register("rock_stew", new StewItem(new Item.Settings().food(FoodComponents.MUSHROOM_STEW).recipeRemainder(Items.BOWL)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item ROCK_CANDY = register("rock_candy", new Item(new Item.Settings().food(UFoodComponents.CANDY).maxCount(16)), ItemGroups.FOOD_AND_DRINK);
|
||||
Item SALT_CUBE = register("salt_cube", new Item(new Item.Settings().food(UFoodComponents.SALT_CUBE)), ItemGroups.FOOD_AND_DRINK);
|
||||
|
||||
|
|
|
@ -128,11 +128,6 @@ abstract class MixinLivingEntity extends Entity implements LivingEntityDuck, Equ
|
|||
get().adjustMovementSpeedInWater(info.getReturnValue()).ifPresent(info::setReturnValue);
|
||||
}
|
||||
|
||||
@Inject(method = "jump()V", at = @At("RETURN"))
|
||||
private void onJump(CallbackInfo info) {
|
||||
get().onJump();
|
||||
}
|
||||
|
||||
@Inject(method = "tick()V", at = @At("HEAD"), cancellable = true)
|
||||
private void beforeTick(CallbackInfo info) {
|
||||
if (get().beforeUpdate()) {
|
||||
|
@ -186,21 +181,4 @@ abstract class MixinLivingEntity extends Entity implements LivingEntityDuck, Equ
|
|||
setLivingFlag(2, hand == Hand.OFF_HAND);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlockPos getBlockPos() {
|
||||
if (get().getPhysics().isGravityNegative()) {
|
||||
return get().getPhysics().getHeadPosition();
|
||||
}
|
||||
return super.getBlockPos();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void spawnSprintingParticles() {
|
||||
if (get().getPhysics().isGravityNegative()) {
|
||||
get().getPhysics().spawnSprintingParticles();
|
||||
} else {
|
||||
super.spawnSprintingParticles();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -27,12 +27,6 @@ abstract class MixinKeyboardInput extends Input {
|
|||
pressingRight = tmp;
|
||||
|
||||
movementSideways = -movementSideways;
|
||||
|
||||
/*if (player.asEntity().getAbilities().flying && !player.getPhysics().isFlying()) {
|
||||
tmp = jumping;
|
||||
jumping = sneaking;
|
||||
sneaking = tmp;
|
||||
}*/
|
||||
}
|
||||
|
||||
if (EffectUtils.getAmplifier(MinecraftClient.getInstance().player, UEffects.PARALYSIS) > 1) {
|
||||
|
|
|
@ -5,6 +5,7 @@ import org.spongepowered.asm.mixin.Mixin;
|
|||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.At.Shift;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyArg;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
|
||||
|
@ -12,7 +13,9 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
|
|||
import com.minelittlepony.unicopia.entity.Equine;
|
||||
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.EntityPose;
|
||||
import net.minecraft.entity.MovementType;
|
||||
import net.minecraft.util.math.Box;
|
||||
import net.minecraft.util.math.Vec3d;
|
||||
|
||||
@Mixin(value = Entity.class, priority = 29000)
|
||||
|
@ -21,7 +24,7 @@ abstract class MixinEntity {
|
|||
// we invert y when moving
|
||||
@ModifyVariable(method = "move", at = @At("HEAD"), argsOnly = true)
|
||||
private Vec3d modifyMovement(Vec3d movement) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
if (unicopiaIsGravityInverted()) {
|
||||
return movement.multiply(1, -1, 1);
|
||||
}
|
||||
return movement;
|
||||
|
@ -35,14 +38,6 @@ abstract class MixinEntity {
|
|||
}
|
||||
}
|
||||
|
||||
// invert jumping velocity so we can jump
|
||||
@Inject(method = "getJumpVelocityMultiplier", at = @At("RETURN"), cancellable = true)
|
||||
private void onGetJumpVelocityMultiplier(CallbackInfoReturnable<Float> info) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
info.setReturnValue(-info.getReturnValue());
|
||||
}
|
||||
}
|
||||
|
||||
// invert offsets so it can properly find the block we're walking on
|
||||
@ModifyVariable(method = "getPosWithYOffset", at = @At("HEAD"), argsOnly = true)
|
||||
private float onGetPosWithYOffset(float offset) {
|
||||
|
@ -53,12 +48,27 @@ abstract class MixinEntity {
|
|||
}
|
||||
|
||||
// fix sprinting particles
|
||||
@Inject(method = "spawnSprintingParticles", at = @At("HEAD"), cancellable = true)
|
||||
protected void spawnSprintingParticles(CallbackInfo info) {
|
||||
@ModifyArg(method = "spawnSprintingParticles",
|
||||
at = @At(value = "INVOKE",
|
||||
target = "net/minecraft/world/World.addParticle(Lnet/minecraft/particle/ParticleEffect;DDDDDD)V"),
|
||||
index = 2)
|
||||
private double modifyParticleY(double y) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
eq.get().getPhysics().spawnSprintingParticles();
|
||||
info.cancel();
|
||||
Entity self = eq.get().asEntity();
|
||||
return self.getHeight() - y + (self.getY() * 2);
|
||||
}
|
||||
return y;
|
||||
}
|
||||
|
||||
// fix fall damage
|
||||
@ModifyArg(
|
||||
method = "move",
|
||||
at = @At(value = "INVOKE", target = "net/minecraft/entity/Entity.fall(DZLnet/minecraft/block/BlockState;Lnet/minecraft/util/math/BlockPos;)V"))
|
||||
private double modifyFallDistance(double heightDifference) {
|
||||
if (unicopiaIsGravityInverted()) {
|
||||
return -heightDifference;
|
||||
}
|
||||
return heightDifference;
|
||||
}
|
||||
|
||||
// invert check for walking up a step
|
||||
|
@ -68,9 +78,43 @@ abstract class MixinEntity {
|
|||
argsOnly = true)
|
||||
|
||||
private static Vec3d modifyMovementForStepheight(Vec3d movement, @Nullable Entity entity) {
|
||||
if (entity != null && movement.getY() == entity.getStepHeight()) {
|
||||
if (entity instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative() && movement.getY() == entity.getStepHeight()) {
|
||||
return movement.multiply(1, -1, 1);
|
||||
}
|
||||
return movement;
|
||||
}
|
||||
|
||||
@Inject(method = {"calculateBoundsForPose"}, at = @At("RETURN"), cancellable = true)
|
||||
private void adjustPoseBoxForGravity(EntityPose pos, CallbackInfoReturnable<Box> info) {
|
||||
unicopiaReAnchorBoundingBox(info);
|
||||
}
|
||||
|
||||
@Inject(method = {"calculateBoundingBox"}, at = @At("RETURN"), cancellable = true)
|
||||
private void adjustPoseBoxForGravity(CallbackInfoReturnable<Box> info) {
|
||||
if (unicopiaReAnchorBoundingBox(info)) {
|
||||
Entity self = (Entity)(Object)this;
|
||||
self.setPos(self.getX(), info.getReturnValue().minY, self.getZ());
|
||||
}
|
||||
}
|
||||
|
||||
private boolean unicopiaReAnchorBoundingBox(CallbackInfoReturnable<Box> info) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
Entity self = eq.get().asEntity();
|
||||
Box box = info.getReturnValue();
|
||||
Box oldBox = self.getBoundingBox();
|
||||
double newHeight = box.getYLength();
|
||||
if (newHeight > oldBox.getYLength()) {
|
||||
double targetMaxY = oldBox.maxY;
|
||||
Vec3d min = new Vec3d(box.minX, targetMaxY - newHeight, box.minZ);
|
||||
Vec3d max = new Vec3d(box.maxX, targetMaxY, box.maxZ);
|
||||
info.setReturnValue(new Box(min, max));
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private boolean unicopiaIsGravityInverted() {
|
||||
return this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,11 +1,15 @@
|
|||
package com.minelittlepony.unicopia.mixin.gravity;
|
||||
|
||||
import org.spongepowered.asm.mixin.*;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Constant;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyArg;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyConstant;
|
||||
import com.minelittlepony.unicopia.entity.*;
|
||||
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.LivingEntity;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
|
||||
@Mixin(LivingEntity.class)
|
||||
abstract class MixinLivingEntity extends Entity implements Equine.Container<Living<?>> {
|
||||
|
@ -19,4 +23,23 @@ abstract class MixinLivingEntity extends Entity implements Equine.Container<Livi
|
|||
private double modifyGravity(double initial) {
|
||||
return Math.abs(get().getPhysics().calcGravity(initial));
|
||||
}
|
||||
|
||||
@ModifyArg(method = "fall",
|
||||
at = @At(value = "INVOKE",
|
||||
target = "net/minecraft/server/world/ServerWorld.spawnParticles(Lnet/minecraft/particle/ParticleEffect;DDDIDDDD)I"),
|
||||
index = 2)
|
||||
private double modifyParticleY(double y) {
|
||||
if (get().getPhysics().isGravityNegative()) {
|
||||
return y + getHeight();
|
||||
}
|
||||
return y;
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlockPos getBlockPos() {
|
||||
if (get().getPhysics().isGravityNegative()) {
|
||||
return get().getPhysics().getHeadPosition();
|
||||
}
|
||||
return super.getBlockPos();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,46 @@
|
|||
package com.minelittlepony.unicopia.mixin.gravity;
|
||||
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.Shadow;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||
|
||||
import net.minecraft.block.entity.PistonBlockEntity;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Box;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
@Mixin(PistonBlockEntity.class)
|
||||
abstract class MixinPistonBlockEntity {
|
||||
@Shadow
|
||||
private static Box offsetHeadBox(BlockPos pos, Box box, PistonBlockEntity blockEntity) {
|
||||
return box;
|
||||
}
|
||||
|
||||
@Shadow
|
||||
private static boolean canMoveEntity(Box box, Entity entity, BlockPos pos) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Shadow
|
||||
private static void moveEntity(Direction direction, Entity entity, double distance, Direction movementDirection) {
|
||||
|
||||
}
|
||||
|
||||
@Inject(method = "moveEntitiesInHoneyBlock", at = @At("TAIL"))
|
||||
private static void moveEntitiesInHoneyBlock(World world, BlockPos pos, float ticks, PistonBlockEntity tile, CallbackInfo info) {
|
||||
Direction direction = tile.getMovementDirection();
|
||||
if (!direction.getAxis().isHorizontal()) {
|
||||
return;
|
||||
}
|
||||
double blockY = tile.getPushedBlock().getCollisionShape(world, pos).getMin(Direction.Axis.Y);
|
||||
Box box = offsetHeadBox(pos, new Box(0, blockY - 1.5000010000000001F, 0, 1, blockY, 1), tile);
|
||||
double distance = ticks - tile.getProgress(1);
|
||||
for (Entity entity2 : world.getOtherEntities(null, box, entity -> canMoveEntity(box, entity, pos))) {
|
||||
moveEntity(direction, entity2, distance, direction);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,43 @@
|
|||
package com.minelittlepony.unicopia.mixin.gravity;
|
||||
|
||||
import org.spongepowered.asm.mixin.*;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyArg;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
|
||||
|
||||
import com.minelittlepony.unicopia.entity.Equine;
|
||||
|
||||
import net.minecraft.entity.MovementType;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.util.math.Vec3d;
|
||||
|
||||
@Mixin(PlayerEntity.class)
|
||||
abstract class MixinPlayerEntity {
|
||||
@ModifyVariable(method = "adjustMovementForSneaking", at = @At("HEAD"), argsOnly = true)
|
||||
private Vec3d flipMovementForSneaking(Vec3d movement) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
return movement.multiply(1, -1, 1);
|
||||
}
|
||||
return movement;
|
||||
}
|
||||
|
||||
@Inject(method = "adjustMovementForSneaking", at = @At("RETURN"), cancellable = true)
|
||||
private void unflipMovementForSneaking(Vec3d movement, MovementType type, CallbackInfoReturnable<Vec3d> info) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
info.setReturnValue(info.getReturnValue().multiply(1, -1, 1));
|
||||
}
|
||||
}
|
||||
|
||||
@ModifyArg(method = { "adjustMovementForSneaking", "method_30263" }, at = @At(
|
||||
value = "INVOKE",
|
||||
target = "net/minecraft/util/math/Box.offset(DDD)Lnet/minecraft/util/math/Box;"),
|
||||
index = 1)
|
||||
private double invertStepHeight(double stepHeight) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
return -stepHeight;
|
||||
}
|
||||
return stepHeight;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,29 @@
|
|||
package com.minelittlepony.unicopia.mixin.gravity;
|
||||
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.Shadow;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
||||
import com.minelittlepony.unicopia.entity.player.Pony;
|
||||
|
||||
import net.minecraft.network.listener.ServerPlayPacketListener;
|
||||
import net.minecraft.network.listener.TickablePacketListener;
|
||||
import net.minecraft.server.network.ServerPlayNetworkHandler;
|
||||
import net.minecraft.server.network.ServerPlayerEntity;
|
||||
import net.minecraft.server.world.EntityTrackingListener;
|
||||
|
||||
@Mixin(ServerPlayNetworkHandler.class)
|
||||
abstract class MixinServerPlayNetworkHandler
|
||||
implements EntityTrackingListener,
|
||||
TickablePacketListener,
|
||||
ServerPlayPacketListener {
|
||||
@Shadow public ServerPlayerEntity player;
|
||||
|
||||
@ModifyVariable(method = "onPlayerMove", at = @At("STORE"), ordinal = 0)
|
||||
private boolean flipLandingFlag(boolean value) {
|
||||
if (Pony.of(this.player).getPhysics().isGravityNegative()) {
|
||||
return !value;
|
||||
}
|
||||
return value;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,24 @@
|
|||
package com.minelittlepony.unicopia.mixin.gravity;
|
||||
|
||||
import org.spongepowered.asm.mixin.*;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
||||
|
||||
import com.minelittlepony.unicopia.entity.Equine;
|
||||
|
||||
import net.minecraft.server.network.ServerPlayerEntity;
|
||||
|
||||
@Mixin(ServerPlayerEntity.class)
|
||||
abstract class MixinServerPlayerEntity {
|
||||
@ModifyVariable(
|
||||
method = "handleFall(DDDZ)V",
|
||||
at = @At("HEAD"),
|
||||
ordinal = 1,
|
||||
argsOnly = true)
|
||||
private double modifyFallDistance(double value) {
|
||||
if (this instanceof Equine.Container eq && eq.get().getPhysics().isGravityNegative()) {
|
||||
return -value;
|
||||
}
|
||||
return value;
|
||||
}
|
||||
}
|
|
@ -20,6 +20,12 @@ public class MutableVector {
|
|||
z = vec.z;
|
||||
}
|
||||
|
||||
public void multiply(double x, double y, double z) {
|
||||
this.x *= x;
|
||||
this.y *= y;
|
||||
this.z *= z;
|
||||
}
|
||||
|
||||
public void add(Vec3d vector) {
|
||||
add(vector.x, vector.y, vector.z);
|
||||
}
|
||||
|
@ -38,6 +44,18 @@ public class MutableVector {
|
|||
this.z += z;
|
||||
}
|
||||
|
||||
public double horizontalLengthSquared() {
|
||||
return x * x + z * z;
|
||||
}
|
||||
|
||||
public double verticalLengthSquared() {
|
||||
return y * y;
|
||||
}
|
||||
|
||||
public double lengthSquared() {
|
||||
return verticalLengthSquared() + horizontalLengthSquared();
|
||||
}
|
||||
|
||||
public Vec3d toImmutable() {
|
||||
return new Vec3d(x, y, z);
|
||||
}
|
||||
|
|
|
@ -146,6 +146,9 @@
|
|||
"item.unicopia.horse_shoe_fries": "Horse Shoe Fries",
|
||||
"item.unicopia.wheat_worms": "Wheat Worms",
|
||||
"item.unicopia.muffin": "Muffin",
|
||||
"item.unicopia.oatmeal_cookie": "Oatmeal Cookie",
|
||||
"item.unicopia.pinecone_cookie": "Pinecone Cookie",
|
||||
"item.unicopia.bowl_of_nuts": "Bowl of Nuts",
|
||||
|
||||
"item.unicopia.pegasus_amulet": "Wings of Icarus",
|
||||
"item.unicopia.pegasus_amulet.lore": "Grants temporary flight to whoever wears it",
|
||||
|
@ -1383,6 +1386,7 @@
|
|||
"commands.gravity.set": "Your gravity has been updated to %f",
|
||||
"commands.gravity.set.self": "Set own gravity to %f",
|
||||
"commands.gravity.set.other": "Set %s's gravity to %f",
|
||||
"commands.gravity.set.multiple": "Updated %s entities",
|
||||
|
||||
"unicopia.options.title": "Unicopia Options",
|
||||
"unicopia.options.ignore_mine_lp": "Ignore Mine Little Pony",
|
||||
|
|
Binary file not shown.
After ![]() (image error) Size: 8.4 KiB |
Binary file not shown.
After ![]() (image error) Size: 8.9 KiB |
Binary file not shown.
After ![]() (image error) Size: 8.9 KiB |
|
@ -17,6 +17,9 @@
|
|||
"unicopia:hay_fries",
|
||||
"unicopia:crispy_hay_fries",
|
||||
"unicopia:horse_shoe_fries",
|
||||
"unicopia:oatmeal_cookie",
|
||||
"unicopia:pinecone_cookie",
|
||||
"unicopia:bowl_of_nuts",
|
||||
{ "id": "farmersdelight:wheat_dough", "required": false },
|
||||
{ "id": "farmersdelight:raw_pasta", "required": false },
|
||||
{ "id": "farmersdelight:pie_crust", "required": false },
|
||||
|
|
|
@ -51,6 +51,7 @@
|
|||
"unicopia:oats",
|
||||
"unicopia:imported_oats",
|
||||
"unicopia:oatmeal",
|
||||
"unicopia:oatmeal_cookie",
|
||||
"unicopia:daffodil_daisy_sandwich",
|
||||
"unicopia:hay_burger",
|
||||
"unicopia:hay_fries",
|
||||
|
@ -61,6 +62,8 @@
|
|||
"unicopia:muffin",
|
||||
"unicopia:acorn",
|
||||
"unicopia:pinecone",
|
||||
"unicopia:pinecone_cookie",
|
||||
"unicopia:bowl_of_nuts",
|
||||
"unicopia:crystal_shard",
|
||||
"unicopia:pebbles",
|
||||
"unicopia:rock",
|
||||
|
|
|
@ -58,7 +58,11 @@
|
|||
"gravity.MixinLivingEntity",
|
||||
"gravity.MixinMobEntity",
|
||||
"gravity.MixinWorld",
|
||||
"gravity.MixinPlayerEntity",
|
||||
"gravity.MixinPistonBlockEntity",
|
||||
"gravity.MixinServerWorld",
|
||||
"gravity.MixinServerPlayerEntity",
|
||||
"gravity.MixinServerPlayNetworkHandler",
|
||||
"gravity.MixinWorldChunk",
|
||||
"trinkets.MixinTrinketSurvivalSlot",
|
||||
"trinkets.MixinTrinketItem",
|
||||
|
|
Loading…
Add table
Reference in a new issue