equivalent-exchange-3/src/main/java/com/pahimar/ee3/network/message/MessageSetEnergyValue.java
Pahimar 0c5f1ccb41 Remove an unnecessary old reference from MessageSetEnergyValue
Stub out MessageSetBlacklistEntry for later development tomorrow
2016-05-24 23:28:04 -04:00

103 lines
3.4 KiB
Java

package com.pahimar.ee3.network.message;
import com.google.gson.JsonParseException;
import com.pahimar.ee3.api.exchange.EnergyValue;
import com.pahimar.ee3.api.exchange.EnergyValueRegistryProxy;
import com.pahimar.ee3.exchange.EnergyValueRegistry;
import com.pahimar.ee3.exchange.WrappedStack;
import com.pahimar.ee3.util.CompressionHelper;
import com.pahimar.ee3.util.LogHelper;
import com.pahimar.ee3.util.SerializationHelper;
import cpw.mods.fml.common.network.simpleimpl.IMessage;
import cpw.mods.fml.common.network.simpleimpl.IMessageHandler;
import cpw.mods.fml.common.network.simpleimpl.MessageContext;
import io.netty.buffer.ByteBuf;
import java.util.Map;
import java.util.TreeMap;
public class MessageSetEnergyValue implements IMessage, IMessageHandler<MessageSetEnergyValue, IMessage> {
public Map<WrappedStack, EnergyValue> energyValueMap;
public MessageSetEnergyValue() {
}
public MessageSetEnergyValue(WrappedStack wrappedStack, EnergyValue energyValue) {
this.energyValueMap = new TreeMap<>();
if (wrappedStack != null && wrappedStack.getWrappedObject() != null && energyValue != null) {
this.energyValueMap.put(wrappedStack, energyValue);
}
}
public MessageSetEnergyValue(Map<WrappedStack, EnergyValue> energyValueMap) {
this.energyValueMap = energyValueMap;
}
@Override
public void fromBytes(ByteBuf buf) {
int compressedJsonLength = buf.readInt();
if (compressedJsonLength != 0) {
byte[] compressedValueMap = buf.readBytes(compressedJsonLength).array();
if (compressedValueMap != null) {
String jsonString = CompressionHelper.decompress(compressedValueMap);
try {
energyValueMap = SerializationHelper.GSON.fromJson(jsonString, SerializationHelper.ENERGY_VALUE_MAP_TYPE);
}
catch (JsonParseException e) {
LogHelper.warn("Failed to read energy value map from server");
energyValueMap = null;
}
}
else {
energyValueMap = null;
}
}
else {
energyValueMap = null;
}
}
@Override
public void toBytes(ByteBuf buf) {
if (energyValueMap != null) {
byte[] compressedValueMap = CompressionHelper.compress(SerializationHelper.GSON.toJson(energyValueMap, SerializationHelper.ENERGY_VALUE_MAP_TYPE));
if (compressedValueMap != null) {
buf.writeInt(compressedValueMap.length);
buf.writeBytes(compressedValueMap);
}
else {
buf.writeInt(0);
}
}
else {
buf.writeInt(0);
}
}
@Override
public IMessage onMessage(MessageSetEnergyValue message, MessageContext ctx) {
if (message.energyValueMap != null) {
for (WrappedStack wrappedStack : message.energyValueMap.keySet()) {
EnergyValue energyValue = message.energyValueMap.get(wrappedStack);
EnergyValueRegistryProxy.setEnergyValue(wrappedStack, energyValue);
EnergyValueRegistry.INSTANCE.setShouldSave(false);
LogHelper.info(EnergyValueRegistry.ENERGY_VALUE_MARKER, "Client successfully received new energy value '{}' for object '{}'", energyValue, wrappedStack);
}
}
return null;
}
}