Jump to content

Custom trees in custom dimension which is generated like the nether, don't spawn


OwnAgePau

Recommended Posts

Hi all, i have generated a custom dimension like the nether, but with custom grass and dirt and some stone types. Also i have set the sky to normal and the light level in my dimension is level 15 in most of the places.

But i can't get my trees to spawn there, any help is great!

I use forge v7.7.1 and mcp 7.44

 

WorldGenGrapeTree:

 

 


package Mod_Ores;

import java.util.Random;
import net.minecraft.block.Block;
import net.minecraft.block.BlockSapling;
import net.minecraft.util.Direction;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenerator;
import net.minecraftforge.common.ForgeDirection;

public class WorldGenGrapeTree extends WorldGenerator
{
/** The minimum height of a generated tree. */
private final int minTreeHeight;

/** True if this tree should grow Vines. */
private final boolean vinesGrow;

/** The metadata value of the wood to use in tree generation. */
private final int metaWood;

/** The metadata value of the leaves to use in tree generation. */
private final int metaLeaves;

public WorldGenGrapeTree(boolean par1)
{
this(par1, 5, 0, 0, false);
}

public WorldGenGrapeTree(boolean par1, int par2, int par3, int par4, boolean par5)
{
super(par1);
this.minTreeHeight = 5;
this.metaWood = par3;
this.metaLeaves = mod_Ores.GrapesBlock.blockID;
this.vinesGrow = true;
}

public boolean generate(World par1World, Random par2Random, int par3, int par4, int par5)
{
int l = par2Random.nextInt(3) + this.minTreeHeight;
boolean flag = true;

if (par4 >= 1 && par4 + l + 1 <= 256)
{
int i1;
byte b0;
int j1;
int k1;

for (i1 = par4; i1 <= par4 + 1 + l; ++i1)
{
b0 = 1;

if (i1 == par4)
{
b0 = 0;
}

if (i1 >= par4 + 1 + l - 2)
{
b0 = 2;
}

for (int l1 = par3 - b0; l1 <= par3 + b0 && flag; ++l1)
{
for (j1 = par5 - b0; j1 <= par5 + b0 && flag; ++j1)
{
if (i1 >= 0 && i1 < 256)
{
k1 = par1World.getBlockId(l1, i1, j1);

Block block = Block.blocksList[k1];

if (k1 != 0 && !block.isLeaves(par1World, l1, i1, j1) &&
k1 != mod_Ores.LateriteGrass.blockID &&
k1 != mod_Ores.LateriteDirt.blockID &&
k1 != mod_Ores.Slate.blockID &&
k1 != mod_Ores.Porphyry.blockID &&
!block.isWood(par1World, l1, i1, j1))
{
flag = false;
}
}
else
{
flag = false;
}
}
}
}

if (!flag)
{
return false;
}
else
{
i1 = par1World.getBlockId(par3, par4 - 1, par5);
Block soil = Block.blocksList[i1];
boolean isSoil = (soil != null && soil.canSustainPlant(par1World, par3, par4 - 1, par5, ForgeDirection.UP, (BlockSapling)Block.sapling));

if (isSoil && par4 < 256 - l - 1)
{
soil.onPlantGrow(par1World, par3, par4 - 1, par5, par3, par4, par5);
b0 = 3;
byte b1 = 0;
int i2;
int j2;
int k2;

for (j1 = par4 - b0 + l; j1 <= par4 + l; ++j1)
{
k1 = j1 - (par4 + l);
i2 = b1 + 1 - k1 / 2;

for (j2 = par3 - i2; j2 <= par3 + i2; ++j2)
{
k2 = j2 - par3;

for (int l2 = par5 - i2; l2 <= par5 + i2; ++l2)
{
int i3 = l2 - par5;

if (Math.abs(k2) != i2 || Math.abs(i3) != i2 || par2Random.nextInt(2) != 0 && k1 != 0)
{
int j3 = par1World.getBlockId(j2, j1, l2);
Block block = Block.blocksList[j3];

if (block == null || block.canBeReplacedByLeaves(par1World, j2, j1, l2))
{
this.setBlockAndMetadata(par1World, j2, j1, l2, mod_Ores.GrapesBlock.blockID, this.metaLeaves);
}
}
}
}
}

for (j1 = 0; j1 < l; ++j1)
{
k1 = par1World.getBlockId(par3, par4 + j1, par5);

Block block = Block.blocksList[k1];

if (k1 == 0 || block == null || block.isLeaves(par1World, par3, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5, Block.wood.blockID, this.metaWood);

if (this.vinesGrow && j1 > 0)
{
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3 - 1, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3 - 1, par4 + j1, par5, mod_Ores.Baneberry.blockID, 2);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3 + 1, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3 + 1, par4 + j1, par5, mod_Ores.Blackberry.blockID, 2);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 - 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 - 1, mod_Ores.Blueberry.blockID, 1);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Cranberry.blockID, 1);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Razzberry.blockID, 1);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Raspberry.blockID, 2);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Strawberry.blockID, ;
}
}
}
}

if (this.vinesGrow)
{
for (j1 = par4 - 3 + l; j1 <= par4 + l; ++j1)
{
k1 = j1 - (par4 + l);
i2 = 2 - k1 / 2;

for (j2 = par3 - i2; j2 <= par3 + i2; ++j2)
{
for (k2 = par5 - i2; k2 <= par5 + i2; ++k2)
{
Block block = Block.blocksList[par1World.getBlockId(j2, j1, k2)];
if (block != null && block.isLeaves(par1World, j2, j1, k2))
{
if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2 - 1, j1, k2) == 0)
{
this.growVines(par1World, j2 - 1, j1, k2, ;
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2 + 1, j1, k2) == 0)
{
this.growVines(par1World, j2 + 1, j1, k2, 2);
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2, j1, k2 - 1) == 0)
{
this.growVines(par1World, j2, j1, k2 - 1, 1);
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2, j1, k2 + 1) == 0)
{
this.growVines(par1World, j2, j1, k2 + 1, 4);
}
}
}
}
}

if (par2Random.nextInt(5) == 0 && l > 5)
{
for (j1 = 0; j1 < 2; ++j1)
{
for (k1 = 0; k1 < 4; ++k1)
{
if (par2Random.nextInt(4 - j1) == 0)
{
i2 = par2Random.nextInt(3);
this.setBlockAndMetadata(par1World, par3 + Direction.offsetX[Direction.footInvisibleFaceRemap[k1]], par4 + l - 5 + j1, par5 + Direction.offsetZ[Direction.footInvisibleFaceRemap[k1]], Block.cocoaPlant.blockID, i2 << 2 | k1);
}
}
}
}
}

return true;
}
else
{
return false;
}
}
}
else
{
return false;
}
}

/**
* Grows vines downward from the given block for a given length. Args: World, x, starty, z, vine-length
*/
private void growVines(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Baneberry.blockID, par5);
int i1 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i1 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Baneberry.blockID, par5);
--i1;

}
}
private void growVines1(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Blueberry.blockID, par5);
int i3 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i3 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Blueberry.blockID, par5);
--i3;
}

}


private void growVines2(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Cranberry.blockID, par5);
int i4 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i4 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Cranberry.blockID, par5);
--i4;
}
}


private void growVines3(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Raspberry.blockID, par5);
int i5 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i5 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Raspberry.blockID, par5);
--i5;
}
}

private void growVines4(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Razzberry.blockID, par5);
int i6 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i6 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Razzberry.blockID, par5);
--i6;
}
}

private void growVines5(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Strawberry.blockID, par5);
int i7 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i7 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Strawberry.blockID, par5);
--i7;
}
}

}

 

 

 

ChunkProviderMarona

 

 


package Mod_Ores;

import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.DUNGEON;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.FIRE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.GLOWSTONE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.NETHER_LAVA;

import java.util.List;
import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.BlockSand;
import net.minecraft.entity.EnumCreatureType;
import net.minecraft.util.IProgressUpdate;
import net.minecraft.world.ChunkPosition;
import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.chunk.Chunk;
import net.minecraft.world.chunk.IChunkProvider;
import net.minecraft.world.gen.MapGenBase;
import net.minecraft.world.gen.MapGenCavesHell;
import net.minecraft.world.gen.NoiseGeneratorOctaves;
import net.minecraft.world.gen.feature.WorldGenDungeons;
import net.minecraft.world.gen.feature.WorldGenFire;
import net.minecraft.world.gen.feature.WorldGenFlowers;
import net.minecraft.world.gen.feature.WorldGenGlowStone1;
import net.minecraft.world.gen.feature.WorldGenGlowStone2;
import net.minecraft.world.gen.feature.WorldGenHellLava;
import net.minecraft.world.gen.feature.WorldGenMinable;
import net.minecraft.world.gen.structure.MapGenNetherBridge;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.Event.Result;
import net.minecraftforge.event.terraingen.ChunkProviderEvent;
import net.minecraftforge.event.terraingen.DecorateBiomeEvent;
import net.minecraftforge.event.terraingen.PopulateChunkEvent;
import static net.minecraftforge.event.terraingen.DecorateBiomeEvent.Decorate.EventType.*;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.*;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.*;
import net.minecraftforge.event.terraingen.TerrainGen;

