Jump to content

Recommended Posts

Posted

hello,

 

I want to save data to player and I use IEEP. So far, so good.

The data survive logout and death.

But when I go from death screen directly to title screen the data is lost.

How can I fix this?

 

IEEP:

public class PlayerInformation implements IExtendedEntityProperties {

public final static String EXT_PROP_NAME = "PlayerInformation";

private final EntityPlayer player;
private HashMap<String, Boolean> layerBools = new HashMap<String, Boolean>();
private HashMap<String, Boolean> questBools = new HashMap<String, Boolean>();
private HashMap<String, Integer> questNums = new HashMap<String, Integer>();

public PlayerInformation(EntityPlayer player) {
	this.player = player;
	for (String s : BlockedLayers.names) {
		questBools.put(s, false);
		questNums.put(s + "Num", 0);
	}
	for (String s : BlockedLayers.layer) {
		layerBools.put(s, false);
	}

}

public static final void register(EntityPlayer player) {
	player.registerExtendedProperties(PlayerInformation.EXT_PROP_NAME,
			new PlayerInformation(player));
}

public static final PlayerInformation get(EntityPlayer player) {
	return (PlayerInformation) player.getExtendedProperties(EXT_PROP_NAME);
}

@Override
public void saveNBTData(NBTTagCompound compound) {
	NBTTagCompound properties = new NBTTagCompound();

	for (Entry<String, Boolean> entry : layerBools.entrySet()) {
		properties.setBoolean(entry.getKey(), entry.getValue());
	}

	for (Entry<String, Boolean> entry : questBools.entrySet()) {
		properties.setBoolean(entry.getKey(), entry.getValue());
	}

	for (Entry<String, Integer> entry : questNums.entrySet()) {
		properties.setInteger(entry.getKey(), entry.getValue());
	}

	compound.setTag(EXT_PROP_NAME, properties);

}

@Override
public void loadNBTData(NBTTagCompound compound) {
	NBTTagCompound properties = (NBTTagCompound) compound
			.getTag(EXT_PROP_NAME);

	for (Entry<String, Boolean> entry : layerBools.entrySet()) {
		entry.setValue(properties.getBoolean(entry.getKey()));
	}
	for (Entry<String, Boolean> entry : questBools.entrySet()) {
		entry.setValue(properties.getBoolean(entry.getKey()));
	}
	for (Entry<String, Integer> entry : questNums.entrySet()) {
		entry.setValue(properties.getInteger(entry.getKey()));
	}

}

private static final String getSaveKey(EntityPlayer player) {
	return player.getCommandSenderName() + ":" + EXT_PROP_NAME;
}

public static final void loadProxyData(EntityPlayer player) {
	PlayerInformation playerData = PlayerInformation.get(player);
	NBTTagCompound savedData = ServerProxy
			.getEntityData(getSaveKey(player));
	if (savedData != null) {
		playerData.loadNBTData(savedData);
	}
}

public static final void saveProxyData(EntityPlayer player) {
	PlayerInformation playerData = PlayerInformation.get(player);
	NBTTagCompound savedData = new NBTTagCompound();

	playerData.saveNBTData(savedData);
	ServerProxy.storeEntityData(getSaveKey(player), savedData);
}

@Override
public void init(Entity entity, World world) {

}

public HashMap<String, Boolean> getLayerBools() {
	return layerBools;
}

public HashMap<String, Boolean> getQuestBools() {
	return questBools;
}

public HashMap<String, Integer> getQuestNums() {
	return questNums;
}

}

 

SyncHandler:

public class SyncHandler {

@SubscribeEvent
public void onLivingDeathEvent(LivingDeathEvent event) {
	if (!event.entity.worldObj.isRemote
			&& event.entity instanceof EntityPlayer) {
		EntityPlayer player = (EntityPlayer) event.entity;
		NBTTagCompound playerData = new NBTTagCompound();
		((PlayerInformation) (player
				.getExtendedProperties(PlayerInformation.EXT_PROP_NAME)))
				.saveNBTData(playerData);
		ServerProxy.storeEntityData(player.getCommandSenderName(),
				playerData);
		PlayerInformation.saveProxyData((EntityPlayer) event.entity);
	}
}

@SubscribeEvent
public void onEntityConstructing(EntityConstructing event) {
	if (event.entity instanceof EntityPlayer) {
		EntityPlayer player = (EntityPlayer) event.entity;
		if (PlayerInformation.get((EntityPlayer) event.entity) == null) {
			PlayerInformation.register(player);
		}
	}
}

@SubscribeEvent
public void respawn(EntityJoinWorldEvent event) {
	if (!event.entity.worldObj.isRemote
			&& event.entity instanceof EntityPlayer && !event.entity.isDead) {
		EntityPlayer player = (EntityPlayer) event.entity;

		NBTTagCompound playerData = ServerProxy.getEntityData(player
				.getCommandSenderName());
		if (playerData != null) {
			(player.getExtendedProperties(PlayerInformation.EXT_PROP_NAME))
					.loadNBTData(playerData);
		}
		PlayerInformation props = PlayerInformation.get(player);

	}

}
}

 

Proxy:

