Jump to content

Recommended Posts

Posted

Well, for the past 4 hours I've been trying to get this to work...

So, I have a tile entity with a set of Boolean values, and I have a method called "updateBools()" that contains serverside code to update said Boolean values, in that tile entity class (the code can ONLY be run serverside as it accesses the worlds directly [3rd party API]). I will need the server to update the Boolean values every tick (for clientside rendering), however:

if(!FMLCommonHandler.instance().getEffectiveSide().isClient()){updateBools();}

if(FMLCommonHandler.instance().getEffectiveSide().isServer()){updateBools();}

and

if(this.worldObj.isRemote()){updateBools();}

don't work :(

If anybody could point me in the right direction, or at least let me know what I'm doing wrong, I'd be very grateful :D

 

EDIT: the 3 mentioned above are put into updateEntity()

Posted

Hi

 

Some code is only ever run on the server side, not the client side.  isRemote() will always return false in that case.

 

You need to put your updateBools in a method that is called on the client side.

 

Some more background information here

 

http://greyminecraftcoder.blogspot.com.au/2013/10/the-most-important-minecraft-classes.html

 

and

 

http://greyminecraftcoder.blogspot.com.au/2013/10/client-server-communication-using.html

 

-TGG

Posted

That's what I mean: I want the server to run updateBools() because the methods called inside are server-only, and won't run clientside without crashing.

 

When checking for isRemote() to be false in updateEntity(), the code never runs, so I need a way of making the server run the updateBools() method.

 

My code:

Boolean tileup = false;

Boolean tiledown = false;

Boolean tileleft = false;

Boolean tileright = false;

Boolean tilefront = false;

Boolean tileback = false;

 

public void updateBools(){

tileup = EnergyNet.instance.getTileEntity(this.worldObj, xCoord, yCoord+1, zCoord) != null;

tiledown = EnergyNet.instance.getTileEntity(this.worldObj, xCoord, yCoord-1, zCoord) != null;

tileleft = EnergyNet.instance.getTileEntity(this.worldObj, xCoord-1, yCoord, zCoord) != null;;

tileright = EnergyNet.instance.getTileEntity(this.worldObj, xCoord+1, yCoord, zCoord) != null;

tilefront = EnergyNet.instance.getTileEntity(this.worldObj, xCoord, yCoord, zCoord+1) != null;

tileback = EnergyNet.instance.getTileEntity(this.worldObj, xCoord, yCoord, zCoord-1) != null;

}

 

public void updateEntity(){

if(!FMLCommonHandler.instance().getEffectiveSide().isClient()){

updateBools();

}

}

 