public class ChunkProviderMarona implements IChunkProvider
{
//NETHER SOUL FOREST IDEA

private Random soulRNG;

/** A NoiseGeneratorOctaves used in generating nether terrain */
private NoiseGeneratorOctaves netherNoiseGen1;
private NoiseGeneratorOctaves netherNoiseGen2;
private NoiseGeneratorOctaves netherNoiseGen3;
public NoiseGeneratorOctaves mobSpawnerNoise;

/** Determines whether lateriteGrass or porphyry can be generated at a location */
private NoiseGeneratorOctaves lateriteGrassPorphyryNoise;

/**
* Determines whether something other than porphyry can be generated at a location
*/
private NoiseGeneratorOctaves porphyryExclusivityNoiseGen;
public NoiseGeneratorOctaves netherNoiseGen6;
public NoiseGeneratorOctaves netherNoiseGen7;

/** The biomes that are used to generate the chunk */
private BiomeGenBase[] biomesForGeneration;

/** Is the world that the nether is getting generated. */
private World worldObj;
private double[] noiseField;
public MapGenNetherBridge genNetherBridge = new MapGenNetherBridge();

/**
* Holds the noise used to determine whether lateriteGrass can be generated at a location
*/
private double[] lateriteGrassNoise = new double[256];
private double[] porphyryNoise = new double[256];

/**
* Holds the noise used to determine whether something other than porphyry can be generated at a location
*/
private double[] porphyryExclusivityNoise = new double[256];
private MapGenBase netherCaveGenerator = new MapGenCavesHell();
double[] noiseData1;
double[] noiseData2;
double[] noiseData3;
double[] noiseData4;
double[] noiseData5;

private Object theBiomeDecorator;

public ChunkProviderMarona(World par1World, long par2)
{
this.worldObj = par1World;
this.soulRNG = new Random(par2);
this.netherNoiseGen1 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.netherNoiseGen2 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.netherNoiseGen3 = new NoiseGeneratorOctaves(this.soulRNG, ;
this.lateriteGrassPorphyryNoise = new NoiseGeneratorOctaves(this.soulRNG, 4);
this.porphyryExclusivityNoiseGen = new NoiseGeneratorOctaves(this.soulRNG, 4);
this.netherNoiseGen6 = new NoiseGeneratorOctaves(this.soulRNG, 10);
this.netherNoiseGen7 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.mobSpawnerNoise = new NoiseGeneratorOctaves(this.soulRNG, ;

NoiseGeneratorOctaves[] noiseGens = {netherNoiseGen1, netherNoiseGen2, netherNoiseGen3, lateriteGrassPorphyryNoise, porphyryExclusivityNoiseGen, netherNoiseGen6, netherNoiseGen7, mobSpawnerNoise};
noiseGens = TerrainGen.getModdedNoiseGenerators(par1World, this.soulRNG, noiseGens);
this.netherNoiseGen1 = noiseGens[0];
this.netherNoiseGen2 = noiseGens[1];
this.netherNoiseGen3 = noiseGens[2];
this.lateriteGrassPorphyryNoise = noiseGens[3];
this.porphyryExclusivityNoiseGen = noiseGens[4];
this.netherNoiseGen6 = noiseGens[5];
this.netherNoiseGen7 = noiseGens[6];
this.mobSpawnerNoise = noiseGens[7];
}


/**
* Generates the shape of the terrain in the nether.
*/
public void generateNetherTerrain(int par1, int par2, byte[] par3ArrayOfByte)
{
byte b0 = 4;
byte b1 = 32;
int k = b0 + 1;
byte b2 = 17;
int l = b0 + 1;
this.noiseField = this.initializeNoiseField(this.noiseField, par1 * b0, 0, par2 * b0, k, b2, l);

for (int i1 = 0; i1 < b0; ++i1)
{
for (int j1 = 0; j1 < b0; ++j1)
{
for (int k1 = 0; k1 < 16; ++k1)
{
double d0 = 0.125D;
double d1 = this.noiseField[((i1 + 0) * l + j1 + 0) * b2 + k1 + 0];
double d2 = this.noiseField[((i1 + 0) * l + j1 + 1) * b2 + k1 + 0];
double d3 = this.noiseField[((i1 + 1) * l + j1 + 0) * b2 + k1 + 0];
double d4 = this.noiseField[((i1 + 1) * l + j1 + 1) * b2 + k1 + 0];
double d5 = (this.noiseField[((i1 + 0) * l + j1 + 0) * b2 + k1 + 1] - d1) * d0;
double d6 = (this.noiseField[((i1 + 0) * l + j1 + 1) * b2 + k1 + 1] - d2) * d0;
double d7 = (this.noiseField[((i1 + 1) * l + j1 + 0) * b2 + k1 + 1] - d3) * d0;
double d8 = (this.noiseField[((i1 + 1) * l + j1 + 1) * b2 + k1 + 1] - d4) * d0;

for (int l1 = 0; l1 < 8; ++l1)
{
double d9 = 0.25D;
double d10 = d1;
double d11 = d2;
double d12 = (d3 - d1) * d9;
double d13 = (d4 - d2) * d9;

for (int i2 = 0; i2 < 4; ++i2)
{
int j2 = i2 + i1 * 4 << 11 | 0 + j1 * 4 << 7 | k1 * 8 + l1;
short short1 = 128;
double d14 = 0.25D;
double d15 = d10;
double d16 = (d11 - d10) * d14;

for (int k2 = 0; k2 < 4; ++k2)
{
int l2 = 0;

if (k1 * 8 + l1 < b1)
{
l2 = Block.waterStill.blockID;
}

if (d15 > 0.0D)
{
l2 = (byte)mod_Ores.Porphyry.blockID;
}

par3ArrayOfByte[j2] = (byte)l2;
j2 += short1;
d15 += d16;
}

d10 += d12;
d11 += d13;
}

d1 += d5;
d2 += d6;
d3 += d7;
d4 += d8;
}
}
}
}
}

/**
* name based on ChunkProviderGenerate
*/
public void replaceBlocksForBiome(int par1, int par2, byte[] par3ArrayOfByte, BiomeGenBase[] par4ArrayOfBiomeGenBase)
{
ChunkProviderEvent.ReplaceBiomeBlocks event = new ChunkProviderEvent.ReplaceBiomeBlocks(this, par1, par2, par3ArrayOfByte, null);
MinecraftForge.EVENT_BUS.post(event);
if (event.getResult() == Result.DENY) return;

byte b0 = 64;
double d0 = 0.03125D;
this.lateriteGrassNoise = this.lateriteGrassPorphyryNoise.generateNoiseOctaves(this.lateriteGrassNoise, par1 * 16, par2 * 16, 0, 16, 16, 1, d0, d0, 1.0D);
this.porphyryNoise = this.lateriteGrassPorphyryNoise.generateNoiseOctaves(this.porphyryNoise, par1 * 16, 109, par2 * 16, 16, 1, 16, d0, 1.0D, d0);
this.porphyryExclusivityNoise = this.porphyryExclusivityNoiseGen.generateNoiseOctaves(this.porphyryExclusivityNoise, par1 * 16, par2 * 16, 0, 16, 16, 1, d0 * 2.0D, d0 * 2.0D, d0 * 2.0D);

for (int k = 0; k < 16; ++k)
{
for (int l = 0; l < 16; ++l)
{
BiomeGenBase biomegenbase = par4ArrayOfBiomeGenBase[l + k * 16];
boolean flag = this.lateriteGrassNoise[k + l * 16] + this.soulRNG.nextDouble() * 0.2D > 0.0D;
boolean flag1 = this.porphyryNoise[k + l * 16] + this.soulRNG.nextDouble() * 0.2D > 0.0D;
int i1 = (int)(this.porphyryExclusivityNoise[k + l * 16] / 3.0D + 3.0D + this.soulRNG.nextDouble() * 0.25D);
int j1 = -1;
byte b1 = biomegenbase.topBlock;
byte b2 = biomegenbase.fillerBlock;

for (int k1 = 127; k1 >= 0; --k1)
{
int l1 = (l * 16 + k) * 128 + k1;

if (k1 < 127 - this.soulRNG.nextInt(5) && k1 > 0 + this.soulRNG.nextInt(5))
{
byte b3 = par3ArrayOfByte[l1];

if (b3 == 0)
{
j1 = -1;
}
else if (b3 == (byte)mod_Ores.Porphyry.blockID)
{
if (j1 == -1)
{
if (i1 <= 0)
{
b1 = 0;
b2 = (byte)mod_Ores.Porphyry.blockID;
}
else if (k1 >= b0 - 4 && k1 <= b0 + 1)
{
b1 = biomegenbase.topBlock;
b2 = biomegenbase.fillerBlock;

if (flag1)
{
b1 = (byte)mod_Ores.LateriteGrass.blockID;
}

if (flag1)
{
b2 = (byte)mod_Ores.Porphyry.blockID;
}

if (flag)
{
b1 = (byte)mod_Ores.LateriteGrass.blockID;
}

if (flag)
{
b2 = (byte)mod_Ores.Slate.blockID;
}
}

if (k1 < b0 && b1 == 0)
{
b1 = (byte)Block.waterStill.blockID;
}

j1 = i1;

if (k1 >= b0 - 1)
{
par3ArrayOfByte[l1] = b1;
}
else
{
par3ArrayOfByte[l1] = b2;
}
}
else if (j1 > 0)
{
--j1;
par3ArrayOfByte[l1] = b2;
}
}
}
else
{
par3ArrayOfByte[l1] = (byte)Block.bedrock.blockID;
}
}
}
}
}

/**
* loads or generates the chunk at the chunk location specified
*/
public Chunk loadChunk(int par1, int par2)
{
return this.provideChunk(par1, par2);
}

/**
* Will return back a chunk, if it doesn't exist and its not a MP client it will generates all the blocks for the
* specified chunk from the map seed and chunk seed
*/
@Override
public Chunk provideChunk(int par1, int par2)
{
this.soulRNG.setSeed((long)par1 * 341873128712L + (long)par2 * 132897987541L);
byte[] abyte = new byte[32768];
this.generateNetherTerrain(par1, par2, abyte);
this.biomesForGeneration = this.worldObj.getWorldChunkManager().loadBlockGeneratorData(this.biomesForGeneration, par1 * 16, par2 * 16, 16, 16);
this.replaceBlocksForBiome(par1, par2, abyte, this.biomesForGeneration);
this.netherCaveGenerator.generate(this, this.worldObj, par1, par2, abyte);
this.genNetherBridge.generate(this, this.worldObj, par1, par2, abyte);
Chunk chunk = new Chunk(this.worldObj, abyte, par1, par2);
BiomeGenBase[] abiomegenbase = this.worldObj.getWorldChunkManager().loadBlockGeneratorData((BiomeGenBase[])null, par1 * 16, par2 * 16, 16, 16);
byte[] abyte1 = chunk.getBiomeArray();

for (int k = 0; k < abyte1.length; ++k)
{
abyte1[k] = (byte)abiomegenbase[k].biomeID;
}

chunk.resetRelightChecks();
return chunk;
}

public void decorate(World par1World, Random par2Random, int par3, int par4)
{
((BiomeGenBase) this.theBiomeDecorator).decorate(par1World, par2Random, par3, par4);
}
/**
* generates a subset of the level's terrain data. Takes 7 arguments: the [empty] noise array, the position, and the
* size.
*/
private double[] initializeNoiseField(double[] par1ArrayOfDouble, int par2, int par3, int par4, int par5, int par6, int par7)
{
ChunkProviderEvent.InitNoiseField event = new ChunkProviderEvent.InitNoiseField(this, par1ArrayOfDouble, par2, par3, par4, par5, par6, par7);
MinecraftForge.EVENT_BUS.post(event);
if (event.getResult() == Result.DENY) return event.noisefield;
if (par1ArrayOfDouble == null)
{
par1ArrayOfDouble = new double[par5 * par6 * par7];
}

double d0 = 684.412D;
double d1 = 2053.236D;
this.noiseData4 = this.netherNoiseGen6.generateNoiseOctaves(this.noiseData4, par2, par3, par4, par5, 1, par7, 1.0D, 0.0D, 1.0D);
this.noiseData5 = this.netherNoiseGen7.generateNoiseOctaves(this.noiseData5, par2, par3, par4, par5, 1, par7, 100.0D, 0.0D, 100.0D);
this.noiseData1 = this.netherNoiseGen3.generateNoiseOctaves(this.noiseData1, par2, par3, par4, par5, par6, par7, d0 / 80.0D, d1 / 60.0D, d0 / 80.0D);
this.noiseData2 = this.netherNoiseGen1.generateNoiseOctaves(this.noiseData2, par2, par3, par4, par5, par6, par7, d0, d1, d0);
this.noiseData3 = this.netherNoiseGen2.generateNoiseOctaves(this.noiseData3, par2, par3, par4, par5, par6, par7, d0, d1, d0);
int k1 = 0;
int l1 = 0;
double[] adouble1 = new double[par6];
int i2;

for (i2 = 0; i2 < par6; ++i2)
{
adouble1[i2] = Math.cos((double)i2 * Math.PI * 6.0D / (double)par6) * 2.0D;
double d2 = (double)i2;

if (i2 > par6 / 2)
{
d2 = (double)(par6 - 1 - i2);
}

if (d2 < 4.0D)
{
d2 = 4.0D - d2;
adouble1[i2] -= d2 * d2 * d2 * 10.0D;
}
}

for (i2 = 0; i2 < par5; ++i2)
{
for (int j2 = 0; j2 < par7; ++j2)
{
double d3 = (this.noiseData4[l1] + 256.0D) / 512.0D;

if (d3 > 1.0D)
{
d3 = 1.0D;
}

double d4 = 0.0D;
double d5 = this.noiseData5[l1] / 8000.0D;

if (d5 < 0.0D)
{
d5 = -d5;
}

d5 = d5 * 3.0D - 3.0D;

if (d5 < 0.0D)
{
d5 /= 2.0D;

if (d5 < -1.0D)
{
d5 = -1.0D;
}

d5 /= 1.4D;
d5 /= 2.0D;
d3 = 0.0D;
}
else
{
if (d5 > 1.0D)
{
d5 = 1.0D;
}

d5 /= 6.0D;
}

d3 += 0.5D;
d5 = d5 * (double)par6 / 16.0D;
++l1;

for (int k2 = 0; k2 < par6; ++k2)
{
double d6 = 0.0D;
double d7 = adouble1[k2];
double d8 = this.noiseData2[k1] / 512.0D;
double d9 = this.noiseData3[k1] / 512.0D;
double d10 = (this.noiseData1[k1] / 10.0D + 1.0D) / 2.0D;

if (d10 < 0.0D)
{
d6 = d8;
}
else if (d10 > 1.0D)
{
d6 = d9;
}
else
{
d6 = d8 + (d9 - d8) * d10;
}

d6 -= d7;
double d11;

if (k2 > par6 - 4)
{
d11 = (double)((float)(k2 - (par6 - 4)) / 3.0F);
d6 = d6 * (1.0D - d11) + -10.0D * d11;
}

if ((double)k2 < d4)
{
d11 = (d4 - (double)k2) / 4.0D;

if (d11 < 0.0D)
{
d11 = 0.0D;
}

if (d11 > 1.0D)
{
d11 = 1.0D;
}

d6 = d6 * (1.0D - d11) + -10.0D * d11;
}

par1ArrayOfDouble[k1] = d6;
++k1;
}
}
}

return par1ArrayOfDouble;
}

/**
* Checks to see if a chunk exists at x, y
*/
public boolean chunkExists(int par1, int par2)
{
return true;
}

/**
* Populates chunk with ores etc etc
*/
public void populate(IChunkProvider par1IChunkProvider, int par2, int par3)
{
BlockSand.fallInstantly = true;

MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Pre(par1IChunkProvider, worldObj, soulRNG, par2, par3, false));

int k = par2 * 16;
int l = par3 * 16;
//this.genNetherBridge.generateStructuresInChunk(this.worldObj, this.soulRNG, par2, par3);
int i1;
int j1;
int k1;
int l1 = 0;

boolean doGen = TerrainGen.populate(par1IChunkProvider, worldObj, soulRNG, par2, par3, false, NETHER_LAVA);
for (i1 = 0; doGen && i1 < 8; ++i1)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128) + 4;
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenHellLava(Block.lavaMoving.blockID, false)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.populate(par1IChunkProvider, worldObj, soulRNG, par2, par3, false, DUNGEON);
for (i1 = 0; doGen && i1 < 8; ++i1)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenSoulForestDungeons()).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

MinecraftForge.EVENT_BUS.post(new DecorateBiomeEvent.Pre(worldObj, soulRNG, k, l));

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, TREE);
for (int i = 0; i < 9; ++i)
{
j1 = k + soulRNG.nextInt(16);
k1 = soulRNG.nextInt(128);
l1 = l + soulRNG.nextInt(16);
(new WorldGenGrapeTree(true)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

i1 = this.soulRNG.nextInt(this.soulRNG.nextInt(10) + 1) + 1;
int i2;

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, SHROOM);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(Block.mushroomBrown.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, SHROOM);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(Block.mushroomRed.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, FLOWERS);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(mod_Ores.plantCantaloupe.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

WorldGenMinable worldgenminable;
int j2;

for (k1 = 0; k1 < 16; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
new WorldGenMinable(mod_Ores.Amazoniteore.blockID, 4, mod_Ores.Porphyry.blockID).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}
for (k1 = 0; k1 < 8; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
new WorldGenMinable(mod_Ores.Amethystore.blockID, 3, mod_Ores.Porphyry.blockID).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}

for (k1 = 0; k1 < 16; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
(new WorldGenHellLava(Block.waterMoving.blockID, true)).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}

MinecraftForge.EVENT_BUS.post(new DecorateBiomeEvent.Post(worldObj, soulRNG, k, l));
MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Post(par1IChunkProvider, worldObj, soulRNG, par2, par3, false));

BlockSand.fallInstantly = false;
}