public class ServerProxy extends CommonProxy implements IGuiHandler {

private static final Map<String, NBTTagCompound> extendedEntityData = new HashMap<String, NBTTagCompound>();

@Override
public Object getServerGuiElement(int ID, EntityPlayer player, World world,
		int x, int y, int z) {
	return null;
}

@Override
public Object getClientGuiElement(int ID, EntityPlayer player, World world,
		int x, int y, int z) {
	return null;
}

public static void storeEntityData(String name, NBTTagCompound compound) {
	extendedEntityData.put(name, compound);
}

public static NBTTagCompound getEntityData(String name) {
	return extendedEntityData.remove(name);
}
}

Posted

these-are-not-the-droids.jpg

 

In simpler words: You are outdated.

 

* IEEP class is cool.

* Clonning data is not cool.

 

What you need:

IEEP = hold data.

EntityConstructing = assign data.

PlayerEvent.Clone = clone data on player re-creation (e.g death).

 

Example:

@SubscribeEvent
public void onPlayerClonning(PlayerEvent.Clone event)
{
IEEP ieepNew = IEEP.get(event.entityPlayer);
IEEP ieepOld = IEEP.get(event.original);

ieepNew.setSomething(ieepOld.getSomething());
}

 

Everything else is old "technique" and you don't need it.

In case you need synchronization - you might wanna look at FML's PlayerEvent#, like: PlayerRespawnEvent, PlayerChangedDimensionEvent.

1.7.10 is no longer supported by forge, you are on your own.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • It gave me an error report. I don't understand what it means. Can you tell me what I should do?   report: [27Mar2025 13:52:28.379] [main/FATAL] [net.minecraftforge.server.loading.ServerModLoader/]: Crash report saved to ./crash-reports/crash-2025-03-27_13.52.28-fml.txt [27Mar2025 13:52:28.384] [main/ERROR] [net.minecraft.server.Main/FATAL]: Failed to start the minecraft server net.minecraftforge.fml.LoadingFailedException: Loading errors encountered: [ Mod §efabric_command_api_v2§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_model_loading_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_content_registries_v0§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_api_base§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_item_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_mining_level_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_renderer_indigo§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_object_builder_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §ewaystones§r requires §6balm§r §o7.0.0 or above§r §7Currently, §6balm§r§7 is §o§nnot installed, Mod §efabric_events_interaction_v0§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_transfer_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_registry_sync_v0§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_screen_handler_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_particles_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_renderer_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_resource_loader_v0§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_sound_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_lifecycle_events_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_data_generation_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_networking_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_item_group_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_transitive_access_wideners_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_rendering_fluids_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_dimensions_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_resource_conditions_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_recipe_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_screen_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §eapoli§r requires §6caelus§r §o3.1.0 or above§r §7Currently, §6caelus§r§7 is §o§nnot installed, Mod §efabric_client_tags_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_block_view_api_v2§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_models_v0§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_api§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_loot_api_v2§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_rendering_data_attachment_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_rendering_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_convention_tags_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_key_binding_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_biome_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_message_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_block_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_api_lookup_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_game_rule_api_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_blockrenderlayer_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0, Mod §efabric_entity_events_v1§r requires §6forge§r §o47.1.3§r §7Currently, §6forge§r§7 is §o47.4.0 ] at net.minecraftforge.fml.ModLoader.gatherAndInitializeMods(ModLoader.java:149) ~[fmlcore-1.20.1-47.4.0.jar%23154!/:?] at net.minecraftforge.server.loading.ServerModLoader.load(ServerModLoader.java:30) ~[forge-1.20.1-47.4.0-universal.jar%23158!/:?] at net.minecraft.server.Main.main(Main.java:125) ~[server-1.20.1-20230612.114412-srg.jar%23153!/:?] at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?] at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[?:?] at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] at java.lang.reflect.Method.invoke(Method.java:568) ~[?:?] at net.minecraftforge.fml.loading.targets.CommonLaunchHandler.runTarget(CommonLaunchHandler.java:111) ~[fmlloader-1.20.1-47.4.0.jar%2369!/:?] at net.minecraftforge.fml.loading.targets.CommonLaunchHandler.serverService(CommonLaunchHandler.java:103) ~[fmlloader-1.20.1-47.4.0.jar%2369!/:?] at net.minecraftforge.fml.loading.targets.CommonServerLaunchHandler.lambda$makeService$0(CommonServerLaunchHandler.java:27) ~[fmlloader-1.20.1-47.4.0.jar%2369!/:?] at cpw.mods.modlauncher.LaunchServiceHandlerDecorator.launch(LaunchServiceHandlerDecorator.java:30) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:53) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:71) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.Launcher.run(Launcher.java:108) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.Launcher.main(Launcher.java:78) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:26) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:23) ~[modlauncher-10.0.9.jar%2355!/:?] at cpw.mods.bootstraplauncher.BootstrapLauncher.main(BootstrapLauncher.java:141) ~[bootstraplauncher-1.1.2.jar:?]
    • Back then there was a number which determined the tier of an item and block. If the block tier is lower or equal to the item number, the block would be mined. this however, has changed and now it goes by "needs_netherite_tool" which is fine, until you realized that some mods had items and blocks that exceeded these values. You can make you own "needs_mod_tool" but I feel that this is more limiting(and just more work) than before. So is there anyway to use something similar to the old tier system while also still being compatible with a lot of other mod tools?
    • Well, when I log in to the server, sometimes within an hour, sometimes within a minute, the server closes and informs me that there was a Ticking entity error. Below is the crash report
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.