Jump to content

[Solved!] Log into a server?


Gingerbreadman

Recommended Posts

This is typical "try over and over again util you succed" case.

 

1. Setup ClientTickEvent and ClientDisconnectionFromServerEvent.

2. Create some static boolean "shouldAutoReconnect".

3. When you get DC, in your ClientDisconnectionFromServerEvent you can set boolean to true.

4. Use ClientTickEvent to check that boolean, then check current screen (instanceof GuiSomething).

5. Make whatever if statements you need and create some incrementation - make client try to reconnect every e.g 2sec (if conditions are met and you are not ingame) or whatever.

6. Done.

 

If you would need to directly know the moment when client faild to connect you can check if current screen displays error msg. Again - you need to do that per-tick with ClientTickEvent.

 

At least that''s what I'd do.

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

Link to comment
Share on other sites

Just look at callbacks :P

 

In GuiMultiplayer:

private void connectToServer(ServerData server)
    {
        net.minecraftforge.fml.client.FMLClientHandler.instance().connectToServer(this, server);
    }

 

You could assume that you need GuiMultiplayer.

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

Link to comment
Share on other sites

Just look at callbacks :P

 

In GuiMultiplayer:

private void connectToServer(ServerData server)
    {
        net.minecraftforge.fml.client.FMLClientHandler.instance().connectToServer(this, server);
    }

You could assume that you need GuiMultiplayer.

I keep getting a null pointer

 

java.lang.NullPointerException

at net.minecraft.client.Minecraft.runTick(Minecraft.java:1994) ~[Minecraft.class:?]

at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1028) ~[Minecraft.class:?]

at net.minecraft.client.Minecraft.run(Minecraft.java:951) [Minecraft.class:?]

at net.minecraft.client.main.Main.main(Main.java:164) [Main.class:?]

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.7.0_71]

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.7.0_71]

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1.7.0_71]

at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.7.0_71]

at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) [launchwrapper-1.11.jar:?]

at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.11.jar:?]

at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source) [start/:?]

at GradleStart.main(Unknown Source) [start/:?]

[02:51:33] [Client thread/INFO] [sTDOUT]: [net.minecraft.client.Minecraft:displayCrashReport:388]: ---- Minecraft Crash Report ----

// Ouch. That hurt :(

 

Time: 07/07/15 02:51

Description: Unexpected error

 

java.lang.NullPointerException: Unexpected error

at net.minecraft.client.Minecraft.runTick(Minecraft.java:1994)

at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1028)

at net.minecraft.client.Minecraft.run(Minecraft.java:951)

at net.minecraft.client.main.Main.main(Main.java:164)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at net.minecraft.launchwrapper.Launch.launch(Launch.java:135)

at net.minecraft.launchwrapper.Launch.main(Launch.java:28)

at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source)

at GradleStart.main(Unknown Source)

Link to comment
Share on other sites

*Ernio focuses on blank page with white-colored letters that supposed to be OP's code*

 

We are not wizards - post your code.

				FMLClientHandler.instance().setupServerList();//might be unnecessary
			FMLClientHandler.instance().connectToServer(new GuiMultiplayer(FMLClientHandler.instance().getClient().currentScreen), new ServerData("", Main.getConfigData().getIP() + ":" + Main.getConfigData().getPort()));

Link to comment
Share on other sites

Try using

FMLClientHandler#connectToServerAtStartup(hostAddress, port)

 

What it does is basically setupServerList and connectToServer, but also first pings the server for availability.

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Link to comment
Share on other sites

I keep getting a nullpointer D:

 

java.lang.NullPointerException
at net.minecraft.client.Minecraft.runTick(Minecraft.java:1994) ~[Minecraft.class:?]
at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1028) ~[Minecraft.class:?]
at net.minecraft.client.Minecraft.run(Minecraft.java:951) [Minecraft.class:?]
at net.minecraft.client.main.Main.main(Main.java:164) [Main.class:?]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.7.0_71]
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.7.0_71]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1.7.0_71]
at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.7.0_71]
at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) [launchwrapper-1.11.jar:?]
at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.11.jar:?]
at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source) [start/:?]
at GradleStart.main(Unknown Source) [start/:?]

My code

FMLClientHandler.instance().connectToServerAtStartup(Main.getConfigData().getIP(), Integer.parseInt(Main.getConfigData().getPort()));

Link to comment
Share on other sites

Look at the line that the crash points to and figure out what is null there and what you are doing that is causing that.

at net.minecraft.launchwrapper.Launch.main(Launch.java:28)

^I think the nullpointer is caused because there is no arguments on line 28 at net.minecraft.launchwrapper.Launch.main?

Link to comment
Share on other sites

I will not write any more responses until you follow what I told you:

Look at the line that the crash points to and figure out what is null there and what you are doing that is causing that.

 

At least tell us what is null on that line so we can do your work for you.

EntityPlayer.itemInUse (ItemStack)

Link to comment
Share on other sites

Use a debugger.

instead of a nullpointer, now I am getting a runtime error