/**
* Two modes of operation: if passed true, save all Chunks in one go. If passed false, save up to two chunks.
* Return true if all chunks have been saved.
*/
public boolean saveChunks(boolean par1, IProgressUpdate par2IProgressUpdate)
{
return true;
}

/**
* Unloads chunks that are marked to be unloaded. This is not guaranteed to unload every such chunk.
*/
public boolean unloadQueuedChunks()
{
return false;
}

/**
* Returns if the IChunkProvider supports saving.
*/
public boolean canSave()
{
return true;
}

/**
* Converts the instance data to a readable string.
*/
public String makeString()
{
return "SoulForestLevelSource";
}

/**
* Returns a list of creatures of the specified type that can spawn at the given location.
*/
public List getPossibleCreatures(EnumCreatureType par1EnumCreatureType, int par2, int par3, int par4)
{
if (par1EnumCreatureType == EnumCreatureType.monster && this.genNetherBridge.hasStructureAt(par2, par3, par4))
{
return this.genNetherBridge.getSpawnList();
}
else
{
BiomeGenBase biomegenbase = this.worldObj.getBiomeGenForCoords(par2, par4);
return biomegenbase == null ? null : biomegenbase.getSpawnableList(par1EnumCreatureType);
}
}

/**
* Returns the location of the closest structure of the specified type. If not found returns null.
*/
public ChunkPosition findClosestStructure(World par1World, String par2Str, int par3, int par4, int par5)
{
return null;
}

public int getLoadedChunkCount()
{
return 0;
}

public void recreateStructures(int par1, int par2)
{
//this.genNetherBridge.generate(this, this.worldObj, par1, par2, (byte[])null);
}
}

 

 

 

BiomeGenSoulForest

 

 


package Mod_Ores;

import java.util.Random;
import net.minecraft.block.Block;
import net.minecraft.entity.passive.EntityWolf;
import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.biome.SpawnListEntry;
import net.minecraft.world.gen.feature.WorldGenVines;

public class BiomeGenSoulForest extends BiomeGenBase
{
public BiomeGenSoulForest(int par1)
{
super(par1);
this.topBlock = (byte)mod_Ores.LateriteGrass.blockID;
this.fillerBlock = (byte)mod_Ores.LateriteDirt.blockID;

//spawnableCreatureList.add(new SpawnListEntry(EntityWolf.class, 5, 4, 4));
theBiomeDecorator.baneberryvineperchunk= 3;
theBiomeDecorator.blackberryvineperchunk= 3;
theBiomeDecorator.blueberryvineperchunk= 6;
theBiomeDecorator.cranberryvineperchunk= 4;
theBiomeDecorator.raspberryvineperchunk= 5;
theBiomeDecorator.razzberryvineperchunk= 5;
theBiomeDecorator.strawberryvineperchunk= 8;
theBiomeDecorator.flowersPerChunk = 30;
theBiomeDecorator.grapetreeperchunk = 10;
theBiomeDecorator.cantaloupeperchunk = 20;
temperature = 2.0F;
}


public void decorate(World par1World, Random par2Random, int par3, int par4)
{
super.decorate(par1World, par2Random, par3, par4);
trees(par1World, par2Random, par3, par4);
}

public void trees(World par2World, Random par3Random, int par5, int par6)
{
for(int i = 0; i < 20; i++)
{
int RandPosX = par5 + par3Random.nextInt(16);
int RandPosY = par3Random.nextInt(164);
int RandPosZ = par6 + par3Random.nextInt(16);
(new WorldGenGrapeTree(true)).generate(par2World, par3Random, RandPosX, RandPosY, RandPosZ);
}
}

}

 

 

 

Thanks for taking the time to read/help!

Link to comment
Share on other sites

Hi all, i have generated a custom dimension like the nether, but with custom grass and dirt and some stone types. Also i have set the sky to normal and the light level in my dimension is level 15 in most of the places.

But i can't get my trees to spawn there, any help is great!

I use forge v7.7.1 and mcp 7.44

 

WorldGenGrapeTree:

 

 


package Mod_Ores;

import java.util.Random;
import net.minecraft.block.Block;
import net.minecraft.block.BlockSapling;
import net.minecraft.util.Direction;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenerator;
import net.minecraftforge.common.ForgeDirection;

