Jump to content

Recommended Posts

Posted

I have a machine that makes dusts from ores. Pretty simple. I decided to add in recipes from the ore dictionary. The below code is supposed to find every registered dust, finds it's ore, and registers the ore. It works fine for redstone, my ores, but everything else is messed up. Non ores are getting put in, and Copper Ore from Immersive Engineering goes straight to copper ingots passing over the dust. Somehow this code is assigning random ores(and basalt) to one of about 4 dusts.

Any help?

for(String dust : OreDictionary.getOreNames())
	{
		if(dust.startsWith("dust"))
		{
			String ore = dust.replace("dust", "ore");
			if(OreDictionary.doesOreNameExist(ore))
			{
				List<ItemStack> ores = OreDictionary.getOres(ore);
				List<ItemStack> dusts = OreDictionary.getOres(dust);
				if(ores.size() > 0 && dusts.size() > 0 && ore.replace("ore", "").equals(dust.replace("dust", "")))
				{
					for(ItemStack currentOre : ores)
					{
						Recipes.addEnrichment(currentOre.getItem(), dusts.get(0).getItem());
					}
				}
			}
		}
	}

[shadow=gray,left][glow=red,2,300]KEEGAN[/glow][/shadow]

Posted

When code like that is doing unexpected things, it's much much more informative to step through it live in the debugger than for someone on the outside to look at it dead at a distance.

 

Set a breakpoint and look at what values your internal variables are acquiring as they acquire them. When you get to one of your mismatches, palm will hit face and you should be able to fix the error (could be something as simple as ore -> ores somewhere, or maybe dusts.get(0) isn't always what's needed?).

 

Anyway, catching it in the act will make analysis easy.

The debugger is a powerful and necessary tool in any IDE, so learn how to use it. You'll be able to tell us more and get better help here if you investigate your runtime problems in the debugger before posting.

Posted

Thanks for the reply!

I tried stepping through, but with my mod on its own everything is fine. I also can't install mods into my development environment without crashing due to NoClassDefFound

 

A println before the final for loop shows a 1:1 properly matched dust to ore list.

ie:

dustIron
oreIron
dustRedstone
oreRedstone
dustZinc
oreZinc
dustOsmium
oreOsmium

 

...but the recipes are still off

[shadow=gray,left][glow=red,2,300]KEEGAN[/glow][/shadow]

Posted

Thanks for the reply!

I tried stepping through, but with my mod on its own everything is fine. I also can't install mods into my development environment without crashing due to NoClassDefFound

 

A println before the final for loop shows a 1:1 properly matched dust to ore list.

ie:

dustIron
oreIron
dustRedstone
oreRedstone
dustZinc
oreZinc
dustOsmium
oreOsmium

 

...but the recipes are still off

Why not try it in the final loop or even in the Recipes.addEnrichment(...) method.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

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.