Jump to content

How to Disconnect Player When is SinglePlayer


jredfox

Recommended Posts

1 minute ago, diesieben07 said:

Do what properly? What is not properly about it?

if player is owner I want the world equivalent to the save and quit button so all the necessary forge events fire when booting the player.

Edited by jredfox
Link to comment
Share on other sites

3 minutes ago, diesieben07 said:

The logout event is not necessary when the server is shutting down. If you want the equivalent to the "save and quit button" the client needs to close the channel.

well it is for me since a player got booted and was owner but, didn't have any modded forge event stuff happen on logout thus a good possibility of screwing up other mods data since they use that as a boolean to close stuff and remove data when the player logout fires.

Not happy about this but, I will have to switch it to client only code and do what jeblar wanted me to do

Edited by jredfox
Link to comment
Share on other sites

3 minutes ago, diesieben07 said:

Please clarify what you mean by "a boolean to close stuff and remove data". You are not doing anything unusual, you are shutting down the server. If a mod does not handle that gracefully, that is a bug in the mod and the mod needs to be fixed.

how is a mod removing arrays/hashmaps data on on player logout and application doesn't restart yet server shuts down a mod issue? There is no way to detect if the server is shutting down because within one tick all code is down and no forge events can fire 

Edited by jredfox
Link to comment
Share on other sites

3 minutes ago, diesieben07 said:

No. I am not going to do this anymore.

Go back to your post and fix your convoluted ass-backwards sentence structure. I have no idea what you are trying to say and I am no longer willing to spend like 2 minutes per "sentence" (you rarely use proper punctuation) trying to decipher what you have vomited into the text field.

 

This is a forum, not a 11-year-old's chat room.

I am sorry but, you explaining stuff wrong isn't my issue. You said it's a mods freaken issue when the entire tick system shuts down the mod should handle that well guess what the mod can't handle it because the game tick no longer occurs. Any coder would know that

Edited by jredfox
Link to comment
Share on other sites

4 minutes ago, diesieben07 said:

Nothing to do with ticks. Yes, game ticks no longer occur when the server shuts down. Tick events are not the place to unload data.

Any code would know that... Thanks for today's laugh. Seriously...

I am doing the client only version because that is what mc calls and I believe player logout events should occur before world shutdown like it does in vanilla save and quit anyways. 

How am I suppose to do this on command when the data gets to the client? The game will crash since the game isn't paused like I was saying at page one. So Should I be opening a gui first then call the code to exit the world like jeblar was saying?

Edited by jredfox
Link to comment
Share on other sites

Just now, diesieben07 said:

No, you send a custom packet to the client.

And in the handler for that packet you do what GuiIngameMenu::actionPerformed case 1 does. Or rather an adaptation for your needs. You do not need GUIs.

I will be sending the packet I just need it to not crash when executing that code. The game freezes and or crashed on previous tests I could try again maybe I thought it was a client tick when it was somehow still server.

Link to comment
Share on other sites

2 minutes ago, diesieben07 said:

Have you ever shut down a dedicated server? No player logout events will fire. This is not a bug.

shutdown a dedicated server player logout events are not needed because the program that the variables are attached to are no longer in memory and the program dies. 

I did post a crash report I am trying again will post it if it still persists

Edited by jredfox
Link to comment
Share on other sites

4 minutes ago, diesieben07 said:

Oh, so that makes it unneeded to save them to disk. Sure. You are ridiculous.

arraylists/hashmap data for manual work around/do functions that don't need to be saved to the disk will get re-instantiated on startup. for example the code you had me do with mob spawnage if that had anything to do with the player that data would get screwed up if I did shutdown like that

I have code myself for uuidfixer on player logout if player is owner(checks for is client) reset the tick counter back to 0.

Yes I could technically do world unload but, but, not all mods are going to use that format.

Edited by jredfox
Link to comment
Share on other sites

4 minutes ago, diesieben07 said:

Again with your sentences...

If you need data attached to a player, use a capability. That is what they are there for. Then all this unloading and loading crap will be taking care of for you.

 

Your "uuidfixer" is stupid and the wrong way to fix your supposed bug, as discussed in another thread. And even if, this is the wrong way to approach this.

 

Then these mods are broken. Just like yours is.

maybe they are broken maybe they are not but, I can confirm alot of mods do this on player logout event for this that I have looked at their code. That's why I knew about the event to begin with

 

either way I need to go ahead and get the client side to  logout of the world

Edited by jredfox
Link to comment
Share on other sites