public class WorldGenGrapeTree extends WorldGenerator
{
/** The minimum height of a generated tree. */
private final int minTreeHeight;

/** True if this tree should grow Vines. */
private final boolean vinesGrow;

/** The metadata value of the wood to use in tree generation. */
private final int metaWood;

/** The metadata value of the leaves to use in tree generation. */
private final int metaLeaves;

public WorldGenGrapeTree(boolean par1)
{
this(par1, 5, 0, 0, false);
}

public WorldGenGrapeTree(boolean par1, int par2, int par3, int par4, boolean par5)
{
super(par1);
this.minTreeHeight = 5;
this.metaWood = par3;
this.metaLeaves = mod_Ores.GrapesBlock.blockID;
this.vinesGrow = true;
}

public boolean generate(World par1World, Random par2Random, int par3, int par4, int par5)
{
int l = par2Random.nextInt(3) + this.minTreeHeight;
boolean flag = true;

if (par4 >= 1 && par4 + l + 1 <= 256)
{
int i1;
byte b0;
int j1;
int k1;

for (i1 = par4; i1 <= par4 + 1 + l; ++i1)
{
b0 = 1;

if (i1 == par4)
{
b0 = 0;
}

if (i1 >= par4 + 1 + l - 2)
{
b0 = 2;
}

for (int l1 = par3 - b0; l1 <= par3 + b0 && flag; ++l1)
{
for (j1 = par5 - b0; j1 <= par5 + b0 && flag; ++j1)
{
if (i1 >= 0 && i1 < 256)
{
k1 = par1World.getBlockId(l1, i1, j1);

Block block = Block.blocksList[k1];

if (k1 != 0 && !block.isLeaves(par1World, l1, i1, j1) &&
k1 != mod_Ores.LateriteGrass.blockID &&
k1 != mod_Ores.LateriteDirt.blockID &&
k1 != mod_Ores.Slate.blockID &&
k1 != mod_Ores.Porphyry.blockID &&
!block.isWood(par1World, l1, i1, j1))
{
flag = false;
}
}
else
{
flag = false;
}
}
}
}

if (!flag)
{
return false;
}
else
{
i1 = par1World.getBlockId(par3, par4 - 1, par5);
Block soil = Block.blocksList[i1];
boolean isSoil = (soil != null && soil.canSustainPlant(par1World, par3, par4 - 1, par5, ForgeDirection.UP, (BlockSapling)Block.sapling));

if (isSoil && par4 < 256 - l - 1)
{
soil.onPlantGrow(par1World, par3, par4 - 1, par5, par3, par4, par5);
b0 = 3;
byte b1 = 0;
int i2;
int j2;
int k2;

for (j1 = par4 - b0 + l; j1 <= par4 + l; ++j1)
{
k1 = j1 - (par4 + l);
i2 = b1 + 1 - k1 / 2;

for (j2 = par3 - i2; j2 <= par3 + i2; ++j2)
{
k2 = j2 - par3;

for (int l2 = par5 - i2; l2 <= par5 + i2; ++l2)
{
int i3 = l2 - par5;

if (Math.abs(k2) != i2 || Math.abs(i3) != i2 || par2Random.nextInt(2) != 0 && k1 != 0)
{
int j3 = par1World.getBlockId(j2, j1, l2);
Block block = Block.blocksList[j3];

if (block == null || block.canBeReplacedByLeaves(par1World, j2, j1, l2))
{
this.setBlockAndMetadata(par1World, j2, j1, l2, mod_Ores.GrapesBlock.blockID, this.metaLeaves);
}
}
}
}
}

for (j1 = 0; j1 < l; ++j1)
{
k1 = par1World.getBlockId(par3, par4 + j1, par5);

Block block = Block.blocksList[k1];

if (k1 == 0 || block == null || block.isLeaves(par1World, par3, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5, Block.wood.blockID, this.metaWood);

if (this.vinesGrow && j1 > 0)
{
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3 - 1, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3 - 1, par4 + j1, par5, mod_Ores.Baneberry.blockID, 2);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3 + 1, par4 + j1, par5))
{
this.setBlockAndMetadata(par1World, par3 + 1, par4 + j1, par5, mod_Ores.Blackberry.blockID, 2);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 - 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 - 1, mod_Ores.Blueberry.blockID, 1);
}

if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Cranberry.blockID, 1);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Razzberry.blockID, 1);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Raspberry.blockID, 2);
}
if (par2Random.nextInt(3) > 0 && par1World.isAirBlock(par3, par4 + j1, par5 + 1))
{
this.setBlockAndMetadata(par1World, par3, par4 + j1, par5 + 1, mod_Ores.Strawberry.blockID, ;
}
}
}
}

if (this.vinesGrow)
{
for (j1 = par4 - 3 + l; j1 <= par4 + l; ++j1)
{
k1 = j1 - (par4 + l);
i2 = 2 - k1 / 2;

for (j2 = par3 - i2; j2 <= par3 + i2; ++j2)
{
for (k2 = par5 - i2; k2 <= par5 + i2; ++k2)
{
Block block = Block.blocksList[par1World.getBlockId(j2, j1, k2)];
if (block != null && block.isLeaves(par1World, j2, j1, k2))
{
if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2 - 1, j1, k2) == 0)
{
this.growVines(par1World, j2 - 1, j1, k2, ;
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2 + 1, j1, k2) == 0)
{
this.growVines(par1World, j2 + 1, j1, k2, 2);
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2, j1, k2 - 1) == 0)
{
this.growVines(par1World, j2, j1, k2 - 1, 1);
}

if (par2Random.nextInt(4) == 0 && par1World.getBlockId(j2, j1, k2 + 1) == 0)
{
this.growVines(par1World, j2, j1, k2 + 1, 4);
}
}
}
}
}

if (par2Random.nextInt(5) == 0 && l > 5)
{
for (j1 = 0; j1 < 2; ++j1)
{
for (k1 = 0; k1 < 4; ++k1)
{
if (par2Random.nextInt(4 - j1) == 0)
{
i2 = par2Random.nextInt(3);
this.setBlockAndMetadata(par1World, par3 + Direction.offsetX[Direction.footInvisibleFaceRemap[k1]], par4 + l - 5 + j1, par5 + Direction.offsetZ[Direction.footInvisibleFaceRemap[k1]], Block.cocoaPlant.blockID, i2 << 2 | k1);
}
}
}
}
}

return true;
}
else
{
return false;
}
}
}
else
{
return false;
}
}

/**
* Grows vines downward from the given block for a given length. Args: World, x, starty, z, vine-length
*/
private void growVines(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Baneberry.blockID, par5);
int i1 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i1 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Baneberry.blockID, par5);
--i1;

}
}
private void growVines1(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Blueberry.blockID, par5);
int i3 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i3 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Blueberry.blockID, par5);
--i3;
}

}


private void growVines2(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Cranberry.blockID, par5);
int i4 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i4 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Cranberry.blockID, par5);
--i4;
}
}


private void growVines3(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Raspberry.blockID, par5);
int i5 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i5 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Raspberry.blockID, par5);
--i5;
}
}

private void growVines4(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Razzberry.blockID, par5);
int i6 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i6 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Razzberry.blockID, par5);
--i6;
}
}

private void growVines5(World par1World, int par2, int par3, int par4, int par5)
{
this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Strawberry.blockID, par5);
int i7 = 4;

while (true)
{
--par3;

if (par1World.getBlockId(par2, par3, par4) != 0 || i7 <= 0)
{
return;
}

this.setBlockAndMetadata(par1World, par2, par3, par4, mod_Ores.Strawberry.blockID, par5);
--i7;
}
}

}

 

 

 

ChunkProviderMarona

 

 


package Mod_Ores;

import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.DUNGEON;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.FIRE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.GLOWSTONE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.NETHER_LAVA;

import java.util.List;
import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.BlockSand;
import net.minecraft.entity.EnumCreatureType;
import net.minecraft.util.IProgressUpdate;
import net.minecraft.world.ChunkPosition;
import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.chunk.Chunk;
import net.minecraft.world.chunk.IChunkProvider;
import net.minecraft.world.gen.MapGenBase;
import net.minecraft.world.gen.MapGenCavesHell;
import net.minecraft.world.gen.NoiseGeneratorOctaves;
import net.minecraft.world.gen.feature.WorldGenDungeons;
import net.minecraft.world.gen.feature.WorldGenFire;
import net.minecraft.world.gen.feature.WorldGenFlowers;
import net.minecraft.world.gen.feature.WorldGenGlowStone1;
import net.minecraft.world.gen.feature.WorldGenGlowStone2;
import net.minecraft.world.gen.feature.WorldGenHellLava;
import net.minecraft.world.gen.feature.WorldGenMinable;
import net.minecraft.world.gen.structure.MapGenNetherBridge;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.Event.Result;
import net.minecraftforge.event.terraingen.ChunkProviderEvent;
import net.minecraftforge.event.terraingen.DecorateBiomeEvent;
import net.minecraftforge.event.terraingen.PopulateChunkEvent;
import static net.minecraftforge.event.terraingen.DecorateBiomeEvent.Decorate.EventType.*;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.*;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.*;
import net.minecraftforge.event.terraingen.TerrainGen;

