Skip to content

Commit

Permalink
fixed desync issue
Browse files Browse the repository at this point in the history
  • Loading branch information
CammiePone committed Sep 7, 2021
1 parent 1b500d3 commit b609896
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 27 deletions.
18 changes: 18 additions & 0 deletions src/main/java/dev/cammiescorner/arcanus/Arcanus.java
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@
import net.fabricmc.fabric.api.event.registry.FabricRegistryBuilder;
import net.fabricmc.fabric.api.networking.v1.ServerPlayNetworking;
import net.fabricmc.fabric.api.screenhandler.v1.ScreenHandlerRegistry;
import net.minecraft.entity.LivingEntity;
import net.minecraft.entity.data.DataTracker;
import net.minecraft.entity.data.TrackedData;
import net.minecraft.entity.data.TrackedDataHandlerRegistry;
import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.item.ItemGroup;
import net.minecraft.item.ItemStack;
import net.minecraft.loot.function.LootFunctionType;
Expand Down Expand Up @@ -56,6 +61,7 @@ public class Arcanus implements ModInitializer {

@Override
public void onInitialize() {
DataTrackers.MANA.getId();
AutoConfig.register(ArcanusConfig.class, JanksonConfigSerializer::new);
config = AutoConfig.getConfigHolder(ArcanusConfig.class).getConfig();

Expand Down Expand Up @@ -84,4 +90,16 @@ private static <T> Registry<T> createRegistry(String name, Class<?> clazz) {
public static MutableText getSpellInputs(List<Pattern> pattern, int index) {
return index >= pattern.size() || pattern.get(index) == null ? new LiteralText("?").formatted(Formatting.GRAY, Formatting.UNDERLINE) : new LiteralText(pattern.get(index).getSymbol()).formatted(Formatting.GREEN);
}

public static class DataTrackers {
public static final TrackedData<Boolean> IS_DISCOMBOBULATED = DataTracker.registerData(LivingEntity.class, TrackedDataHandlerRegistry.BOOLEAN);
public static final TrackedData<Integer> DISCOMBOBULATED_TIMER = DataTracker.registerData(LivingEntity.class, TrackedDataHandlerRegistry.INTEGER);

public static final TrackedData<Integer> MANA = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
public static final TrackedData<Float> MANA_RECHARGE_RATE = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.FLOAT);
public static final TrackedData<Integer> BURNOUT = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
public static final TrackedData<Float> BURNOUT_RECHARGE_RATE = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.FLOAT);
public static final TrackedData<Integer> MANA_LOCK = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
public static final TrackedData<Boolean> SHOW_MANA = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.BOOLEAN);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,28 +5,20 @@
import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityType;
import net.minecraft.entity.LivingEntity;
import net.minecraft.entity.data.DataTracker;
import net.minecraft.entity.data.TrackedData;
import net.minecraft.entity.data.TrackedDataHandlerRegistry;
import net.minecraft.nbt.NbtCompound;
import net.minecraft.util.math.Vec3d;
import net.minecraft.world.World;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
import org.spongepowered.asm.mixin.Unique;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.ModifyVariable;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;

import static dev.cammiescorner.arcanus.Arcanus.DataTrackers.DISCOMBOBULATED_TIMER;
import static dev.cammiescorner.arcanus.Arcanus.DataTrackers.IS_DISCOMBOBULATED;

@Mixin(LivingEntity.class)
public abstract class LivingEntityMixin extends Entity implements CanBeDiscombobulated {
@Shadow private float movementSpeed;
@Unique
private static final TrackedData<Boolean> IS_DISCOMBOBULATED = DataTracker.registerData(LivingEntity.class, TrackedDataHandlerRegistry.BOOLEAN);
@Unique
private static final TrackedData<Integer> DISCOMBOBULATED_TIMER = DataTracker.registerData(LivingEntity.class, TrackedDataHandlerRegistry.INTEGER);

public LivingEntityMixin(EntityType<?> type, World world) {
super(type, world);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,6 @@
import net.minecraft.entity.LivingEntity;
import net.minecraft.entity.TntEntity;
import net.minecraft.entity.damage.DamageSource;
import net.minecraft.entity.data.DataTracker;
import net.minecraft.entity.data.TrackedData;
import net.minecraft.entity.data.TrackedDataHandlerRegistry;
import net.minecraft.entity.player.HungerManager;
import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.entity.projectile.PersistentProjectileEntity;
Expand Down Expand Up @@ -53,6 +50,7 @@
import java.util.List;
import java.util.Optional;

import static dev.cammiescorner.arcanus.Arcanus.DataTrackers.*;
import static dev.cammiescorner.arcanus.Arcanus.config;

@Mixin(PlayerEntity.class)
Expand All @@ -74,18 +72,6 @@ public abstract class PlayerEntityMixin extends LivingEntity implements MagicUse
private int spellTimer = 0;
@Unique
private static final int MAX_MANA = 20;
@Unique
private static final TrackedData<Integer> MANA = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
@Unique
private static final TrackedData<Float> MANA_RECHARGE_RATE = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.FLOAT);
@Unique
private static final TrackedData<Integer> BURNOUT = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
@Unique
private static final TrackedData<Float> BURNOUT_RECHARGE_RATE = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.FLOAT);
@Unique
private static final TrackedData<Integer> MANA_LOCK = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.INTEGER);
@Unique
private static final TrackedData<Boolean> SHOW_MANA = DataTracker.registerData(PlayerEntity.class, TrackedDataHandlerRegistry.BOOLEAN);

protected PlayerEntityMixin(EntityType<? extends LivingEntity> entityType, World world) {
super(entityType, world);
Expand Down Expand Up @@ -169,7 +155,7 @@ public void writeNbt(NbtCompound tag, CallbackInfo info) {
rootTag.putInt("SpellTimer", spellTimer);
}

@Inject(method = "initDataTracker", at = @At("TAIL"))
@Inject(method = "initDataTracker", at = @At("HEAD"))
public void initTracker(CallbackInfo info) {
dataTracker.startTracking(MANA, MAX_MANA);
dataTracker.startTracking(MANA_RECHARGE_RATE, 1F);
Expand Down

0 comments on commit b609896

Please sign in to comment.