(Spoiler wouldn't work :( )

 

If that makes sense... :/

Posted

He listed it as updatebools.  I'm betting he just has the method and isn't calling it from any method the server ticks.

Long time Bukkit & Forge Programmer

Happy to try and help

Posted

I have a class called TileEntityWire extending TileEntity, it is registered in my main mod class, and it works fine apart from this rather large issue :(

 

I have overriden the updateEntity class, and have other functions working in it perfectly.

 

The only problem is - I cant get these shared boolean values to be updated by the server, because it isn't running my code

 

and delphi, the server does tick updateEntity() right?

Posted

Hi

 

updateEntity is called on both client and server side, assuming your TileEntity is properly registered and created on the server side as well as the client side.

 

Are you sure your updateEntity() is being called on the client side?  i.e. maybe it's not being called at all.

 

I would suggest you create a flat land, place your tile entity, then put a breakpoint into World.updateEntities and see why it gets called on the client but not on the server.  That should give you a more direct clue to the problem

 

-TGG

Posted

I just tried out

System.out.println("Hi :D");

in my updateEntity() method, It just appears that the method is not being called :S

so updateEntity() works, just not updateBools()

and in updateEntity() i have

if(!this.worldObj.isRemote){updateBools();}

Posted

So, where is your tileentity registration code?

please show the code.

I. Stellarium for Minecraft: Configurable Universe for Minecraft! (WIP)

II. Stellar Sky, Better Star Rendering&Sky Utility mod, had separated from Stellarium.

Posted
  On 4/18/2014 at 2:44 AM, thatsimplekid said:

  Quote

So, where is your tileentity registration code?

please show the code.

 

GameRegistry.registerTileEntity(TileEntityWire.class, "SCWireEntity");

So where is the registration code?

I. Stellarium for Minecraft: Configurable Universe for Minecraft! (WIP)

II. Stellar Sky, Better Star Rendering&Sky Utility mod, had separated from Stellarium.

Posted

Don't worry people, I just realised what I was doing wrong xD I'd forgotten to sync my boolen values from/to server<-->client, therefore they were changing serverside, and nothing was happening clientside *facepalm*

Thanks for your help anyway :D

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

    • I am playing a mod (1.16.5) that is heavily modded. I played it for a few hours completely fine but now that I am trying to load in again 6 hours later I crash. I  have 32 gigs of dedicated ram to this mod, and Ive gone into my world save, serverconfigs, and deleted usefulbackpacks-server.toml                 What do I do from here   This is my full crash log from Curseforge at net.minecraftforge.fml.config.ConfigFileTypeHandler.lambda$reader$1(ConfigFileTypeHandler.java:61) ~[?:?] at net.minecraftforge.fml.config.ConfigFileTypeHandler$$Lambda$14819/1243247982.apply(Unknown Source) ~[?:?] at net.minecraftforge.fml.config.ConfigTracker.openConfig(ConfigTracker.java:104) ~[?:?] at net.minecraftforge.fml.config.ConfigTracker.lambda$loadConfigs$1(ConfigTracker.java:83) ~[?:?] at net.minecraftforge.fml.config.ConfigTracker$$Lambda$14818/841663910.accept(Unknown Source) ~[?:?] at java.lang.Iterable.forEach(Iterable.java:75) ~[?:1.8.0_51] at java.util.Collections$SynchronizedCollection.forEach(Collections.java:2062) ~[?:1.8.0_51] at net.minecraftforge.fml.config.ConfigTracker.loadConfigs(ConfigTracker.java:83) ~[?:?] at net.minecraftforge.fml.server.ServerLifecycleHooks.handleServerAboutToStart(ServerLifecycleHooks.java:94) ~[?:?] at net.minecraft.server.integrated.IntegratedServer.func_71197_b(IntegratedServer.java:59) ~[?:?] at net.minecraft.server.MinecraftServer.func_240802_v_(MinecraftServer.java:621) [?:?] at net.minecraft.server.MinecraftServer.func_240783_a_(MinecraftServer.java:232) [?:?] at net.minecraft.server.MinecraftServer$$Lambda$21132/2071546526.run(Unknown Source) [?:?] at java.lang.Thread.run(Thread.java:745) [?:1.8.0_51] Caused by: com.electronwill.nightconfig.core.io.ParsingException: Not enough data available at com.electronwill.nightconfig.core.io.ParsingException.notEnoughData(ParsingException.java:22) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.ReaderInput.directReadChar(ReaderInput.java:36) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.AbstractInput.readChar(AbstractInput.java:49) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.AbstractInput.readCharsUntil(AbstractInput.java:123) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.toml.TableParser.parseKey(TableParser.java:166) ~[toml-3.6.3.jar:?] at com.electronwill.nightconfig.toml.TableParser.parseDottedKey(TableParser.java:145) ~[toml-3.6.3.jar:?] at com.electronwill.nightconfig.toml.TableParser.parseNormal(TableParser.java:55) ~[toml-3.6.3.jar:?] at com.electronwill.nightconfig.toml.TomlParser.parse(TomlParser.java:44) ~[toml-3.6.3.jar:?] at com.electronwill.nightconfig.toml.TomlParser.parse(TomlParser.java:37) ~[toml-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.ConfigParser.parse(ConfigParser.java:113) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.ConfigParser.parse(ConfigParser.java:219) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.io.ConfigParser.parse(ConfigParser.java:202) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.file.WriteSyncFileConfig.load(WriteSyncFileConfig.java:73) ~[core-3.6.3.jar:?] at com.electronwill.nightconfig.core.file.AutosaveCommentedFileConfig.load(AutosaveCommentedFileConfig.java:85) ~[core-3.6.3.jar:?] at net.minecraftforge.fml.config.ConfigFileTypeHandler.lambda$reader$1(ConfigFileTypeHandler.java:57) ~[?:?] ... 13 more [23:26:44] [Server thread/FATAL]:Preparing crash report with UUID a1e4c58d-8019-4653-affd-236e2af63d55
    • The server just disconnect me and sent me this error message [01:29:54] [Server thread/ERROR] [minecraft/ServerLoginPacketListenerImpl]: Couldn't place player in world, this is my latest log https://pastebin.com/J300TKP6, I don't know exactly how this started but just yesterday I was playing perfectly.
    • Sorry, didn't work. Still getting the message. Is there anything else I can show you guys that might help more? that Debug Log screen doesn't show much....
    • These 2 mods are the same, remove one of them.
    • I havent played in a while and updated all mod packs and resource packs that required updating, after i updated everything when i would launch the mod it would crash?   [12:20:57] [main/ERROR]:Found duplicate mods: Mod ID: 'rubidium' from mod files: xenon-0.3.31+mc1.20.1.jar, embeddium-0.3.31+mc1.20.1.jar Mod ID: 'embeddium' from mod files: xenon-0.3.31+mc1.20.1.jar, embeddium-0.3.31+mc1.20.1.jar [12:20:57] [main/ERROR]:Failed to build unique mod list after mod discovery. net.minecraftforge.fml.loading.EarlyLoadingException: Duplicate mods found at net.minecraftforge.fml.loading.UniqueModListBuilder.buildUniqueList(UniqueModListBuilder.java:87) ~[fmlloader-1.20.1-47.3.7.jar:1.0] at net.minecraftforge.fml.loading.moddiscovery.ModDiscoverer.discoverMods(ModDiscoverer.java:106) ~[fmlloader-1.20.1-47.3.7.jar:?] at net.minecraftforge.fml.loading.FMLLoader.beginModScan(FMLLoader.java:164) ~[fmlloader-1.20.1-47.3.7.jar:1.0] at net.minecraftforge.fml.loading.FMLServiceProvider.beginScanning(FMLServiceProvider.java:86) ~[fmlloader-1.20.1-47.3.7.jar:1.0] at cpw.mods.modlauncher.TransformationServiceDecorator.runScan(TransformationServiceDecorator.java:112) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.TransformationServicesHandler.lambda$runScanningTransformationServices$8(TransformationServicesHandler.java:100) ~[modlauncher-10.0.9.jar:?] at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:197) ~[?:?] at java.util.HashMap$ValueSpliterator.forEachRemaining(HashMap.java:1779) ~[?:?] at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:509) ~[?:?] at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:499) ~[?:?] at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:575) ~[?:?] at java.util.stream.AbstractPipeline.evaluateToArrayNode(AbstractPipeline.java:260) ~[?:?] at java.util.stream.ReferencePipeline.toArray(ReferencePipeline.java:616) ~[?:?] at java.util.stream.ReferencePipeline.toArray(ReferencePipeline.java:622) ~[?:?] at java.util.stream.ReferencePipeline.toList(ReferencePipeline.java:627) ~[?:?] at cpw.mods.modlauncher.TransformationServicesHandler.runScanningTransformationServices(TransformationServicesHandler.java:102) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.TransformationServicesHandler.initializeTransformationServices(TransformationServicesHandler.java:55) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.Launcher.run(Launcher.java:88) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.Launcher.main(Launcher.java:78) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:26) ~[modlauncher-10.0.9.jar:?] at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:23) ~[modlauncher-10.0.9.jar:?] at cpw.mods.bootstraplauncher.BootstrapLauncher.main(BootstrapLauncher.java:141) ~[bootstraplauncher-1.1.2.jar:?] [12:20:57] [main/ERROR]:Mod Discovery failed. Skipping dependency discovery.
  • Topics

  • Who's Online (See full list)

    • There are no registered users currently online
×
×
  • Create New...

Important Information

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