public class ChunkProviderMarona implements IChunkProvider
{
//NETHER SOUL FOREST IDEA

private Random soulRNG;

/** A NoiseGeneratorOctaves used in generating nether terrain */
private NoiseGeneratorOctaves netherNoiseGen1;
private NoiseGeneratorOctaves netherNoiseGen2;
private NoiseGeneratorOctaves netherNoiseGen3;
public NoiseGeneratorOctaves mobSpawnerNoise;

/** Determines whether lateriteGrass or porphyry can be generated at a location */
private NoiseGeneratorOctaves lateriteGrassPorphyryNoise;

/**
* Determines whether something other than porphyry can be generated at a location
*/
private NoiseGeneratorOctaves porphyryExclusivityNoiseGen;
public NoiseGeneratorOctaves netherNoiseGen6;
public NoiseGeneratorOctaves netherNoiseGen7;

/** The biomes that are used to generate the chunk */
private BiomeGenBase[] biomesForGeneration;

/** Is the world that the nether is getting generated. */
private World worldObj;
private double[] noiseField;
public MapGenNetherBridge genNetherBridge = new MapGenNetherBridge();

/**
* Holds the noise used to determine whether lateriteGrass can be generated at a location
*/
private double[] lateriteGrassNoise = new double[256];
private double[] porphyryNoise = new double[256];

/**
* Holds the noise used to determine whether something other than porphyry can be generated at a location
*/
private double[] porphyryExclusivityNoise = new double[256];
private MapGenBase netherCaveGenerator = new MapGenCavesHell();
double[] noiseData1;
double[] noiseData2;
double[] noiseData3;
double[] noiseData4;
double[] noiseData5;

private Object theBiomeDecorator;

public ChunkProviderMarona(World par1World, long par2)
{
this.worldObj = par1World;
this.soulRNG = new Random(par2);
this.netherNoiseGen1 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.netherNoiseGen2 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.netherNoiseGen3 = new NoiseGeneratorOctaves(this.soulRNG, ;
this.lateriteGrassPorphyryNoise = new NoiseGeneratorOctaves(this.soulRNG, 4);
this.porphyryExclusivityNoiseGen = new NoiseGeneratorOctaves(this.soulRNG, 4);
this.netherNoiseGen6 = new NoiseGeneratorOctaves(this.soulRNG, 10);
this.netherNoiseGen7 = new NoiseGeneratorOctaves(this.soulRNG, 16);
this.mobSpawnerNoise = new NoiseGeneratorOctaves(this.soulRNG, ;

NoiseGeneratorOctaves[] noiseGens = {netherNoiseGen1, netherNoiseGen2, netherNoiseGen3, lateriteGrassPorphyryNoise, porphyryExclusivityNoiseGen, netherNoiseGen6, netherNoiseGen7, mobSpawnerNoise};
noiseGens = TerrainGen.getModdedNoiseGenerators(par1World, this.soulRNG, noiseGens);
this.netherNoiseGen1 = noiseGens[0];
this.netherNoiseGen2 = noiseGens[1];
this.netherNoiseGen3 = noiseGens[2];
this.lateriteGrassPorphyryNoise = noiseGens[3];
this.porphyryExclusivityNoiseGen = noiseGens[4];
this.netherNoiseGen6 = noiseGens[5];
this.netherNoiseGen7 = noiseGens[6];
this.mobSpawnerNoise = noiseGens[7];
}


/**
* Generates the shape of the terrain in the nether.
*/
public void generateNetherTerrain(int par1, int par2, byte[] par3ArrayOfByte)
{
byte b0 = 4;
byte b1 = 32;
int k = b0 + 1;
byte b2 = 17;
int l = b0 + 1;
this.noiseField = this.initializeNoiseField(this.noiseField, par1 * b0, 0, par2 * b0, k, b2, l);

for (int i1 = 0; i1 < b0; ++i1)
{
for (int j1 = 0; j1 < b0; ++j1)
{
for (int k1 = 0; k1 < 16; ++k1)
{
double d0 = 0.125D;
double d1 = this.noiseField[((i1 + 0) * l + j1 + 0) * b2 + k1 + 0];
double d2 = this.noiseField[((i1 + 0) * l + j1 + 1) * b2 + k1 + 0];
double d3 = this.noiseField[((i1 + 1) * l + j1 + 0) * b2 + k1 + 0];
double d4 = this.noiseField[((i1 + 1) * l + j1 + 1) * b2 + k1 + 0];
double d5 = (this.noiseField[((i1 + 0) * l + j1 + 0) * b2 + k1 + 1] - d1) * d0;
double d6 = (this.noiseField[((i1 + 0) * l + j1 + 1) * b2 + k1 + 1] - d2) * d0;
double d7 = (this.noiseField[((i1 + 1) * l + j1 + 0) * b2 + k1 + 1] - d3) * d0;
double d8 = (this.noiseField[((i1 + 1) * l + j1 + 1) * b2 + k1 + 1] - d4) * d0;

for (int l1 = 0; l1 < 8; ++l1)
{
double d9 = 0.25D;
double d10 = d1;
double d11 = d2;
double d12 = (d3 - d1) * d9;
double d13 = (d4 - d2) * d9;

for (int i2 = 0; i2 < 4; ++i2)
{
int j2 = i2 + i1 * 4 << 11 | 0 + j1 * 4 << 7 | k1 * 8 + l1;
short short1 = 128;
double d14 = 0.25D;
double d15 = d10;
double d16 = (d11 - d10) * d14;

for (int k2 = 0; k2 < 4; ++k2)
{
int l2 = 0;

if (k1 * 8 + l1 < b1)
{
l2 = Block.waterStill.blockID;
}

if (d15 > 0.0D)
{
l2 = (byte)mod_Ores.Porphyry.blockID;
}

par3ArrayOfByte[j2] = (byte)l2;
j2 += short1;
d15 += d16;
}

d10 += d12;
d11 += d13;
}

d1 += d5;
d2 += d6;
d3 += d7;
d4 += d8;
}
}
}
}
}

/**
* name based on ChunkProviderGenerate
*/
public void replaceBlocksForBiome(int par1, int par2, byte[] par3ArrayOfByte, BiomeGenBase[] par4ArrayOfBiomeGenBase)
{
ChunkProviderEvent.ReplaceBiomeBlocks event = new ChunkProviderEvent.ReplaceBiomeBlocks(this, par1, par2, par3ArrayOfByte, null);
MinecraftForge.EVENT_BUS.post(event);
if (event.getResult() == Result.DENY) return;

byte b0 = 64;
double d0 = 0.03125D;
this.lateriteGrassNoise = this.lateriteGrassPorphyryNoise.generateNoiseOctaves(this.lateriteGrassNoise, par1 * 16, par2 * 16, 0, 16, 16, 1, d0, d0, 1.0D);
this.porphyryNoise = this.lateriteGrassPorphyryNoise.generateNoiseOctaves(this.porphyryNoise, par1 * 16, 109, par2 * 16, 16, 1, 16, d0, 1.0D, d0);
this.porphyryExclusivityNoise = this.porphyryExclusivityNoiseGen.generateNoiseOctaves(this.porphyryExclusivityNoise, par1 * 16, par2 * 16, 0, 16, 16, 1, d0 * 2.0D, d0 * 2.0D, d0 * 2.0D);

for (int k = 0; k < 16; ++k)
{
for (int l = 0; l < 16; ++l)
{
BiomeGenBase biomegenbase = par4ArrayOfBiomeGenBase[l + k * 16];
boolean flag = this.lateriteGrassNoise[k + l * 16] + this.soulRNG.nextDouble() * 0.2D > 0.0D;
boolean flag1 = this.porphyryNoise[k + l * 16] + this.soulRNG.nextDouble() * 0.2D > 0.0D;
int i1 = (int)(this.porphyryExclusivityNoise[k + l * 16] / 3.0D + 3.0D + this.soulRNG.nextDouble() * 0.25D);
int j1 = -1;
byte b1 = biomegenbase.topBlock;
byte b2 = biomegenbase.fillerBlock;

for (int k1 = 127; k1 >= 0; --k1)
{
int l1 = (l * 16 + k) * 128 + k1;

if (k1 < 127 - this.soulRNG.nextInt(5) && k1 > 0 + this.soulRNG.nextInt(5))
{
byte b3 = par3ArrayOfByte[l1];

if (b3 == 0)
{
j1 = -1;
}
else if (b3 == (byte)mod_Ores.Porphyry.blockID)
{
if (j1 == -1)
{
if (i1 <= 0)
{
b1 = 0;
b2 = (byte)mod_Ores.Porphyry.blockID;
}
else if (k1 >= b0 - 4 && k1 <= b0 + 1)
{
b1 = biomegenbase.topBlock;
b2 = biomegenbase.fillerBlock;

if (flag1)
{
b1 = (byte)mod_Ores.LateriteGrass.blockID;
}

if (flag1)
{
b2 = (byte)mod_Ores.Porphyry.blockID;
}

if (flag)
{
b1 = (byte)mod_Ores.LateriteGrass.blockID;
}

if (flag)
{
b2 = (byte)mod_Ores.Slate.blockID;
}
}

if (k1 < b0 && b1 == 0)
{
b1 = (byte)Block.waterStill.blockID;
}

j1 = i1;

if (k1 >= b0 - 1)
{
par3ArrayOfByte[l1] = b1;
}
else
{
par3ArrayOfByte[l1] = b2;
}
}
else if (j1 > 0)
{
--j1;
par3ArrayOfByte[l1] = b2;
}
}
}
else
{
par3ArrayOfByte[l1] = (byte)Block.bedrock.blockID;
}
}
}
}
}

/**
* loads or generates the chunk at the chunk location specified
*/
public Chunk loadChunk(int par1, int par2)
{
return this.provideChunk(par1, par2);
}

/**
* Will return back a chunk, if it doesn't exist and its not a MP client it will generates all the blocks for the
* specified chunk from the map seed and chunk seed
*/
@Override
public Chunk provideChunk(int par1, int par2)
{
this.soulRNG.setSeed((long)par1 * 341873128712L + (long)par2 * 132897987541L);
byte[] abyte = new byte[32768];
this.generateNetherTerrain(par1, par2, abyte);
this.biomesForGeneration = this.worldObj.getWorldChunkManager().loadBlockGeneratorData(this.biomesForGeneration, par1 * 16, par2 * 16, 16, 16);
this.replaceBlocksForBiome(par1, par2, abyte, this.biomesForGeneration);
this.netherCaveGenerator.generate(this, this.worldObj, par1, par2, abyte);
this.genNetherBridge.generate(this, this.worldObj, par1, par2, abyte);
Chunk chunk = new Chunk(this.worldObj, abyte, par1, par2);
BiomeGenBase[] abiomegenbase = this.worldObj.getWorldChunkManager().loadBlockGeneratorData((BiomeGenBase[])null, par1 * 16, par2 * 16, 16, 16);
byte[] abyte1 = chunk.getBiomeArray();

for (int k = 0; k < abyte1.length; ++k)
{
abyte1[k] = (byte)abiomegenbase[k].biomeID;
}

chunk.resetRelightChecks();
return chunk;
}

public void decorate(World par1World, Random par2Random, int par3, int par4)
{
((BiomeGenBase) this.theBiomeDecorator).decorate(par1World, par2Random, par3, par4);
}
/**
* generates a subset of the level's terrain data. Takes 7 arguments: the [empty] noise array, the position, and the
* size.
*/
private double[] initializeNoiseField(double[] par1ArrayOfDouble, int par2, int par3, int par4, int par5, int par6, int par7)
{
ChunkProviderEvent.InitNoiseField event = new ChunkProviderEvent.InitNoiseField(this, par1ArrayOfDouble, par2, par3, par4, par5, par6, par7);
MinecraftForge.EVENT_BUS.post(event);
if (event.getResult() == Result.DENY) return event.noisefield;
if (par1ArrayOfDouble == null)
{
par1ArrayOfDouble = new double[par5 * par6 * par7];
}

double d0 = 684.412D;
double d1 = 2053.236D;
this.noiseData4 = this.netherNoiseGen6.generateNoiseOctaves(this.noiseData4, par2, par3, par4, par5, 1, par7, 1.0D, 0.0D, 1.0D);
this.noiseData5 = this.netherNoiseGen7.generateNoiseOctaves(this.noiseData5, par2, par3, par4, par5, 1, par7, 100.0D, 0.0D, 100.0D);
this.noiseData1 = this.netherNoiseGen3.generateNoiseOctaves(this.noiseData1, par2, par3, par4, par5, par6, par7, d0 / 80.0D, d1 / 60.0D, d0 / 80.0D);
this.noiseData2 = this.netherNoiseGen1.generateNoiseOctaves(this.noiseData2, par2, par3, par4, par5, par6, par7, d0, d1, d0);
this.noiseData3 = this.netherNoiseGen2.generateNoiseOctaves(this.noiseData3, par2, par3, par4, par5, par6, par7, d0, d1, d0);
int k1 = 0;
int l1 = 0;
double[] adouble1 = new double[par6];
int i2;

for (i2 = 0; i2 < par6; ++i2)
{
adouble1[i2] = Math.cos((double)i2 * Math.PI * 6.0D / (double)par6) * 2.0D;
double d2 = (double)i2;

if (i2 > par6 / 2)
{
d2 = (double)(par6 - 1 - i2);
}

if (d2 < 4.0D)
{
d2 = 4.0D - d2;
adouble1[i2] -= d2 * d2 * d2 * 10.0D;
}
}

for (i2 = 0; i2 < par5; ++i2)
{
for (int j2 = 0; j2 < par7; ++j2)
{
double d3 = (this.noiseData4[l1] + 256.0D) / 512.0D;

if (d3 > 1.0D)
{
d3 = 1.0D;
}

double d4 = 0.0D;
double d5 = this.noiseData5[l1] / 8000.0D;

if (d5 < 0.0D)
{
d5 = -d5;
}

d5 = d5 * 3.0D - 3.0D;

if (d5 < 0.0D)
{
d5 /= 2.0D;

if (d5 < -1.0D)
{
d5 = -1.0D;
}

d5 /= 1.4D;
d5 /= 2.0D;
d3 = 0.0D;
}
else
{
if (d5 > 1.0D)
{
d5 = 1.0D;
}

d5 /= 6.0D;
}

d3 += 0.5D;
d5 = d5 * (double)par6 / 16.0D;
++l1;

for (int k2 = 0; k2 < par6; ++k2)
{
double d6 = 0.0D;
double d7 = adouble1[k2];
double d8 = this.noiseData2[k1] / 512.0D;
double d9 = this.noiseData3[k1] / 512.0D;
double d10 = (this.noiseData1[k1] / 10.0D + 1.0D) / 2.0D;

if (d10 < 0.0D)
{
d6 = d8;
}
else if (d10 > 1.0D)
{
d6 = d9;
}
else
{
d6 = d8 + (d9 - d8) * d10;
}

d6 -= d7;
double d11;

if (k2 > par6 - 4)
{
d11 = (double)((float)(k2 - (par6 - 4)) / 3.0F);
d6 = d6 * (1.0D - d11) + -10.0D * d11;
}

if ((double)k2 < d4)
{
d11 = (d4 - (double)k2) / 4.0D;

if (d11 < 0.0D)
{
d11 = 0.0D;
}

if (d11 > 1.0D)
{
d11 = 1.0D;
}

d6 = d6 * (1.0D - d11) + -10.0D * d11;
}

par1ArrayOfDouble[k1] = d6;
++k1;
}
}
}

return par1ArrayOfDouble;
}

/**
* Checks to see if a chunk exists at x, y
*/
public boolean chunkExists(int par1, int par2)
{
return true;
}

/**
* Populates chunk with ores etc etc
*/
public void populate(IChunkProvider par1IChunkProvider, int par2, int par3)
{
BlockSand.fallInstantly = true;

MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Pre(par1IChunkProvider, worldObj, soulRNG, par2, par3, false));

int k = par2 * 16;
int l = par3 * 16;
//this.genNetherBridge.generateStructuresInChunk(this.worldObj, this.soulRNG, par2, par3);
int i1;
int j1;
int k1;
int l1 = 0;

boolean doGen = TerrainGen.populate(par1IChunkProvider, worldObj, soulRNG, par2, par3, false, NETHER_LAVA);
for (i1 = 0; doGen && i1 < 8; ++i1)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128) + 4;
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenHellLava(Block.lavaMoving.blockID, false)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.populate(par1IChunkProvider, worldObj, soulRNG, par2, par3, false, DUNGEON);
for (i1 = 0; doGen && i1 < 8; ++i1)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenSoulForestDungeons()).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

MinecraftForge.EVENT_BUS.post(new DecorateBiomeEvent.Pre(worldObj, soulRNG, k, l));

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, TREE);
for (int i = 0; i < 9; ++i)
{
j1 = k + soulRNG.nextInt(16);
k1 = soulRNG.nextInt(128);
l1 = l + soulRNG.nextInt(16);
(new WorldGenGrapeTree(true)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

i1 = this.soulRNG.nextInt(this.soulRNG.nextInt(10) + 1) + 1;
int i2;

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, SHROOM);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(Block.mushroomBrown.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, SHROOM);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(Block.mushroomRed.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

doGen = TerrainGen.decorate(worldObj, soulRNG, k, l, FLOWERS);
if (doGen && this.soulRNG.nextInt(1) == 0)
{
j1 = k + this.soulRNG.nextInt(16) + 8;
k1 = this.soulRNG.nextInt(128);
l1 = l + this.soulRNG.nextInt(16) + 8;
(new WorldGenFlowers(mod_Ores.plantCantaloupe.blockID)).generate(this.worldObj, this.soulRNG, j1, k1, l1);
}

WorldGenMinable worldgenminable;
int j2;

for (k1 = 0; k1 < 16; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
new WorldGenMinable(mod_Ores.Amazoniteore.blockID, 4, mod_Ores.Porphyry.blockID).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}
for (k1 = 0; k1 < 8; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
new WorldGenMinable(mod_Ores.Amethystore.blockID, 3, mod_Ores.Porphyry.blockID).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}

for (k1 = 0; k1 < 16; ++k1)
{
l1 = k + this.soulRNG.nextInt(16);
i2 = this.soulRNG.nextInt(108) + 10;
j2 = l + this.soulRNG.nextInt(16);
(new WorldGenHellLava(Block.waterMoving.blockID, true)).generate(this.worldObj, this.soulRNG, l1, i2, j2);
}

MinecraftForge.EVENT_BUS.post(new DecorateBiomeEvent.Post(worldObj, soulRNG, k, l));
MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Post(par1IChunkProvider, worldObj, soulRNG, par2, par3, false));

BlockSand.fallInstantly = false;
}