[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: java.lang.RuntimeException: No OpenGL context found in the current thread.
Exception in thread "Timer-0" [15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at org.lwjgl.opengl.GLContext.getCapabilities(GLContext.java:124)
[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at net.minecraft.client.gui.GuiMainMenu.<init>(GuiMainMenu.java:125)
[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at cpw.mods.fml.client.FMLClientHandler.connectToServerAtStartup(FMLClientHandler.java:806)
[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at net.RPD.BlazeBot.Bot$3.run(Bot.java:67)
[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at java.util.TimerThread.mainLoop(Unknown Source)
[15:52:20] [Timer-0/INFO] [sTDERR]: [java.lang.Throwable$WrappedPrintStream:println:-1]: 	at java.util.TimerThread.run(Unknown Source)

and my event

	@SubscribeEvent
public void onDisconnect(ClientDisconnectionFromServerEvent e) {
	Timer t = new Timer();
	t.schedule(new TimerTask() {
		@Override
		public void run() {
			FMLClientHandler.instance().connectToServerAtStartup("192.168.1.8", 69);
		}
	}, 5000);
}

Link to comment
Share on other sites

This is typical "try over and over again util you succed" case.

 

1. Setup ClientTickEvent and ClientDisconnectionFromServerEvent.

2. Create some static boolean "shouldAutoReconnect".

3. When you get DC, in your ClientDisconnectionFromServerEvent you can set boolean to true.

4. Use ClientTickEvent to check that boolean, then check current screen (instanceof GuiSomething).

5. Make whatever if statements you need and create some incrementation - make client try to reconnect every e.g 2sec (if conditions are met and you are not ingame) or whatever.

6. Done.

 

If you would need to directly know the moment when client faild to connect you can check if current screen displays error msg. Again - you need to do that per-tick with ClientTickEvent.

 

At least that''s what I'd do.

Whats the name of the GUI screen of the actual game ingame?

Link to comment
Share on other sites

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

    • Post logs as per https://forums.minecraftforge.net/topic/125488-rules-and-frequently-asked-questions-faq/ They may have information that will answer these questions.
    • I was left reeling when a glitch on a cryptocurrency exchange caused me to lose $166,000 worth of my hard-earned savings. It felt like my entire world had crumbled in the blink of an eye, leaving me with a sense of hopelessness. Determined not to give up, I delved into research on recovery options, unsure of what to expect. That's when I stumbled upon I was left reeling when a glitch on a cryptocurrency exchange caused me to lose $166,000 worth of my hard-earned savings. It felt like my entire world had crumbled in the blink of an eye, leaving me with a sense of hopelessness. Determined not to give up, I delved into research on recovery options, unsure of what to expect. That's when I stumbled upon DIGITAL HACK RECOVERY, a beacon of hope in my darkest hour. Despite my initial doubts, I decided to take a leap of faith and give them a shot as a final lifeline. The experts at DIGITAL HACK RECOVERY proved to be masters of their craft, guiding me through their exclusive process with precision and expertise. Utilizing cutting-edge blockchain analysis methods, they were able to track down the elusive trail of my missing funds and identify the exact point of failure. Their forensic talents were unparalleled as they tirelessly combed through the intricate web of blockchain data to locate my cryptocurrency. With each step they took, they kept me informed of their progress, never wavering in their belief that my funds could be rescued. After several painstaking weeks, DIGITAL HACK RECOVERY finally located and restored my $166,000 worth of cryptocurrency. I was awestruck that they were able to salvage what I had thought was lost forever. The whole experience restored my faith in the crypto space and proved that even in the worst situations, recovery is possible with the right experts on your side. I will be forever grateful to DIGITAL HACK RECOVERY for giving me back my life savings when I needed it most. Their tireless efforts and technical mastery turned what could have been a devastating loss into an uplifting success story. Book a time with DIGITAL HACK RECOVERY through: digital hack recovery @ techie . com &  +12018871705
    • public class ParticleReboundRecipe implements Recipe<CraftingContainer> { private List<ParticleReboundIngredient> inputs; private ParticleReboundFuel fuel; private ItemStack output; public ParticleReboundRecipe(List<ParticleReboundIngredient> inputs, ParticleReboundFuel fuel, ItemStack output) { this.inputs = inputs; this.fuel = fuel; this.output = output; } // TODO: Implement interface ... // TODO: Move to separate file if desired public record ParticleReboundIngredient(Ingredient ingredient, int count) { public static final Codec<ParticleReboundIngredient> CODEC = RecordCodecBuilder.create( builder -> builder.group( Ingredient.CODEC.fieldOf("ingredient").forGetter((i) -> i.ingredient), Codec.INT.fieldOf("count").forGetter(i -> i.count) ).apply(builder, ParticleReboundIngredient::new) ); } // TODO: Move to separate file if desired public record ParticleReboundFuel(String tag) { public static final Codec<ParticleReboundFuel> CODEC = RecordCodecBuilder.create( builder -> builder.group(Codec.STRING.fieldOf("tag").forGetter(f -> f.tag)).apply(builder, ParticleReboundFuel::new) ); public boolean isFuel(ItemStack stack) { // TODO: Check if fuel item matches the tag } } public class Serializer implements RecipeSerializer<ParticleReboundRecipe> { public static final Codec<ParticleReboundRecipe> CODEC = RecordCodecBuilder.create( builder -> builder.group( ParticleReboundIngredient.CODEC.listOf().fieldOf("inputs").forGetter(r -> r.inputs), ParticleReboundFuel.CODEC.fieldOf("fuel").forGetter(r -> r.fuel), ItemStack.CODEC.fieldOf("output").forGetter(r -> r.output) ).apply(builder, ParticleReboundRecipe::new) ); @Override public @NotNull Codec<ParticleReboundRecipe> codec() { return CODEC; } // TODO: The rest ... } }   ?
    • I'm sure load and SaveAdditional are what you are looking for, probably. Mind sharing your BE class code? You also need to override onLoad method if you haven't
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

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