Jump to content

[1.10.2] [SOLVED] Capability init works on Integrated but not Dedicated Server


Recommended Posts

Posted

Hi all,

I am currently working on a mod that adds rpg-like skills to Minecraft using a Capability attached to EntityPlayer. Right now, the system works just fine on an Integrated Server, but upon attempting to launch it on a Dedicated Server, the line registering the capability encounters a NoClassDefFoundError:

https://github.com/archery2000/Mod/blob/master/Crashlog

 

Here is the part of my code that is probably related to the crash:

https://github.com/archery2000/Mod/blob/master/skills/core/SkillCapability.java

https://github.com/archery2000/Mod/blob/master/core/Main.java

https://github.com/archery2000/Mod/blob/master/core/CommonProxy.java

https://github.com/archery2000/Mod/blob/master/core/ServerProxy.java

https://github.com/archery2000/Mod/blob/master/core/ClientProxy.java

 

Would be so grateful if someone could point me in the right direction.

 

Thanks!

 

Edit: Thanks to Abastro, I figured out the source of the problem. By only injecting it in Common Proxy and referring to it from all my other files, the error is prevented.

Posted

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Posted

replace

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

w/

if (event.getSide() == Side.CLIENT)

 

It didn't work, here's the second crashlog(which looks about the same):

https://github.com/archery2000/Mod/blob/master/Crashlog2

 

May I know the rationale behind the change? Also, if it is important, I use several packets to update the skill information between client and server, where I update the capability information in the packet handler under the appropriate thread.

 

 

That's from an FX handler that was updated from 1.8. In it, all the FX used by my mod is managed. It was added into Common by accident and has been removed. Thanks!

Posted

Your crash is caused by using EntityPlayerSP somewhere in your code.

 

Yes, that I know, but the issue is that I have no idea how to remedy it.

 

There are only two places where EntityPlayerSP is used.

The first is in my packet handlers which are intended to sync capability data from server to client(the player on client side is gotten using Minecraft.getMinecraft().thePlayer. I suppose it is not wrong to attach the capability to this instance of the player? Or is there another 'player entity' that I am supposed to attach it to?

The second is in GUIs because I render the skill bar on the HUD. In this case, the player is again obtained using Minecraft.getMinecraft().thePlayer, because it is client sided only.

 

Regardless, I don't really understand why the error comes up in initialisation.

Posted

Check all part where the casting capability is injected. Client-only code shouldn't be referenced on the same class with the injection.

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

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

Posted

Because the class is

loaded

.  Merely by being called into existence, the JVM needs to load up every class that it then references before ANY method can be run.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

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 also just tried with iron's spellbooks removed, since that seemed related, but i am still having the same problem, even in newly created worlds. https://mclo.gs/AtrAfaj 
    • My Gradle Project for my Minecraft mod isn't building. Terminal: * Where: Settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle' line: 2 * What went wrong: Could not compile settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle'. > startup failed:   settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle': 2: The pluginManagement {} block must appear before any other statements in the script.   For more information on the pluginManagement {} block, please refer to https://docs.gradle.org/9.0.0/userguide/plugins.html#sec:plugin_management in the Gradle documentation.    @ line 2, column 1.      pluginManagement {      ^   1 error * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Run with --scan to generate a Build Scan (Powered by Develocity). > Get more help at https://help.gradle.org.   Setting.Gradle File:   rootProject.name = 'fusion-lucky-block' pluginManagement {     repositories {         gradlePluginPortal()         maven { url "https://maven.minecraftforge.net/" }         mavenCentral()     } }
    • no change still. here's a new log  https://mclo.gs/RXwiZmn 
    • Whenever I go to build my it says "Build failed in " how many seconds   Here is what is said in my terminal * Where: Build file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\build.gradle' line: 3 * What went wrong: Plugin [id: 'net.minecraftforge.gradle', version: '6.1.51'] was not found in any of the following sources: - Gradle Core Plugins (plugin is not in 'org.gradle' namespace) - Included Builds (No included builds contain this plugin) - Plugin Repositories (could not resolve plugin artifact 'net.minecraftforge.gradle:net.minecraftforge.gradle.gradle.plugin:6.1.51')   Searched in the following repositories:     Gradle Central Plugin Repository     MinecraftForge(https://maven.minecraftforge.net/) * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Get more help at https://help.gradle.org.   Here is what is in my build.gradle file plugins {     id 'java'     id 'net.minecraftforge.gradle' version '6.1+' }   group = 'io.github.csonnic03.fusionlucky' version = '1.0.0' archivesBaseName = 'fusionlucky'   java {     toolchain {         languageVersion = JavaLanguageVersion.of(17)     } }   repositories {     mavenCentral()     maven {         name "forgeMaven"         url "https://maven.minecraftforge.net/<repository>" } }   dependencies {     minecraft 'net.minecraftforge:forge:1.20.1-47.1.0' }   minecraft {     mappings channel: 'official', version: '1.20.1'     runs {         client {             workingDirectory project.file('run')         }         server {             workingDirectory project.file('run')         }     } }   tasks.withType(JavaCompile) {     options.encoding = 'UTF-8' }   jar {     manifest {         attributes(             "Specification-Title": "Fusion Lucky Block",             "Specification-Vendor": "example",             "Implementation-Title": project.name,             "Implementation-Version": project.version,             "Implementation-Vendor": "example",             "ModLauncher-TargetFMLVersion": "[47,)"         )     } }  
  • Topics

×
×
  • Create New...

Important Information

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