/**
* Two modes of operation: if passed true, save all Chunks in one go. If passed false, save up to two chunks.
* Return true if all chunks have been saved.
*/
public boolean saveChunks(boolean par1, IProgressUpdate par2IProgressUpdate)
{
return true;
}

/**
* Unloads chunks that are marked to be unloaded. This is not guaranteed to unload every such chunk.
*/
public boolean unloadQueuedChunks()
{
return false;
}

/**
* Returns if the IChunkProvider supports saving.
*/
public boolean canSave()
{
return true;
}

/**
* Converts the instance data to a readable string.
*/
public String makeString()
{
return "SoulForestLevelSource";
}

/**
* Returns a list of creatures of the specified type that can spawn at the given location.
*/
public List getPossibleCreatures(EnumCreatureType par1EnumCreatureType, int par2, int par3, int par4)
{
if (par1EnumCreatureType == EnumCreatureType.monster && this.genNetherBridge.hasStructureAt(par2, par3, par4))
{
return this.genNetherBridge.getSpawnList();
}
else
{
BiomeGenBase biomegenbase = this.worldObj.getBiomeGenForCoords(par2, par4);
return biomegenbase == null ? null : biomegenbase.getSpawnableList(par1EnumCreatureType);
}
}

/**
* Returns the location of the closest structure of the specified type. If not found returns null.
*/
public ChunkPosition findClosestStructure(World par1World, String par2Str, int par3, int par4, int par5)
{
return null;
}

public int getLoadedChunkCount()
{
return 0;
}

public void recreateStructures(int par1, int par2)
{
//this.genNetherBridge.generate(this, this.worldObj, par1, par2, (byte[])null);
}
}

 

 

 

BiomeGenSoulForest

 

 


package Mod_Ores;

import java.util.Random;
import net.minecraft.block.Block;
import net.minecraft.entity.passive.EntityWolf;
import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.biome.SpawnListEntry;
import net.minecraft.world.gen.feature.WorldGenVines;

public class BiomeGenSoulForest extends BiomeGenBase
{
public BiomeGenSoulForest(int par1)
{
super(par1);
this.topBlock = (byte)mod_Ores.LateriteGrass.blockID;
this.fillerBlock = (byte)mod_Ores.LateriteDirt.blockID;

//spawnableCreatureList.add(new SpawnListEntry(EntityWolf.class, 5, 4, 4));
theBiomeDecorator.baneberryvineperchunk= 3;
theBiomeDecorator.blackberryvineperchunk= 3;
theBiomeDecorator.blueberryvineperchunk= 6;
theBiomeDecorator.cranberryvineperchunk= 4;
theBiomeDecorator.raspberryvineperchunk= 5;
theBiomeDecorator.razzberryvineperchunk= 5;
theBiomeDecorator.strawberryvineperchunk= 8;
theBiomeDecorator.flowersPerChunk = 30;
theBiomeDecorator.grapetreeperchunk = 10;
theBiomeDecorator.cantaloupeperchunk = 20;
temperature = 2.0F;
}


public void decorate(World par1World, Random par2Random, int par3, int par4)
{
super.decorate(par1World, par2Random, par3, par4);
trees(par1World, par2Random, par3, par4);
}

public void trees(World par2World, Random par3Random, int par5, int par6)
{
for(int i = 0; i < 20; i++)
{
int RandPosX = par5 + par3Random.nextInt(16);
int RandPosY = par3Random.nextInt(164);
int RandPosZ = par6 + par3Random.nextInt(16);
(new WorldGenGrapeTree(true)).generate(par2World, par3Random, RandPosX, RandPosY, RandPosZ);
}
}

}

 

 

 

Thanks for taking the time to read/help!

Link to comment
Share on other sites

I have fixed trees spawning there, but now they still won't spawn on my custom grass blocks. How can i change that?

 

soil.canSustainPlant(par1World, par3, par4 - 1, par5, ForgeDirection.UP, (BlockSapling)Block.sapling)

 

Does your custom grass return true for this function?

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.

Link to comment
Share on other sites

I have fixed trees spawning there, but now they still won't spawn on my custom grass blocks. How can i change that?

 

soil.canSustainPlant(par1World, par3, par4 - 1, par5, ForgeDirection.UP, (BlockSapling)Block.sapling)

 