People like diesieben07 are key contributors to developing Forge itself. And I have been modding for years. We are telling you very important things about how to do things properly and you're totally arguing and ignoring the good advice. Why are you even asking for help if you won't listen to someone that actually helped write Forge!?!

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

Link to comment
Share on other sites

21 hours ago, jabelar said:

People like diesieben07 are key contributors to developing Forge itself. And I have been modding for years. We are telling you very important things about how to do things properly and you're totally arguing and ignoring the good advice. Why are you even asking for help if you won't listen to someone that actually helped write Forge!?!

attaching a capability for a global tick counter isn't an option he only half reads my posts anyways. it would reset per player when in reality I need it global to check for all players. On player logout if is server owner I reset the tick counter back to 0 has nothing to do with this.

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

    • Working with Lee Ultimate Hacker was a transformative experience that not only restored hacked funds but also exemplified a level of professionalism that exceeded expectations. In a world where cryptocurrency theft is a prevalent threat, the need for reliable recovery services is paramount. My testimony delves into my journey with Lee Ultimate Hacker, highlighting the profound impact of hacked funds and the exceptional recovery process provided by the company. From the initial consultation to the execution of the recovery plan, the expertise and dedication of Lee Ultimate Hacker shone through, setting a new standard for crypto recovery services. Within the rapidly evolving realm of cryptocurrencies, there is always a chance of fraud and hacking. Cybercrime affects a lot of people and companies, costing them their hard-earned digital assets. As a result, there is an increasing need for reputable and trustworthy crypto recovery services to assist victims in getting back what is truly theirs. A beam of brilliance amid the swirling storms of cryptocurrency robbery is Lee Ultimate Hacker. Lee Ultimate Hacker is passionate about assisting clients in safety and effectively recovering their monies that have been compromised, and it does so by utilizing state-of-the-art technology and a team of knowledgeable specialists. In the crypto recovery market, they are a well-known brand thanks to their track record of expertise and accomplishments. The repercussions of having your crypto assets hacked can be devastating. Apart from the financial loss, there is also a sense of violation and helplessness that comes with being a victim of cybercrime. The emotional toll and stress of dealing with such a situation can be overwhelming, affecting both personal and professional aspects of life. Upon contacting Lee Ultimate Hacker via LEEULTIMATEHACKER@ AOL. COM   Support @ leeultimatehacker . com.  telegram:LEEULTIMATE   wh@tsapp +1  (715) 314  -  9248  https://leeultimatehacker.com I met with a thorough initial consultation to understand the details of the hack and assess the extent of the damage. This step is crucial in formulating a tailored recovery plan that suits the specific needs of each client. With their extensive knowledge of blockchain technology and forensic investigation abilities, they create a recovery plan that increases the likelihood that the funds will be successfully retrieved.  Lee Ultimate Hacker has an illustrious history of accomplishment. The team's professionalism, knowledge, and commitment to helping people recover from crypto-related issues have been emphasized by the countless clients who have shared their great experiences working with them.
    • Hi, has anyone dealt with gradlew :runClient crashing on start before? I've currently made a forge 1.18.2 mod with the latest mdk and I use IntelliJ IDEA 2024.1 as my IDE, and now whenever I try to run the `:runClient` command with gradle, it works at first, but then the process stops reporting this issue: `Caused by: java.lang.reflect.InvocationTargetException` and `Caused by: java.lang.NoSuchMethodError: 'int net.minecraft.util.Mth.m_14045_(int, int, int)'`. I've pasted the full runClient gradle log in this message. I investigated this issue further on the forge forums to find that not much people had encountered it, and those who did encounter it somehow fixed it with fixes that does not work for me like deleting cache and let gradle redownload the cache or anything and that this issue is caused by a "Corrupted Cache", or whatever the heck that meant. I tried cloning my entire repo (https://github.com/Type-32/PreciseManufacturing) to another directory to "start fresh" but the same issue persists. I created a new project with a clean forge mod 1.18.2 template but the issue persists. I tried all the fixes I can find but none of them worked. even `.\gradlew --refresh-dependencies` didn't work. I am getting desparate for any help now ~~this is so freaking frustrating~~ This is my build.gradle file plugins { id 'eclipse' id 'idea' id 'net.minecraftforge.gradle' version '[6.0.16,6.2)' id 'org.parchmentmc.librarian.forgegradle' version '1.+' } group = mod_group_id version = mod_version base { archivesName = mod_id } java { toolchain.languageVersion = JavaLanguageVersion.of(17) } minecraft { mappings channel: mapping_channel, version: mapping_version copyIdeResources = true runs { // applies to all the run configs below configureEach { workingDirectory project.file('run') property 'forge.logging.markers', 'REGISTRIES' property 'forge.logging.console.level', 'debug' mods { "${mod_id}" { source sourceSets.main } } } client { // Comma-separated list of namespaces to load gametests from. Empty = all namespaces. property 'forge.enabledGameTestNamespaces', mod_id property 'mixin.env.remapRefMap', 'true' property 'mixin.env.refMapRemappingFile', "${projectDir}/build/createSrgToMcp/output.srg" } server { property 'forge.enabledGameTestNamespaces', mod_id args '--nogui' } gameTestServer { property 'forge.enabledGameTestNamespaces', mod_id } data { // example of overriding the workingDirectory set in configureEach above workingDirectory project.file('run-data') // Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources. args '--mod', mod_id, '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/') } } } jarJar.enable() reobf { jarJar { } } tasks.jarJar.finalizedBy('reobfJarJar') // Include resources generated by data generators. sourceSets.main.resources { srcDir 'src/generated/resources' } repositories { maven { name = 'tterrag maven' url = 'https://maven.tterrag.com/' } mavenLocal() } dependencies { minecraft "net.minecraftforge:forge:${minecraft_version}-${forge_version}" implementation fg.deobf("com.simibubi.create:create-${create_minecraft_version}:${create_version}:slim") { transitive = false } implementation fg.deobf("com.jozufozu.flywheel:flywheel-forge-${flywheel_minecraft_version}:${flywheel_version}") implementation fg.deobf("com.tterrag.registrate:Registrate:${registrate_version}") // [MC<minecraft_version>,MC<next_minecraft_version>) jarJar(group: 'com.tterrag.registrate', name: 'Registrate', version: "[MC1.18.2,MC1.19)") // Example mod dependency with JEI - using fg.deobf() ensures the dependency is remapped to your development mappings // The JEI API is declared for compile time use, while the full JEI artifact is used at runtime // compileOnly fg.deobf("mezz.jei:jei-${mc_version}-common-api:${jei_version}") // compileOnly fg.deobf("mezz.jei:jei-${mc_version}-forge-api:${jei_version}") // runtimeOnly fg.deobf("mezz.jei:jei-${mc_version}-forge:${jei_version}") // Example mod dependency using a mod jar from ./libs with a flat dir repository // This maps to ./libs/coolmod-${mc_version}-${coolmod_version}.jar // The group id is ignored when searching -- in this case, it is "blank" // implementation fg.deobf("blank:coolmod-${mc_version}:${coolmod_version}") } tasks.named('processResources', ProcessResources).configure { var replaceProperties = [ minecraft_version: minecraft_version, minecraft_version_range: minecraft_version_range, forge_version: forge_version, forge_version_range: forge_version_range, loader_version_range: loader_version_range, mod_id: mod_id, mod_name: mod_name, mod_license: mod_license, mod_version: mod_version, mod_authors: mod_authors, mod_description: mod_description, ] inputs.properties replaceProperties filesMatching(['META-INF/mods.toml', 'pack.mcmeta']) { expand replaceProperties + [project: project] }} // Example for how to get properties into the manifest for reading at runtime. tasks.named('jar', Jar).configure { manifest { attributes([ "Specification-Title": mod_id, "Specification-Vendor": mod_authors, "Specification-Version": "1", // We are version 1 of ourselves "Implementation-Title": project.name, "Implementation-Version": project.jar.archiveVersion, "Implementation-Vendor": mod_authors, "Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ") ]) } // This is the preferred method to reobfuscate your jar file finalizedBy 'reobfJar' } tasks.withType(JavaCompile).configureEach { options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation }  
    • pastebin.com and paste.ee couldn't handle the debug and crash log sizes, apologies I have to send it on mega, and I hope it's not a problem Basically, Minecraft turns on normally but when I try to create a world, it goes to 100%, joining world, saving world and crashes   debug log https://mega.nz/file/kP1nGDKZ decryption key: C_VSH-IO6Kpi9IdqUs2Z0KDu0Fpujmen_I3rI1yUyVw crash log https://mega.nz/file/RXVEhRpZ 0r05xiqoGmL8rQEXjYaf8Q8BO-XbJGzpeBDek3aqb0w
  • Topics

×
×
  • Create New...

Important Information

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