Does your custom grass return true for this function?

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.

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.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Now it says me "Incompatible Server"  I run Forge 40.2.0 with 38 mods at the same version as the aternos server. https://mclo.gs/oLpLRxH
    • Unfortunatly you can´t allocate more ram on aternos servers
    • I resolved all the conflicts that weren't letting me enter the game, thank you very much. But now another error has appeared, when I enter a world it immediately crashes, here is the log: https://paste.ee/p/AOGUx.
    • every mod is up to date, i need help, here's the log     [19:50:14] [main/INFO]: ModLauncher running: args [--username, HH_Zere, --version, forge-47.2.0, --gameDir, C:\Users\------\curseforge\minecraft\Instances\Single Player (1), --assetsDir, C:\Users\------\curseforge\minecraft\Install\assets, --assetIndex, 5, --uuid, ba5d8ed702394fa9a945f5e5bc8731d2, --accessToken, ????????, --clientId, Yzk2MmQ2NjQtOGZhOS00YjRlLTllMDQtYmUxMmM1NmY3Mzcy, --xuid, 2535439086822918, --userType, msa, --versionType, release, --width, 1920, --height, 1080, --quickPlayPath, C:\Users\------\curseforge\minecraft\Install\quickPlay\java\1709232612667.json, --launchTarget, forgeclient, --fml.forgeVersion, 47.2.0, --fml.mcVersion, 1.20.1, --fml.forgeGroup, net.minecraftforge, --fml.mcpVersion, 20230612.114412] [19:50:14] [main/INFO]: ModLauncher 10.0.9+10.0.9+main.dcd20f30 starting: java version 17.0.8 by Microsoft; OS Windows 11 arch amd64 version 10.0 [19:50:16] [main/INFO]: Loading ImmediateWindowProvider fmlearlywindow [19:50:16] [main/INFO]: Trying GL version 4.6 [19:50:16] [main/INFO]: Requested GL version 4.6 got version 4.6 [19:50:16] [main/INFO]: SpongePowered MIXIN Subsystem Version=0.8.5 Source=union:/C:/Users/Daniel/curseforge/minecraft/Install/libraries/org/spongepowered/mixin/0.8.5/mixin-0.8.5.jar%23100!/ Service=ModLauncher Env=CLIENT [19:50:16] [pool-2-thread-1/INFO]: GL info: NVIDIA GeForce RTX 2080 Ti/PCIe/SSE2 GL version 4.6.0 NVIDIA 551.61, NVIDIA Corporation [19:50:17] [main/INFO]: Found mod file [1.20.1] SecurityCraft v1.9.8.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file [Forge]ctov-3.4.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file additional_lights-1.20.1-2.1.7.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file AI-Improvements-1.20-0.5.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file AmbientSounds_FORGE_v5.3.9_mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file appleskin-forge-mc1.20.1-2.5.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file architectury-9.2.14-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file AttributeFix-Forge-1.20.1-21.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file balm-forge-1.20.1-7.2.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file bellsandwhistles-0.4.3-1.20.x.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Better Falling-forge-1.3.0-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BetterThirdPerson-Forge-1.20-1.9.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BiomesOPlenty-1.20.1-18.0.0.592.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Bookshelf-Forge-1.20.1-20.1.9.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BotanyPots-Forge-1.20.1-13.0.24.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BotanyPotsOrePlanting-Forge-7.9.0+1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BotanyPotsTiers-Forge-1.20.1-6.0.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file BotanyTrees-Forge-1.20.1-9.0.11.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file botarium-forge-1.20.1-2.3.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file cannibal-1.0.5-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file castle_in_the_sky-1.20.1-0.6.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Chimes-v2.0.1-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file cleanswing-1.20-1.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file cloth-config-11.1.118-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Clumps-forge-1.20.1-12.0.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Cognition-v2.0.3-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file collective-1.20.1-7.36.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file CraftableTotemOfUndying-1.20.1-3.2.1-[FORGE].jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create-1.20.1-0.5.1.f.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create-new-age-forge-1.20.1-1.1.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_jetpack-forge-4.2.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_mechanical_spawner-1.20.1-0.0.14.e-22.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_misc_and_things_ 1.20.1_4.0A.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_netherless-1.20.1-1.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_recycle_1.0.2_forge_1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file create_sabers-1.20.1-1.3.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file createaddition-1.20.1-1.2.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file createbigcannons-forge-1.20.1-0.5.3.b.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file createdeco-2.0.1-1.20.1-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file createoreexcavation-1.20-1.4.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file CreativeCore_FORGE_v2.11.24_mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Croptopia-1.20.1-FORGE-3.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file curios-forge-5.7.0+1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file cyanide-forge-1.20.1-4.1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file DarkUtilities-Forge-1.20.1-17.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file design_decor-0.3-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file DiagonalFences-v8.1.3-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file DiagonalWalls-v8.0.2-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file DiagonalWindows-v8.1.3-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file doubledoors-1.20.1-5.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file DripSounds-1.19.4-0.3.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Durability101-forge-1.20-0.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file dynamiccrosshair-7.4.4+1.20-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file effortlessbuilding-1.20.1-3.7-all.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file embeddium-0.3.7+mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file EnchantingInfuser-v8.0.2-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file endermanoverhaul-forge-1.20.1-1.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file entityculling-forge-1.6.2-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file EpheroLib-1.20.1-FORGE-1.2.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file extendedgears-2.1.0-1.20.1-0.5.1.c-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file fancymenu_forge_3.1.1_MC_1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file fantasyfurniture-1.20.1-9.0.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file ferritecore-6.0.1-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file fixexperiencebug-1.20-46.2.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file FlowerPatch-forge-1.20.1-3.1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file FlowerSeeds2-1.20.1-1.1.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file FramedBlocks-9.2.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file fusion-1.1.1-forge-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file geckolib-forge-1.20.1-4.4.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file giacomos_exp-1.20.1-1.4.6.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file GoldenCrops-1.20.1-1.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file handcrafted-forge-1.20.1-3.0.6.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file iceandfire-2.1.13-1.20.1-beta-4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file immersive_weathering-1.20.1-2.0.1-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file infinity_cave-0.4-1.20.1-FORGE.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file interiors-0.5.2+mc1.20.1-FORGE.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file inventorio-1.20-forge-1.9.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file invhud.forge.1.20.1-3.4.18.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file ironchest-1.20.1-14.4.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file ironfurnaces-1.20.1-4.1.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file itemcollectors-1.1.9-forge-mc1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file jei-1.20.1-forge-15.3.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file jumpoverfences-forge-1.20.1-1.3.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file keepmysoiltilled-1.20.1-2.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Kiwi-1.20.1-forge-11.5.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file konkrete_forge_1.8.0_MC_1.20-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file kotlinforforge-4.10.0-all.jar of type LIBRARY with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file lazulib-1.20.1-1.2.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file lithostitched-forge-1.20.1-1.1.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file macawsbridgesbop-1.20-1.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file macawsroofsbop-1.20-1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-bridges-2.1.1-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-doors-1.1.0forge-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-fences-1.1.1-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-furniture-3.2.2-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-paintings-1.0.5-1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-paths-1.0.4forge-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-roofs-2.3.0-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-trapdoors-1.1.2-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcw-windows-2.2.1-mc1.20.1forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mcwfencesbop-1.20-1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file melody_forge_1.0.3_MC_1.20.1-1.20.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file mining-dimension-forge-1.20.1-1.1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file MOAdecor LIGHTS 1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file moonlight-1.20-2.10.10-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file MouseTweaks-forge-mc1.20-2.25.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file nct-1.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file nocube's_create_compact_exp_1.0.3_forge_1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file nyfsspiders-forge-1.20.1-2.1.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file oculus-mc1.20.1-1.6.15a.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file PassableFoliage-1.20.1-forge-8.2.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file physics-mod-pro-v167d-forge-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file PigPen-Forge-1.20.1-15.0.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file pipez-forge-1.20.1-1.2.6.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file player-animation-lib-forge-1.0.2-rc1+1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file polymorph-forge-0.49.2+1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file preciseblockplacing-2.0.2+1.19-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file puffish_skills-0.11.3-1.20-forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file PuzzlesLib-v8.1.17-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file rangedwirelessredstone-1.20-4.0.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file realmrpg_dragon_wyrms_1.0.1_forge_1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file realmrpg_fallen_adventurers_1.0.3_forge_1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file rechiseled-1.1.5c-forge-mc1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file rechiseledcreate-1.0.2-forge-mc1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file resourcefulconfig-forge-1.20.1-2.1.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file resourcefullib-forge-1.20.1-2.1.23.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Runelic-Forge-1.20.1-18.0.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file ShoulderSurfing-Forge-1.20.1-2.9.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file shw-forge-1.0.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file simplylight-1.20.1-1.4.6-build.50.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file sky_lands-0.1.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file SkyVillages-1.0.3-1.19.2-1.20.x-forge-release.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file smoothboot(reloaded)-mc1.20.1-0.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file sophisticatedbackpacks-1.20.1-3.20.1.1012.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file sophisticatedcore-1.20.1-0.6.3.553.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file sound-physics-remastered-forge-1.20.1-1.3.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Steam_Rails-1.5.3+forge-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file storagedrawers-1.20.1-12.0.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file supermartijn642configlib-1.1.8-forge-mc1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file supermartijn642corelib-1.1.17-forge-mc1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file supplementaries-1.20-2.8.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file TerraBlender-forge-1.20.1-3.0.1.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file TheCropReapingMod-1.20.1-2.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file toolleveling-forge-1.20.1-2.0.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file torchmaster-20.1.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file totw_modded-1.0.2-1.20.1.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file trashcans-1.0.18b-forge-mc1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file treeharvester-1.20.1-8.7.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file vc_gliders-forge-1.1.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file villagesandpillages-forge-mc1.20.1-1.0.0.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file VisualWorkbench-v8.0.0-1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file waterframes-1.20.1-1.3.1e.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file watermedia-2.0.28.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file WI-Zoom-1.5-MC1.20.1-Forge.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file Xaeros_Minimap_23.9.7_Forge_1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file XaerosWorldMap_1.37.8_Forge_1.20.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsApi-1.20-Forge-4.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterDesertTemples-1.20-Forge-3.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterDungeons-1.20-Forge-4.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterEndIsland-1.20-Forge-2.0.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterJungleTemples-1.20-Forge-2.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterMineshafts-1.20-Forge-4.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterNetherFortresses-1.20-Forge-2.0.5.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterOceanMonuments-1.20-Forge-3.0.4.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterStrongholds-1.20-Forge-4.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBetterWitchHuts-1.20-Forge-3.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsBridges-1.20-Forge-4.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsExtras-1.20-Forge-4.0.3.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/INFO]: Found mod file YungsMenuTweaks-1.20.1-Forge-1.0.2.jar of type MOD with provider {mods folder locator at C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods} [19:50:17] [main/WARN]: Mod file C:\Users\Daniel\curseforge\minecraft\Install\libraries\net\minecraftforge\fmlcore\1.20.1-47.2.0\fmlcore-1.20.1-47.2.0.jar is missing mods.toml file [19:50:17] [main/WARN]: Mod file C:\Users\Daniel\curseforge\minecraft\Install\libraries\net\minecraftforge\javafmllanguage\1.20.1-47.2.0\javafmllanguage-1.20.1-47.2.0.jar is missing mods.toml file [19:50:17] [main/WARN]: Mod file C:\Users\Daniel\curseforge\minecraft\Install\libraries\net\minecraftforge\lowcodelanguage\1.20.1-47.2.0\lowcodelanguage-1.20.1-47.2.0.jar is missing mods.toml file [19:50:17] [main/WARN]: Mod file C:\Users\Daniel\curseforge\minecraft\Install\libraries\net\minecraftforge\mclanguage\1.20.1-47.2.0\mclanguage-1.20.1-47.2.0.jar is missing mods.toml file [19:50:17] [main/INFO]: Found mod file fmlcore-1.20.1-47.2.0.jar of type LIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/INFO]: Found mod file javafmllanguage-1.20.1-47.2.0.jar of type LANGPROVIDER with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/INFO]: Found mod file lowcodelanguage-1.20.1-47.2.0.jar of type LANGPROVIDER with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/INFO]: Found mod file mclanguage-1.20.1-47.2.0.jar of type LANGPROVIDER with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/INFO]: Found mod file client-1.20.1-20230612.114412-srg.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/INFO]: Found mod file forge-1.20.1-47.2.0-universal.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.MinecraftLocator@70e889e9 [19:50:17] [main/WARN]: Attempted to select two dependency jars from JarJar which have the same identification: Mod File:  and Mod File: . Using Mod File:  [19:50:17] [main/WARN]: Attempted to select two dependency jars from JarJar which have the same identification: Mod File:  and Mod File: . Using Mod File:  [19:50:17] [main/WARN]: Attempted to select a dependency jar for JarJar which was passed in as source: playeranimator. Using Mod File: C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1)\mods\player-animation-lib-forge-1.0.2-rc1+1.20.jar [19:50:17] [main/INFO]: Found 24 dependencies adding them to mods collection [19:50:17] [main/INFO]: Found mod file caffeine-3.1.8.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file commonality-1.20.1-7.0.0.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file mixinsquared-forge-0.1.1.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file Registrate-MC1.20-1.3.3.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file PalladiumCore-forge-1.20-2.0.0.0-forge.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file spectrelib-forge-0.13.14+1.20.1.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file mclib-20.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file kffmod-4.10.0.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file flywheel-forge-1.20.1-0.6.10-7.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file bytecodecs-1.0.2.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file ritchiesprojectilelib-1.0.0-369e88d+1.20.1-forge.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file jcpp-1.4.14.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file MixinSquared-0.1.1.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file mixinextras-forge-0.2.0-beta.8.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file yabn-1.0.3.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file apexcore-1.20.1-10.0.0.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file flightlib-forge-2.1.0.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file yaclx-1.12+1.20.2-forge.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file kfflang-4.10.0.jar of type LANGPROVIDER with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file puzzlesaccessapi-forge-8.0.7.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file MixinExtras-0.3.2.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file kfflib-4.10.0.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file diagonalblocks-forge-8.0.4.jar of type MOD with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/INFO]: Found mod file japng-0.5.3.jar of type GAMELIBRARY with provider net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator@5df778c3 [19:50:17] [main/ERROR]: Missing or unsupported mandatory dependencies:     Mod ID: 'watermedia', Requested by: 'waterframes', Expected range: '[1.3,1.4]', Actual version: '2.0.28'     Mod ID: 'citadel', Requested by: 'iceandfire', Expected range: '[2.4.1,2.5.99]', Actual version: '[MISSING]' [19:50:20] [main/INFO]: Compatibility level set to JAVA_17 [19:50:21] [main/ERROR]: Mixin config vc_gliders-common.mixins.json does not specify "minVersion" property [19:50:21] [main/ERROR]: Mixin config vc_gliders.mixins.json does not specify "minVersion" property [19:50:21] [main/ERROR]: Mixin config palladiumcore-common.mixins.json does not specify "minVersion" property [19:50:21] [main/ERROR]: Mixin config palladiumcore.mixins.json does not specify "minVersion" property [19:50:21] [main/ERROR]: Mixin config cannibal.mixin.json does not specify "minVersion" property [19:50:21] [main/INFO]: Successfully loaded Mixin Connector [com.sonicether.soundphysics.MixinConnector] [19:50:21] [main/INFO]: Successfully loaded Mixin Connector [de.maxhenkel.miningdimension.mixin.MixinConnector] [19:50:21] [main/INFO]: Launching target 'forgeclient' with arguments [--version, forge-47.2.0, --gameDir, C:\Users\Daniel\curseforge\minecraft\Instances\Single Player (1), --assetsDir, C:\Users\Daniel\curseforge\minecraft\Install\assets, --uuid, ba5d8ed702394fa9a945f5e5bc8731d2, --username, HH_Zere, --assetIndex, 5, --accessToken, ????????, --clientId, Yzk2MmQ2NjQtOGZhOS00YjRlLTllMDQtYmUxMmM1NmY3Mzcy, --xuid, 2535439086822918, --userType, msa, --versionType, release, --width, 1920, --height, 1080, --quickPlayPath, C:\Users\Daniel\curseforge\minecraft\Install\quickPlay\java\1709232612667.json] [19:50:21] [main/WARN]: Reference map 'createdeco-common-refmap.json' for createdeco-common.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'createdeco-forge-refmap.json' for createdeco.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/INFO]: Loaded configuration file for Embeddium: 44 options available, 0 override(s) found [19:50:21] [main/INFO]: Searching for graphics cards... [19:50:21] [main/INFO]: Found graphics card: GraphicsAdapterInfo[vendor=NVIDIA, name=NVIDIA GeForce RTX 2080 Ti, version=DriverVersion=31.0.15.5161] [19:50:21] [main/WARN]: Sodium has applied one or more workarounds to prevent crashes or other issues on your system: [NVIDIA_THREADED_OPTIMIZATIONS] [19:50:21] [main/WARN]: This is not necessarily an issue, but it may result in certain features or optimizations being disabled. You can sometimes fix these issues by upgrading your graphics driver. [19:50:21] [main/WARN]: Reference map 'handcrafted-forge-1.20.1-forge-refmap.json' for handcrafted.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'yungsextras.refmap.json' for yungsextras.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'yungsextras.refmap.json' for yungsextras_forge.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'EpheroLib-refmap.json' for epherolib.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'tfmg.refmap.json' for design_decor.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'vc_gliders-forge-refmap.json' for vc_gliders.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/INFO]: Loading 2 mods:     - forge 47.2.0     - minecraft 1.20.1 [19:50:21] [main/WARN]: Reference map 'ritchiesprojectilelib-forge-refmap.json' for ritchiesprojectilelib-forge.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'create_mechanical_spawner.refmap.json' for create_mechanical_spawner.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:21] [main/WARN]: Reference map 'apexcore.refmap.json' for apexcore.mixins.json could not be read. If this is a development environment you can ignore this message [19:50:22] [main/WARN]: Error loading class: net/raphimc/immediatelyfast/feature/map_atlas_generation/MapAtlasTexture (java.lang.ClassNotFoundException: net.raphimc.immediatelyfast.feature.map_atlas_generation.MapAtlasTexture) [19:50:22] [main/WARN]: Error loading class: net/optifine/shaders/Shaders (java.lang.ClassNotFoundException: net.optifine.shaders.Shaders) [19:50:22] [main/WARN]: Error loading class: net/optifine/shaders/ShadersCompatibility (java.lang.ClassNotFoundException: net.optifine.shaders.ShadersCompatibility) [19:50:22] [main/WARN]: Error loading class: net/optifine/shaders/Programs (java.lang.ClassNotFoundException: net.optifine.shaders.Programs) [19:50:22] [main/WARN]: Error loading class: org/valkyrienskies/core/impl/game/ships/ShipObjectClient (java.lang.ClassNotFoundException: org.valkyrienskies.core.impl.game.ships.ShipObjectClient) [19:50:22] [main/WARN]: Error loading class: net/optifine/util/BlockUtils (java.lang.ClassNotFoundException: net.optifine.util.BlockUtils) [19:50:22] [main/WARN]: Error loading class: ca/spottedleaf/starlight/common/light/StarLightEngine (java.lang.ClassNotFoundException: ca.spottedleaf.starlight.common.light.StarLightEngine) [19:50:22] [main/WARN]: Error loading class: link/infra/indium/renderer/render/TerrainRenderContext (java.lang.ClassNotFoundException: link.infra.indium.renderer.render.TerrainRenderContext) [19:50:22] [main/WARN]: Error loading class: net/optifine/shaders/ShadersRender (java.lang.ClassNotFoundException: net.optifine.shaders.ShadersRender) [19:50:22] [main/WARN]: @Mixin target net.optifine.shaders.ShadersRender was not found shouldersurfing.mixins.json:MixinShadersRender [19:50:22] [main/WARN]: Error loading class: me/cominixo/betterf3/modules/TargetModule (java.lang.ClassNotFoundException: me.cominixo.betterf3.modules.TargetModule) [19:50:22] [main/WARN]: @Mixin target me.cominixo.betterf3.modules.TargetModule was not found securitycraft.mixins.json:f3.BetterF3TargetModuleMixin [19:50:22] [main/WARN]: Error loading class: de/maxhenkel/voicechat/plugins/impl/audiochannel/EntityAudioChannelImpl (java.lang.ClassNotFoundException: de.maxhenkel.voicechat.plugins.impl.audiochannel.EntityAudioChannelImpl) [19:50:22] [main/WARN]: @Mixin target de.maxhenkel.voicechat.plugins.impl.audiochannel.EntityAudioChannelImpl was not found railways-common.mixins.json:compat.voicechat.EntityAudioChannelImplMixin [19:50:22] [main/WARN]: Error loading class: de/maxhenkel/voicechat/voice/server/Server (java.lang.ClassNotFoundException: de.maxhenkel.voicechat.voice.server.Server) [19:50:22] [main/WARN]: @Mixin target de.maxhenkel.voicechat.voice.server.Server was not found railways-common.mixins.json:compat.voicechat.ServerMixin [19:50:22] [main/WARN]: Error loading class: de/maxhenkel/voicechat/voice/server/ServerWorldUtils (java.lang.ClassNotFoundException: de.maxhenkel.voicechat.voice.server.ServerWorldUtils) [19:50:22] [main/WARN]: @Mixin target de.maxhenkel.voicechat.voice.server.ServerWorldUtils was not found railways-common.mixins.json:compat.voicechat.ServerWorldUtilsMixin [19:50:22] [main/WARN]: Error loading class: de/maxhenkel/voicechat/integration/freecam/FreecamUtil (java.lang.ClassNotFoundException: de.maxhenkel.voicechat.integration.freecam.FreecamUtil) [19:50:22] [main/WARN]: @Mixin target de.maxhenkel.voicechat.integration.freecam.FreecamUtil was not found railways-common.mixins.json:compat.voicechat.FreecamUtilMixin [19:50:22] [main/ERROR]: Could not find embeddium mod, there is likely a dependency error. Skipping mixin application. [19:50:23] [main/INFO]: Initializing MixinExtras via com.llamalad7.mixinextras.service.MixinExtrasServiceImpl(version=0.3.2). [19:50:23] [main/INFO]: Smooth Boot (Reloaded) config initialized [19:50:26] [pool-4-thread-1/WARN]: @Redirect conflict. Skipping securitycraft.mixins.json:camera.ServerPlayerMixin->@Redirect::securitycraft$tick(Lnet/minecraft/server/level/ServerPlayer;DDDFF)V with priority 1100, already redirected by railways-common.mixins.json:conductor_possession.ServerPlayerMixin->@Redirect::snr$securitycraft$tick(Lnet/minecraft/server/level/ServerPlayer;DDDFF)V with priority 1200
  • Topics

×
×
  • Create New...

Important Information

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