Jump to content

[1.7.2] Custom Biome not spawning in custom dimension


JimiIT92

Recommended Posts

Hi everibody! I'm trying to make a new dimension for my mod, but i've noticed that when entering this dimension a custom biome defined for it is not spawning. All i can see is only my custom stone block and my custom water, nothing elese, instead to have a biome with custom grass and dirt :/

Here is all the files i have for the dimension

 

WorldProviderCorrupted:

package mod.mineworld.world.mod_dimension;

import mod.mineworld.mod_dimension;
import net.minecraft.world.WorldProvider;
import net.minecraft.world.WorldProviderEnd;
import net.minecraft.world.WorldProviderHell;
import net.minecraft.world.chunk.IChunkProvider;
import net.minecraft.world.gen.ChunkProviderHell;

public class WorldProviderCorrupted extends WorldProvider
{

/**
     * creates a new world chunk manager for WorldProvider
     */
    public void registerWorldChunkManager()
    {
        this.worldChunkMgr = new WorldChunkManagerCorrupted(mod_dimension.biomeCorrupted, 0.0F);
        this.dimensionId = 2;
    }
    

    /**
     * A message to display to the user when they transfer to this dimension.
     *
     * @return The message to be displayed
     */
    @Override
    public String getWelcomeMessage()
    {
        return "Entering the corruption";
    }

    /**
     * A Message to display to the user when they transfer out of this dismension.
     *
     * @return The message to be displayed
     */
    @Override
    public String getDepartMessage()
    {
        return "Leaving the corruption";
    }

    /**
     * The dimensions movement factor. Relative to normal overworld.
     * It is applied to the players position when they transfer dimensions.
     * Exa: Nether movement is 8.0
     * @return The movement factor
     */
    @Override
    public double getMovementFactor()
    {        
        return 1.0;
    }
    

    /**
     * Returns a new chunk provider which generates chunks for this world
     */
    public IChunkProvider createChunkGenerator()
    {
        return new ChunkProviderCorrupted(this.worldObj, this.worldObj.getSeed(), false);
    }

    /**
     * True if the player can respawn in this dimension
     */
    public boolean canRespawnHere()
    {
        return true;
    }
    
    /**
     * Returns the dimension's name
     */
    public String getDimensionName()
    {
        return "Corrupted";
    }
}

 

WorldChunkManagerCorrupted:

package mod.mineworld.world.mod_dimension;

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

import net.minecraft.world.ChunkPosition;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.biome.WorldChunkManager;

public class WorldChunkManagerCorrupted extends WorldChunkManager
{
    /** The biome generator object. */
    private BiomeGenBase biomeGenerator;
    /** The rainfall in the world */
    private float rainfall;

    public WorldChunkManagerCorrupted(BiomeGenBase par1, float par2)
    {
        this.biomeGenerator = par1;
        this.rainfall = par2;
    }

    /**
     * Returns the BiomeGenBase related to the x, z position on the world.
     */
    public BiomeGenBase getBiomeGenAt(int par1, int par2)
    {
        return this.biomeGenerator;
    }

    /**
     * Returns an array of biomes for the location input.
     */
    public BiomeGenBase[] getBiomesForGeneration(BiomeGenBase[] par1ArrayOfBiomeGenBase, int par2, int par3, int par4, int par5)
    {
        if (par1ArrayOfBiomeGenBase == null || par1ArrayOfBiomeGenBase.length < par4 * par5)
        {
            par1ArrayOfBiomeGenBase = new BiomeGenBase[par4 * par5];
        }

        Arrays.fill(par1ArrayOfBiomeGenBase, 0, par4 * par5, this.biomeGenerator);
        return par1ArrayOfBiomeGenBase;
    }

    /**
     * Returns a list of rainfall values for the specified blocks. Args: listToReuse, x, z, width, length.
     */
    public float[] getRainfall(float[] par1ArrayOfFloat, int par2, int par3, int par4, int par5)
    {
        if (par1ArrayOfFloat == null || par1ArrayOfFloat.length < par4 * par5)
        {
            par1ArrayOfFloat = new float[par4 * par5];
        }

        Arrays.fill(par1ArrayOfFloat, 0, par4 * par5, this.rainfall);
        return par1ArrayOfFloat;
    }

    /**
     * Returns biomes to use for the blocks and loads the other data like temperature and humidity onto the
     * WorldChunkManager Args: oldBiomeList, x, z, width, depth
     */
    public BiomeGenBase[] loadBlockGeneratorData(BiomeGenBase[] par1ArrayOfBiomeGenBase, int par2, int par3, int par4, int par5)
    {
        if (par1ArrayOfBiomeGenBase == null || par1ArrayOfBiomeGenBase.length < par4 * par5)
        {
            par1ArrayOfBiomeGenBase = new BiomeGenBase[par4 * par5];
        }

        Arrays.fill(par1ArrayOfBiomeGenBase, 0, par4 * par5, this.biomeGenerator);
        return par1ArrayOfBiomeGenBase;
    }

    /**
     * Return a list of biomes for the specified blocks. Args: listToReuse, x, y, width, length, cacheFlag (if false,
     * don't check biomeCache to avoid infinite loop in BiomeCacheBlock)
     */
    public BiomeGenBase[] getBiomeGenAt(BiomeGenBase[] par1ArrayOfBiomeGenBase, int par2, int par3, int par4, int par5, boolean par6)
    {
        return this.loadBlockGeneratorData(par1ArrayOfBiomeGenBase, par2, par3, par4, par5);
    }

    public ChunkPosition findBiomePosition(int par1, int par2, int par3, List par4List, Random par5Random)
    {
        return par4List.contains(this.biomeGenerator) ? new ChunkPosition(par1 - par3 + par5Random.nextInt(par3 * 2 + 1), 0, par2 - par3 + par5Random.nextInt(par3 * 2 + 1)) : null;
    }

    /**
     * checks given Chunk's Biomes against List of allowed ones
     */
    public boolean areBiomesViable(int par1, int par2, int par3, List par4List)
    {
        return par4List.contains(this.biomeGenerator);
    }
}

 

TeleporterCorrupted:

package mod.mineworld.world.mod_dimension;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Random;

import mod.mineworld.mod_dimension;
import net.minecraft.entity.Entity;
import net.minecraft.init.Blocks;
import net.minecraft.util.ChunkCoordinates;
import net.minecraft.util.Direction;
import net.minecraft.util.LongHashMap;
import net.minecraft.util.MathHelper;
import net.minecraft.world.ChunkCoordIntPair;
import net.minecraft.world.Teleporter;
import net.minecraft.world.WorldServer;

public class TeleporterCorrupted extends Teleporter
{
    private final WorldServer worldServerInstance;

    /** A private Random() function in Teleporter */
    private final Random random;

    /** Stores successful portal placement locations for rapid lookup. */
    private final LongHashMap destinationCoordinateCache = new LongHashMap();

    /**
     * A list of valid keys for the destinationCoordainteCache. These are based on the X & Z of the players initial
     * location.
     */
    @SuppressWarnings("rawtypes")
private final List destinationCoordinateKeys = new ArrayList();

    public TeleporterCorrupted(WorldServer par1WorldServer)
    {
    	super(par1WorldServer);
        this.worldServerInstance = par1WorldServer;
        this.random = new Random(par1WorldServer.getSeed());
    }

    /**
     * Place an entity in a nearby portal, creating one if necessary.
     */
    @Override
    public void placeInPortal(Entity par1Entity, double par2, double par4, double par6, float par8)
    {
        if (this.worldServerInstance.provider.dimensionId != 1)
        {
            if (!this.placeInExistingPortal(par1Entity, par2, par4, par6, par8))
            {
                this.makePortal(par1Entity);
                this.placeInExistingPortal(par1Entity, par2, par4, par6, par8);
            }
        }
        else
        {
            int i = MathHelper.floor_double(par1Entity.posX);
            int j = MathHelper.floor_double(par1Entity.posY) - 1;
            int k = MathHelper.floor_double(par1Entity.posZ);
            byte b0 = 1;
            byte b1 = 0;

            for (int l = -2; l <= 2; ++l)
            {
                for (int i1 = -2; i1 <= 2; ++i1)
                {
                    for (int j1 = -1; j1 < 3; ++j1)
                    {
                        int k1 = i + i1 * b0 + l * b1;
                        int l1 = j + j1;
                        int i2 = k + i1 * b1 - l * b0;
                        boolean flag = j1 < 0;
                        this.worldServerInstance.setBlock(k1, l1, i2, flag ? Blocks.sandstone : Blocks.air);
                    }
                }
            }

            par1Entity.setLocationAndAngles((double)i, (double)j, (double)k, par1Entity.rotationYaw, 0.0F);
            par1Entity.motionX = par1Entity.motionY = par1Entity.motionZ = 0.0D;
        }
    }

    /**
     * Place an entity in a nearby portal which already exists.
     */
    @SuppressWarnings("unchecked")
@Override
    public boolean placeInExistingPortal(Entity par1Entity, double par2, double par4, double par6, float par8)
    {
        short short1 = 128;
        double d3 = -1.0D;
        int i = 0;
        int j = 0;
        int k = 0;
        int l = MathHelper.floor_double(par1Entity.posX);
        int i1 = MathHelper.floor_double(par1Entity.posZ);
        long j1 = ChunkCoordIntPair.chunkXZ2Int(l, i1);
        boolean flag = true;
        double d4;
        int k1;

        if (this.destinationCoordinateCache.containsItem(j1))
        {
            PortalPosition portalposition = (PortalPosition)this.destinationCoordinateCache.getValueByKey(j1);
            d3 = 0.0D;
            i = portalposition.posX;
            j = portalposition.posY;
            k = portalposition.posZ;
            portalposition.lastUpdateTime = this.worldServerInstance.getTotalWorldTime();
            flag = false;
        }
        else
        {
            for (k1 = l - short1; k1 <= l + short1; ++k1)
            {
                double d5 = (double)k1 + 0.5D - par1Entity.posX;

                for (int l1 = i1 - short1; l1 <= i1 + short1; ++l1)
                {
                    double d6 = (double)l1 + 0.5D - par1Entity.posZ;

                    for (int i2 = this.worldServerInstance.getActualHeight() - 1; i2 >= 0; --i2)
                    {
                        if (this.worldServerInstance.getBlock(k1, i2, l1) == mod_dimension.corrupted_portal)
                        {
                            while (this.worldServerInstance.getBlock(k1, i2 - 1, l1) == mod_dimension.corrupted_portal)
                            {
                                --i2;
                            }

                            d4 = (double)i2 + 0.5D - par1Entity.posY;
                            double d7 = d5 * d5 + d4 * d4 + d6 * d6;

                            if (d3 < 0.0D || d7 < d3)
                            {
                                d3 = d7;
                                i = k1;
                                j = i2;
                                k = l1;
                            }
                        }
                    }
                }
            }
        }

        if (d3 >= 0.0D)
        {
            if (flag)
            {
                this.destinationCoordinateCache.add(j1, new PortalPosition(i, j, k, this.worldServerInstance.getTotalWorldTime()));
                this.destinationCoordinateKeys.add(Long.valueOf(j1));
            }

            double d8 = (double)i + 0.5D;
            double d9 = (double)j + 0.5D;
            d4 = (double)k + 0.5D;
            int j2 = -1;

            if (this.worldServerInstance.getBlock(i - 1, j, k) == mod_dimension.corrupted_portal)
            {
                j2 = 2;
            }

            if (this.worldServerInstance.getBlock(i + 1, j, k) == mod_dimension.corrupted_portal)
            {
                j2 = 0;
            }

            if (this.worldServerInstance.getBlock(i, j, k - 1) == mod_dimension.corrupted_portal)
            {
                j2 = 3;
            }

            if (this.worldServerInstance.getBlock(i, j, k + 1) == mod_dimension.corrupted_portal)
            {
                j2 = 1;
            }

            int k2 = par1Entity.getTeleportDirection();

            if (j2 > -1)
            {
                int l2 = Direction.rotateLeft[j2];
                int i3 = Direction.offsetX[j2];
                int j3 = Direction.offsetZ[j2];
                int k3 = Direction.offsetX[l2];
                int l3 = Direction.offsetZ[l2];
                boolean flag1 = !this.worldServerInstance.isAirBlock(i + i3 + k3, j, k + j3 + l3) || !this.worldServerInstance.isAirBlock(i + i3 + k3, j + 1, k + j3 + l3);
                boolean flag2 = !this.worldServerInstance.isAirBlock(i + i3, j, k + j3) || !this.worldServerInstance.isAirBlock(i + i3, j + 1, k + j3);

                if (flag1 && flag2)
                {
                    j2 = Direction.rotateOpposite[j2];
                    l2 = Direction.rotateOpposite[l2];
                    i3 = Direction.offsetX[j2];
                    j3 = Direction.offsetZ[j2];
                    k3 = Direction.offsetX[l2];
                    l3 = Direction.offsetZ[l2];
                    k1 = i - k3;
                    d8 -= (double)k3;
                    int i4 = k - l3;
                    d4 -= (double)l3;
                    flag1 = !this.worldServerInstance.isAirBlock(k1 + i3 + k3, j, i4 + j3 + l3) || !this.worldServerInstance.isAirBlock(k1 + i3 + k3, j + 1, i4 + j3 + l3);
                    flag2 = !this.worldServerInstance.isAirBlock(k1 + i3, j, i4 + j3) || !this.worldServerInstance.isAirBlock(k1 + i3, j + 1, i4 + j3);
                }

                float f1 = 0.5F;
                float f2 = 0.5F;

                if (!flag1 && flag2)
                {
                    f1 = 1.0F;
                }
                else if (flag1 && !flag2)
                {
                    f1 = 0.0F;
                }
                else if (flag1 && flag2)
                {
                    f2 = 0.0F;
                }

                d8 += (double)((float)k3 * f1 + f2 * (float)i3);
                d4 += (double)((float)l3 * f1 + f2 * (float)j3);
                float f3 = 0.0F;
                float f4 = 0.0F;
                float f5 = 0.0F;
                float f6 = 0.0F;

                if (j2 == k2)
                {
                    f3 = 1.0F;
                    f4 = 1.0F;
                }
                else if (j2 == Direction.rotateOpposite[k2])
                {
                    f3 = -1.0F;
                    f4 = -1.0F;
                }
                else if (j2 == Direction.rotateRight[k2])
                {
                    f5 = 1.0F;
                    f6 = -1.0F;
                }
                else
                {
                    f5 = -1.0F;
                    f6 = 1.0F;
                }

                double d10 = par1Entity.motionX;
                double d11 = par1Entity.motionZ;
                par1Entity.motionX = d10 * (double)f3 + d11 * (double)f6;
                par1Entity.motionZ = d10 * (double)f5 + d11 * (double)f4;
                par1Entity.rotationYaw = par8 - (float)(k2 * 90) + (float)(j2 * 90);
            }
            else
            {
                par1Entity.motionX = par1Entity.motionY = par1Entity.motionZ = 0.0D;
            }

            par1Entity.setLocationAndAngles(d8, d9, d4, par1Entity.rotationYaw, par1Entity.rotationPitch);
            return true;
        }
        else
        {
            return false;
        }
    }

    @Override
    public boolean makePortal(Entity par1Entity)
    {
        byte b0 = 16;
        double d0 = -1.0D;
        int i = MathHelper.floor_double(par1Entity.posX);
        int j = MathHelper.floor_double(par1Entity.posY);
        int k = MathHelper.floor_double(par1Entity.posZ);
        int l = i;
        int i1 = j;
        int j1 = k;
        int k1 = 0;
        int l1 = this.random.nextInt(4);
        int i2;
        double d1;
        double d2;
        int j2;
        int k2;
        int l2;
        int i3;
        int j3;
        int k3;
        int l3;
        int i4;
        int j4;
        int k4;
        double d3;
        double d4;

        for (i2 = i - b0; i2 <= i + b0; ++i2)
        {
            d1 = (double)i2 + 0.5D - par1Entity.posX;

            for (j2 = k - b0; j2 <= k + b0; ++j2)
            {
                d2 = (double)j2 + 0.5D - par1Entity.posZ;
                label274:

                for (k2 = this.worldServerInstance.getActualHeight() - 1; k2 >= 0; --k2)
                {
                    if (this.worldServerInstance.isAirBlock(i2, k2, j2))
                    {
                        while (k2 > 0 && this.worldServerInstance.isAirBlock(i2, k2 - 1, j2))
                        {
                            --k2;
                        }

                        for (i3 = l1; i3 < l1 + 4; ++i3)
                        {
                            l2 = i3 % 2;
                            k3 = 1 - l2;

                            if (i3 % 4 >= 2)
                            {
                                l2 = -l2;
                                k3 = -k3;
                            }

                            for (j3 = 0; j3 < 3; ++j3)
                            {
                                for (i4 = 0; i4 < 4; ++i4)
                                {
                                    for (l3 = -1; l3 < 4; ++l3)
                                    {
                                        k4 = i2 + (i4 - 1) * l2 + j3 * k3;
                                        j4 = k2 + l3;
                                        int l4 = j2 + (i4 - 1) * k3 - j3 * l2;

                                        if (l3 < 0 && !this.worldServerInstance.getBlock(k4, j4, l4).getMaterial().isSolid() || l3 >= 0 && !this.worldServerInstance.isAirBlock(k4, j4, l4))
                                        {
                                            continue label274;
                                        }
                                    }
                                }
                            }

                            d4 = (double)k2 + 0.5D - par1Entity.posY;
                            d3 = d1 * d1 + d4 * d4 + d2 * d2;

                            if (d0 < 0.0D || d3 < d0)
                            {
                                d0 = d3;
                                l = i2;
                                i1 = k2;
                                j1 = j2;
                                k1 = i3 % 4;
                            }
                        }
                    }
                }
            }
        }

        if (d0 < 0.0D)
        {
            for (i2 = i - b0; i2 <= i + b0; ++i2)
            {
                d1 = (double)i2 + 0.5D - par1Entity.posX;

                for (j2 = k - b0; j2 <= k + b0; ++j2)
                {
                    d2 = (double)j2 + 0.5D - par1Entity.posZ;
                    label222:

                    for (k2 = this.worldServerInstance.getActualHeight() - 1; k2 >= 0; --k2)
                    {
                        if (this.worldServerInstance.isAirBlock(i2, k2, j2))
                        {
                            while (k2 > 0 && this.worldServerInstance.isAirBlock(i2, k2 - 1, j2))
                            {
                                --k2;
                            }

                            for (i3 = l1; i3 < l1 + 2; ++i3)
                            {
                                l2 = i3 % 2;
                                k3 = 1 - l2;

                                for (j3 = 0; j3 < 4; ++j3)
                                {
                                    for (i4 = -1; i4 < 4; ++i4)
                                    {
                                        l3 = i2 + (j3 - 1) * l2;
                                        k4 = k2 + i4;
                                        j4 = j2 + (j3 - 1) * k3;

                                        if (i4 < 0 && !this.worldServerInstance.getBlock(l3, k4, j4).getMaterial().isSolid() || i4 >= 0 && !this.worldServerInstance.isAirBlock(l3, k4, j4))
                                        {
                                            continue label222;
                                        }
                                    }
                                }

                                d4 = (double)k2 + 0.5D - par1Entity.posY;
                                d3 = d1 * d1 + d4 * d4 + d2 * d2;

                                if (d0 < 0.0D || d3 < d0)
                                {
                                    d0 = d3;
                                    l = i2;
                                    i1 = k2;
                                    j1 = j2;
                                    k1 = i3 % 2;
                                }
                            }
                        }
                    }
                }
            }
        }

        int i5 = l;
        int j5 = i1;
        j2 = j1;
        int k5 = k1 % 2;
        int l5 = 1 - k5;

        if (k1 % 4 >= 2)
        {
            k5 = -k5;
            l5 = -l5;
        }

        boolean flag;

        if (d0 < 0.0D)
        {
            if (i1 < 70)
            {
                i1 = 70;
            }

            if (i1 > this.worldServerInstance.getActualHeight() - 10)
            {
                i1 = this.worldServerInstance.getActualHeight() - 10;
            }

            j5 = i1;

            for (k2 = -1; k2 <= 1; ++k2)
            {
                for (i3 = 1; i3 < 3; ++i3)
                {
                    for (l2 = -1; l2 < 3; ++l2)
                    {
                        k3 = i5 + (i3 - 1) * k5 + k2 * l5;
                        j3 = j5 + l2;
                        i4 = j2 + (i3 - 1) * l5 - k2 * k5;
                        flag = l2 < 0;
                        this.worldServerInstance.setBlock(k3, j3, i4, flag ? Blocks.sandstone : Blocks.air);
                    }
                }
            }
        }

        for (k2 = 0; k2 < 4; ++k2)
        {
            for (i3 = 0; i3 < 4; ++i3)
            {
                for (l2 = -1; l2 < 4; ++l2)
                {
                    k3 = i5 + (i3 - 1) * k5;
                    j3 = j5 + l2;
                    i4 = j2 + (i3 - 1) * l5;
                    flag = i3 == 0 || i3 == 3 || l2 == -1 || l2 == 3;
                    this.worldServerInstance.setBlock(k3, j3, i4, flag ? Blocks.sandstone : mod_dimension.corrupted_portal, 0, 2);
                }
            }

            for (i3 = 0; i3 < 4; ++i3)
            {
                for (l2 = -1; l2 < 4; ++l2)
                {
                    k3 = i5 + (i3 - 1) * k5;
                    j3 = j5 + l2;
                    i4 = j2 + (i3 - 1) * l5;
                    this.worldServerInstance.notifyBlocksOfNeighborChange(k3, j3, i4, this.worldServerInstance.getBlock(k3, j3, i4));
                }
            }
        }

        return true;
    }

    /**
     * called periodically to remove out-of-date portal locations from the cache list. Argument par1 is a
     * WorldServer.getTotalWorldTime() value.
     */
    @SuppressWarnings("rawtypes")
@Override
    public void removeStalePortalLocations(long par1)
    {
        if (par1 % 100L == 0L)
        {
            Iterator iterator = this.destinationCoordinateKeys.iterator();
            long j = par1 - 600L;

            while (iterator.hasNext())
            {
                Long olong = (Long)iterator.next();
                PortalPosition portalposition = (PortalPosition)this.destinationCoordinateCache.getValueByKey(olong.longValue());

                if (portalposition == null || portalposition.lastUpdateTime < j)
                {
                    iterator.remove();
                    this.destinationCoordinateCache.remove(olong.longValue());
                }
            }
        }
    }
    
    public class PortalPosition extends ChunkCoordinates
    {
        /** The worldtime at which this PortalPosition was last verified */
        public long lastUpdateTime;

        public PortalPosition(int par2, int par3, int par4, long par5)
        {
            super(par2, par3, par4);
            this.lastUpdateTime = par5;
        }
    }
}

 

ChunkProviderCorrupted:

package mod.mineworld.world.mod_dimension;

import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.CAVE;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.MINESHAFT;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.RAVINE;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.SCATTERED_FEATURE;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.STRONGHOLD;
import static net.minecraftforge.event.terraingen.InitMapGenEvent.EventType.VILLAGE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.ANIMALS;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.DUNGEON;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.ICE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.LAKE;
import static net.minecraftforge.event.terraingen.PopulateChunkEvent.Populate.EventType.LAVA;

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

import mod.mineworld.mod_dimension;
import net.minecraft.block.Block;
import net.minecraft.block.BlockFalling;
import net.minecraft.entity.EnumCreatureType;
import net.minecraft.init.Blocks;
import net.minecraft.util.IProgressUpdate;
import net.minecraft.util.MathHelper;
import net.minecraft.world.ChunkPosition;
import net.minecraft.world.SpawnerAnimals;
import net.minecraft.world.World;
import net.minecraft.world.WorldType;
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.MapGenCaves;
import net.minecraft.world.gen.MapGenRavine;
import net.minecraft.world.gen.NoiseGenerator;
import net.minecraft.world.gen.NoiseGeneratorOctaves;
import net.minecraft.world.gen.NoiseGeneratorPerlin;
import net.minecraft.world.gen.feature.WorldGenDungeons;
import net.minecraft.world.gen.feature.WorldGenLakes;
import net.minecraft.world.gen.structure.MapGenMineshaft;
import net.minecraft.world.gen.structure.MapGenScatteredFeature;
import net.minecraft.world.gen.structure.MapGenStronghold;
import net.minecraft.world.gen.structure.MapGenVillage;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.terraingen.ChunkProviderEvent;
import net.minecraftforge.event.terraingen.PopulateChunkEvent;
import net.minecraftforge.event.terraingen.TerrainGen;
import cpw.mods.fml.common.eventhandler.Event.Result;

public class ChunkProviderCorrupted implements IChunkProvider 
{
    /** RNG. */
    private Random rand;
    private NoiseGeneratorOctaves noiseGeneratorOctaves1;
    private NoiseGeneratorOctaves noiseGeneratorOctaves2;
    private NoiseGeneratorOctaves noiseGeneratorOctaves3;
    private NoiseGeneratorPerlin noiseGeneratorPerlin;
    /** A NoiseGeneratorOctaves used in generating terrain */
    public NoiseGeneratorOctaves noiseGen5;
    /** A NoiseGeneratorOctaves used in generating terrain */
    public NoiseGeneratorOctaves noiseGen6;
    public NoiseGeneratorOctaves mobSpawnerNoise;
    /** Reference to the World object. */
    private World worldObj;
    /** are map structures going to be generated (e.g. strongholds) */
    private final boolean mapFeaturesEnabled;
    private WorldType world_type;
    private final double[] field_147434_q;
    private final float[] parabolicField;
    private double[] stoneNoise = new double[256];
    private MapGenBase caveGenerator = new MapGenCaves();
    /** Holds Stronghold Generator */
    private MapGenStronghold strongholdGenerator = new MapGenStronghold();
    /** Holds Village Generator */
    private MapGenVillage villageGenerator = new MapGenVillage();
    /** Holds Mineshaft Generator */
    private MapGenMineshaft mineshaftGenerator = new MapGenMineshaft();
    private MapGenScatteredFeature scatteredFeatureGenerator = new MapGenScatteredFeature();
    /** Holds ravine generator */
    private MapGenBase ravineGenerator = new MapGenRavine();
    /** The biomes that are used to generate the chunk */
    private BiomeGenBase[] biomesForGeneration;
    double[] field_147427_d;
    double[] field_147428_e;
    double[] field_147425_f;
    double[] field_147426_g;
    int[][] field_73219_j = new int[32][32];

    {
        caveGenerator = TerrainGen.getModdedMapGen(caveGenerator, CAVE);
        strongholdGenerator = (MapGenStronghold) TerrainGen.getModdedMapGen(strongholdGenerator, STRONGHOLD);
        villageGenerator = (MapGenVillage) TerrainGen.getModdedMapGen(villageGenerator, VILLAGE);
        mineshaftGenerator = (MapGenMineshaft) TerrainGen.getModdedMapGen(mineshaftGenerator, MINESHAFT);
        scatteredFeatureGenerator = (MapGenScatteredFeature) TerrainGen.getModdedMapGen(scatteredFeatureGenerator, SCATTERED_FEATURE);
        ravineGenerator = TerrainGen.getModdedMapGen(ravineGenerator, RAVINE);
    }    

    public ChunkProviderCorrupted(World par1World, long par2, boolean par4)
    {
        this.worldObj = par1World;
        this.mapFeaturesEnabled = par4;
        this.world_type = par1World.getWorldInfo().getTerrainType();
        this.rand = new Random(par2);
        this.noiseGeneratorOctaves1 = new NoiseGeneratorOctaves(this.rand, 16);
        this.noiseGeneratorOctaves2 = new NoiseGeneratorOctaves(this.rand, 16);
        this.noiseGeneratorOctaves3 = new NoiseGeneratorOctaves(this.rand, ;
        this.noiseGeneratorPerlin = new NoiseGeneratorPerlin(this.rand, 4);
        this.noiseGen5 = new NoiseGeneratorOctaves(this.rand, 10);
        this.noiseGen6 = new NoiseGeneratorOctaves(this.rand, 16);
        this.mobSpawnerNoise = new NoiseGeneratorOctaves(this.rand, ;
        this.field_147434_q = new double[825];
        this.parabolicField = new float[25];

        for (int j = -2; j <= 2; ++j)
        {
            for (int k = -2; k <= 2; ++k)
            {
                float f = 10.0F / MathHelper.sqrt_float((float)(j * j + k * k) + 0.2F);
                this.parabolicField[j + 2 + (k + 2) * 5] = f;
            }
        }

        NoiseGenerator[] noiseGens = {noiseGeneratorOctaves1, noiseGeneratorOctaves2, noiseGeneratorOctaves3, noiseGeneratorPerlin, noiseGen5, noiseGen6, mobSpawnerNoise};
        noiseGens = TerrainGen.getModdedNoiseGenerators(par1World, this.rand, noiseGens);
        this.noiseGeneratorOctaves1 = (NoiseGeneratorOctaves)noiseGens[0];
        this.noiseGeneratorOctaves2 = (NoiseGeneratorOctaves)noiseGens[1];
        this.noiseGeneratorOctaves3 = (NoiseGeneratorOctaves)noiseGens[2];
        this.noiseGeneratorPerlin = (NoiseGeneratorPerlin)noiseGens[3];
        this.noiseGen5 = (NoiseGeneratorOctaves)noiseGens[4];
        this.noiseGen6 = (NoiseGeneratorOctaves)noiseGens[5];
        this.mobSpawnerNoise = (NoiseGeneratorOctaves)noiseGens[6];
    }

    public void func_147424_a(int par1, int par2, Block[] par3BlockArray)
    {
        byte b0 = 63;
        this.biomesForGeneration = this.worldObj.getWorldChunkManager().getBiomesForGeneration(this.biomesForGeneration, par1 * 4 - 2, par2 * 4 - 2, 10, 10);
        this.func_147423_a(par1 * 4, 0, par2 * 4);

        for (int k = 0; k < 4; ++k)
        {
            int l = k * 5;
            int i1 = (k + 1) * 5;

            for (int j1 = 0; j1 < 4; ++j1)
            {
                int k1 = (l + j1) * 33;
                int l1 = (l + j1 + 1) * 33;
                int i2 = (i1 + j1) * 33;
                int j2 = (i1 + j1 + 1) * 33;

                for (int k2 = 0; k2 < 32; ++k2)
                {
                    double d0 = 0.125D;
                    double d1 = this.field_147434_q[k1 + k2];
                    double d2 = this.field_147434_q[l1 + k2];
                    double d3 = this.field_147434_q[i2 + k2];
                    double d4 = this.field_147434_q[j2 + k2];
                    double d5 = (this.field_147434_q[k1 + k2 + 1] - d1) * d0;
                    double d6 = (this.field_147434_q[l1 + k2 + 1] - d2) * d0;
                    double d7 = (this.field_147434_q[i2 + k2 + 1] - d3) * d0;
                    double d8 = (this.field_147434_q[j2 + k2 + 1] - d4) * d0;

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

                        for (int i3 = 0; i3 < 4; ++i3)
                        {
                            int j3 = i3 + k * 4 << 12 | 0 + j1 * 4 << 8 | k2 * 8 + l2;
                            short short1 = 256;
                            j3 -= short1;
                            double d14 = 0.25D;
                            double d16 = (d11 - d10) * d14;
                            double d15 = d10 - d16;

                            for (int k3 = 0; k3 < 4; ++k3)
                            {
                                if ((d15 += d16) > 0.0D)
                                {
                                    par3BlockArray[j3 += short1] = mod_dimension.corrupted_stone;
                                }
                                else if (k2 * 8 + l2 < b0)
                                {
                                    par3BlockArray[j3 += short1] = mod_dimension.corrupted_water;
                                }
                                else
                                {
                                    par3BlockArray[j3 += short1] = null;
                                }
                            }

                            d10 += d12;
                            d11 += d13;
                        }

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

    public void replaceBlocksForBiome(int par1, int par2, Block[] par3BlockArray, byte[] par4ByteArray, BiomeGenBase[] par5BiomeGenBaseArray)
    {
        ChunkProviderEvent.ReplaceBiomeBlocks event = new ChunkProviderEvent.ReplaceBiomeBlocks(this, par1, par2, par3BlockArray, par4ByteArray, par5BiomeGenBaseArray);
        MinecraftForge.EVENT_BUS.post(event);
        if (event.getResult() == Result.DENY) return;

        double d0 = 0.03125D;
        this.stoneNoise = this.noiseGeneratorPerlin.func_151599_a(this.stoneNoise, (double)(par1 * 16), (double)(par2 * 16), 16, 16, d0 * 2.0D, d0 * 2.0D, 1.0D);

        for (int k = 0; k < 16; ++k)
        {
            for (int l = 0; l < 16; ++l)
            {
                BiomeGenBase biomegenbase = par5BiomeGenBaseArray[l + k * 16];
                biomegenbase.genTerrainBlocks(this.worldObj, this.rand, par3BlockArray, par4ByteArray, par1 * 16 + k, par2 * 16 + l, this.stoneNoise[l + k * 16]);
            }
        }
    }

    /**
     * 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
     */
    public Chunk provideChunk(int par1, int par2)
    {
        this.rand.setSeed((long)par1 * 341873128712L + (long)par2 * 132897987541L);
        Block[] ablock = new Block[65536];
        byte[] abyte = new byte[65536];
        this.func_147424_a(par1, par2, ablock);
        this.biomesForGeneration = this.worldObj.getWorldChunkManager().loadBlockGeneratorData(this.biomesForGeneration, par1 * 16, par2 * 16, 16, 16);
        this.replaceBlocksForBiome(par1, par2, ablock, abyte, this.biomesForGeneration);
        this.caveGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);
        this.ravineGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);

        if (this.mapFeaturesEnabled)
        {
            this.mineshaftGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);
            this.villageGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);
            this.strongholdGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);
            this.scatteredFeatureGenerator.func_151539_a(this, this.worldObj, par1, par2, ablock);
        }

        Chunk chunk = new Chunk(this.worldObj, ablock, abyte, par1, par2);
        byte[] abyte1 = chunk.getBiomeArray();

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

        chunk.generateSkylightMap();
        return chunk;
    }

    private void func_147423_a(int par1, int par2, int par3)
    {
        double d0 = 684.412D;
        double d1 = 684.412D;
        double d2 = 512.0D;
        double d3 = 512.0D;
        this.field_147426_g = this.noiseGen6.generateNoiseOctaves(this.field_147426_g, par1, par3, 5, 5, 200.0D, 200.0D, 0.5D);
        this.field_147427_d = this.noiseGeneratorOctaves3.generateNoiseOctaves(this.field_147427_d, par1, par2, par3, 5, 33, 5, 8.555150000000001D, 4.277575000000001D, 8.555150000000001D);
        this.field_147428_e = this.noiseGeneratorOctaves1.generateNoiseOctaves(this.field_147428_e, par1, par2, par3, 5, 33, 5, 684.412D, 684.412D, 684.412D);
        this.field_147425_f = this.noiseGeneratorOctaves2.generateNoiseOctaves(this.field_147425_f, par1, par2, par3, 5, 33, 5, 684.412D, 684.412D, 684.412D);
        boolean flag1 = false;
        boolean flag = false;
        int l = 0;
        int i1 = 0;
        double d4 = 8.5D;

        for (int j1 = 0; j1 < 5; ++j1)
        {
            for (int k1 = 0; k1 < 5; ++k1)
            {
                float f = 0.0F;
                float f1 = 0.0F;
                float f2 = 0.0F;
                byte b0 = 2;
                BiomeGenBase biomegenbase = this.biomesForGeneration[j1 + 2 + (k1 + 2) * 10];

                for (int l1 = -b0; l1 <= b0; ++l1)
                {
                    for (int i2 = -b0; i2 <= b0; ++i2)
                    {
                        BiomeGenBase biomegenbase1 = this.biomesForGeneration[j1 + l1 + 2 + (k1 + i2 + 2) * 10];
                        float f3 = biomegenbase1.rootHeight;
                        float f4 = biomegenbase1.heightVariation;

                        if (this.world_type == WorldType.AMPLIFIED && f3 > 0.0F)
                        {
                            f3 = 1.0F + f3 * 2.0F;
                            f4 = 1.0F + f4 * 4.0F;
                        }

                        float f5 = this.parabolicField[l1 + 2 + (i2 + 2) * 5] / (f3 + 2.0F);

                        if (biomegenbase1.rootHeight > biomegenbase.rootHeight)
                        {
                            f5 /= 2.0F;
                        }

                        f += f4 * f5;
                        f1 += f3 * f5;
                        f2 += f5;
                    }
                }

                f /= f2;
                f1 /= f2;
                f = f * 0.9F + 0.1F;
                f1 = (f1 * 4.0F - 1.0F) / 8.0F;
                double d12 = this.field_147426_g[i1] / 8000.0D;

                if (d12 < 0.0D)
                {
                    d12 = -d12 * 0.3D;
                }

                d12 = d12 * 3.0D - 2.0D;

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

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

                    d12 /= 1.4D;
                    d12 /= 2.0D;
                }
                else
                {
                    if (d12 > 1.0D)
                    {
                        d12 = 1.0D;
                    }

                    d12 /= 8.0D;
                }

                ++i1;
                double d13 = (double)f1;
                double d14 = (double)f;
                d13 += d12 * 0.2D;
                d13 = d13 * 8.5D / 8.0D;
                double d5 = 8.5D + d13 * 4.0D;

                for (int j2 = 0; j2 < 33; ++j2)
                {
                    double d6 = ((double)j2 - d5) * 12.0D * 128.0D / 256.0D / d14;

                    if (d6 < 0.0D)
                    {
                        d6 *= 4.0D;
                    }

                    double d7 = this.field_147428_e[l] / 512.0D;
                    double d8 = this.field_147425_f[l] / 512.0D;
                    double d9 = (this.field_147427_d[l] / 10.0D + 1.0D) / 2.0D;
                    double d10 = MathHelper.denormalizeClamp(d7, d8, d9) - d6;

                    if (j2 > 29)
                    {
                        double d11 = (double)((float)(j2 - 29) / 3.0F);
                        d10 = d10 * (1.0D - d11) + -10.0D * d11;
                    }

                    this.field_147434_q[l] = d10;
                    ++l;
                }
            }
        }
    }

    /**
     * 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)
    {
        BlockFalling.fallInstantly = true;
        int k = par2 * 16;
        int l = par3 * 16;
        BiomeGenBase biomegenbase = this.worldObj.getBiomeGenForCoords(k + 16, l + 16);
        this.rand.setSeed(this.worldObj.getSeed());
        long i1 = this.rand.nextLong() / 2L * 2L + 1L;
        long j1 = this.rand.nextLong() / 2L * 2L + 1L;
        this.rand.setSeed((long)par2 * i1 + (long)par3 * j1 ^ this.worldObj.getSeed());
        boolean flag = false;

        MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Pre(par1IChunkProvider, worldObj, rand, par2, par3, flag));

        if (this.mapFeaturesEnabled)
        {
            this.mineshaftGenerator.generateStructuresInChunk(this.worldObj, this.rand, par2, par3);
            flag = this.villageGenerator.generateStructuresInChunk(this.worldObj, this.rand, par2, par3);
            this.strongholdGenerator.generateStructuresInChunk(this.worldObj, this.rand, par2, par3);
            this.scatteredFeatureGenerator.generateStructuresInChunk(this.worldObj, this.rand, par2, par3);
        }

        int k1;
        int l1;
        int i2;

        if (biomegenbase != BiomeGenBase.desert && biomegenbase != BiomeGenBase.desertHills && !flag && this.rand.nextInt(4) == 0
            && TerrainGen.populate(par1IChunkProvider, worldObj, rand, par2, par3, flag, LAKE))
        {
            k1 = k + this.rand.nextInt(16) + 8;
            l1 = this.rand.nextInt(256);
            i2 = l + this.rand.nextInt(16) + 8;
            (new WorldGenLakes(mod_dimension.corrupted_water)).generate(this.worldObj, this.rand, k1, l1, i2);
        }

        if (TerrainGen.populate(par1IChunkProvider, worldObj, rand, par2, par3, flag, LAVA) && !flag && this.rand.nextInt( == 0)
        {
            k1 = k + this.rand.nextInt(16) + 8;
            l1 = this.rand.nextInt(this.rand.nextInt(248) + ;
            i2 = l + this.rand.nextInt(16) + 8;

            if (l1 < 63 || this.rand.nextInt(10) == 0)
            {
                (new WorldGenLakes(Blocks.lava)).generate(this.worldObj, this.rand, k1, l1, i2);
            }
        }

        boolean doGen = TerrainGen.populate(par1IChunkProvider, worldObj, rand, par2, par3, flag, DUNGEON);
        for (k1 = 0; doGen && k1 < 8; ++k1)
        {
            l1 = k + this.rand.nextInt(16) + 8;
            i2 = this.rand.nextInt(256);
            int j2 = l + this.rand.nextInt(16) + 8;
            (new WorldGenDungeons()).generate(this.worldObj, this.rand, l1, i2, j2);
        }

        biomegenbase.decorate(this.worldObj, this.rand, k, l);
        if (TerrainGen.populate(par1IChunkProvider, worldObj, rand, par2, par3, flag, ANIMALS))
        {
        SpawnerAnimals.performWorldGenSpawning(this.worldObj, biomegenbase, k + 8, l + 8, 16, 16, this.rand);
        }
        k += 8;
        l += 8;

        doGen = TerrainGen.populate(par1IChunkProvider, worldObj, rand, par2, par3, flag, ICE);
        for (k1 = 0; doGen && k1 < 16; ++k1)
        {
            for (l1 = 0; l1 < 16; ++l1)
            {
                i2 = this.worldObj.getPrecipitationHeight(k + k1, l + l1);

                if (this.worldObj.isBlockFreezable(k1 + k, i2 - 1, l1 + l))
                {
                    this.worldObj.setBlock(k1 + k, i2 - 1, l1 + l, Blocks.ice, 0, 2);
                }

                if (this.worldObj.func_147478_e(k1 + k, i2, l1 + l, true))
                {
                    this.worldObj.setBlock(k1 + k, i2, l1 + l, Blocks.snow_layer, 0, 2);
                }
            }
        }

        MinecraftForge.EVENT_BUS.post(new PopulateChunkEvent.Post(par1IChunkProvider, worldObj, rand, par2, par3, flag));

        BlockFalling.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;
    }

    /**
     * Save extra data not associated with any Chunk.  Not saved during autosave, only during world unload.  Currently
     * unimplemented.
     */
    public void saveExtraData() {}

    /**
     * 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 "RandomLevelSourceCorrupted";
    }

    /**
     * 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)
    {
        BiomeGenBase biomegenbase = this.worldObj.getBiomeGenForCoords(par2, par4);
        return par1EnumCreatureType == EnumCreatureType.monster && this.scatteredFeatureGenerator.func_143030_a(par2, par3, par4) ? this.scatteredFeatureGenerator.getScatteredFeatureSpawnList() : biomegenbase.getSpawnableList(par1EnumCreatureType);
    }

    public ChunkPosition func_147416_a(World par1, String par2String, int par3, int par4, int par5)
    {
        return "Stronghold".equals(par2String) && this.strongholdGenerator != null ? this.strongholdGenerator.func_151545_a(par1, par3, par4, par5) : null;
    }

    public int getLoadedChunkCount()
    {
        return 0;
    }

    public void recreateStructures(int par1, int par2)
    {
        if (this.mapFeaturesEnabled)
        {
            this.mineshaftGenerator.func_151539_a(this, this.worldObj, par1, par2, (Block[])null);
            this.villageGenerator.func_151539_a(this, this.worldObj, par1, par2, (Block[])null);
            this.strongholdGenerator.func_151539_a(this, this.worldObj, par1, par2, (Block[])null);
            this.scatteredFeatureGenerator.func_151539_a(this, this.worldObj, par1, par2, (Block[])null);
        }
    }
}

 

BiomeGenCorrupted:

package mod.mineworld.world.mod_dimension;
import java.util.Random;

import mod.mineworld.mod_dimension;
import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.init.Blocks;
import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.gen.feature.WorldGenerator;
public class BiomeGenCorrupted extends BiomeGenBase
{
private WorldGenerator UnDeadworldGeneratorBigTree;
public final Material blockMaterial;
public BiomeGenCorrupted(int par1)
{
	super(par1);
	this.blockMaterial = Material.water;
	this.setHeight(BiomeGenBase.height_MidHills);
	this.spawnableMonsterList.clear();
	this.spawnableCreatureList.clear();
	this.topBlock = mod_dimension.corrupted_grass;
	this.fillerBlock = mod_dimension.corrupted_stone;
}

@Override
public void genTerrainBlocks(World world, Random random, Block[] blocks, byte[] bytes, int int1, int int2, double d) {
	boolean flag = true;
	Block block = this.topBlock;
	byte b0 = (byte)(this.field_150604_aj & 255);
	Block block1 = this.fillerBlock;
	int k = -1;
	int l = (int)(d / 3.0D + 3.0D + random.nextDouble() * 0.25D);
	int i1 = int1 & 15;
	int j1 = int2 & 15;
	int k1 = blocks.length / 256;

	for (int l1 = 255; l1 >= 0; --l1)
	{
		int i2 = (j1 * 16 + i1) * k1 + l1;

		if (l1 <= 0 + random.nextInt(5))
		{
			blocks[i2] = Blocks.bedrock;
		}
		else
		{
			Block block2 = blocks[i2];

			if (block2 != null && block2.getMaterial() != Material.air)
			{
				if (block2 == mod_dimension.corrupted_grass)
				{
					if (k == -1)
					{
						if (l <= 0)
						{
							block = null;
							b0 = 0;
							block1 = mod_dimension.corrupted_grass;
						}
						else if (l1 >= 59 && l1 <= 64)
						{
							block = this.topBlock;
							b0 = (byte)(this.field_150604_aj & 255);
							block1 = this.fillerBlock;
						}

						if (l1 < 63 && (block == null || block.getMaterial() == Material.air))
						{
							if (this.getFloatTemperature(int1, l1, int2) < 0.15F)
							{
								block = Blocks.ice;
								b0 = 0;
							}
							else
							{
								block = mod_dimension.corrupted_water;
								b0 = 0;
							}
						}

						k = l;

						if (l1 >= 62)
						{
							blocks[i2] = block;
							bytes[i2] = b0;
						}
						else if (l1 < 56 - l)
						{
							block = null;
							block1 = mod_dimension.corrupted_grass;
							blocks[i2] = Blocks.gravel;
						}
						else
						{
							blocks[i2] = block1;
						}
					}
					else if (k > 0)
					{
						--k;
						blocks[i2] = block1;

						if (k == 0 && block1 == Blocks.sand)
						{
							k = random.nextInt(4) + Math.max(0, l1 - 63);
							block1 = Blocks.sandstone;
						}
					}
				}
			}
			else
			{
				k = -1;
			}
		}
	}
}
}

 

BlockCorruptedPortal:

package mod.mineworld.blocks.mod_dimension;

import mod.mineworld.mod_dimension;
import mod.mineworld.mod_tabs;
import mod.mineworld.world.mod_dimension.TeleporterCorrupted;
import net.minecraft.block.Block;
import net.minecraft.block.BlockPortal;
import net.minecraft.client.renderer.texture.IIconRegister;
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraft.init.Blocks;
import net.minecraft.server.MinecraftServer;
import net.minecraft.world.World;

public class BlockCorruptedPortal extends BlockPortal
{
public BlockCorruptedPortal()
{
	super();
}

@Override
public void onEntityCollidedWithBlock(World par1World, int par2, int par3, int par4, Entity par5Entity)
{
	if ((par5Entity.ridingEntity == null) && (par5Entity.riddenByEntity == null) && ((par5Entity instanceof EntityPlayerMP)))
	{
		EntityPlayerMP player = (EntityPlayerMP) par5Entity;

		MinecraftServer mServer = MinecraftServer.getServer();

		if (player.timeUntilPortal > 0)
		{
			player.timeUntilPortal = 10;
		}
		else if (player.dimension != 2)
		{
			player.timeUntilPortal = 10;

			player.mcServer.getConfigurationManager().transferPlayerToDimension(player, 2, new TeleporterCorrupted(mServer.worldServerForDimension(2)));
		}
		else
		{
			player.timeUntilPortal = 10;
			player.mcServer.getConfigurationManager().transferPlayerToDimension(player, 0, new TeleporterCorrupted(mServer.worldServerForDimension(1)));
		}
	}
}

public boolean func_150000_e(World par1World, int par2, int par3, int par4)
{
	byte b0 = 0;
	byte b1 = 0;

	if (par1World.getBlock(par2 - 1, par3, par4) == Blocks.sandstone || par1World.getBlock(par2 + 1, par3, par4) == Blocks.sandstone)
	{
		b0 = 1;
	}

	if (par1World.getBlock(par2, par3, par4 - 1) == Blocks.sandstone || par1World.getBlock(par2, par3, par4 + 1) == Blocks.sandstone)
	{
		b1 = 1;
	}

	if (b0 == b1)
	{
		return false;
	}
	else
	{
		if (par1World.isAirBlock(par2 - b0, par3, par4 - b1))
		{
			par2 -= b0;
			par4 -= b1;
		}

		int l;
		int i1;

		for (l = -1; l <= 2; ++l)
		{
			for (i1 = -1; i1 <= 3; ++i1)
			{
				boolean flag = l == -1 || l == 2 || i1 == -1 || i1 == 3;

				if (l != -1 && l != 2 || i1 != -1 && i1 != 3)
				{
					Block j1 = par1World.getBlock(par2 + b0 * l, par3 + i1, par4 + b1 * l);
					boolean isAirBlock = par1World.isAirBlock(par2 + b0 * l, par3 + i1, par4 + b1 * l);

					if (flag)
					{
						if (j1 != Blocks.sandstone)
						{
							return false;
						}
					}
					else if (!isAirBlock && j1 != Blocks.fire)
					{
						return false;
					}
				}
			}
		}

		for (l = 0; l < 2; ++l)
		{
			for (i1 = 0; i1 < 3; ++i1)
			{
				par1World.setBlock(par2 + b0 * l, par3 + i1, par4 + b1 * l, mod_dimension.corrupted_portal, 0, 2);
			}
		}

		return true;
	}
}

@Override
public void onNeighborBlockChange(World par1World, int par2, int par3, int par4, Block par5)
{
	byte b0 = 0;
	byte b1 = 1;

	if (par1World.getBlock(par2 - 1, par3, par4) == this || par1World.getBlock(par2 + 1, par3, par4) == this)
	{
		b0 = 1;
		b1 = 0;
	}

	int i1;

	for (i1 = par3; par1World.getBlock(par2, i1 - 1, par4) == this; --i1)
	{
		;
	}

	if (par1World.getBlock(par2, i1 - 1, par4) != Blocks.sandstone)
	{
		par1World.setBlockToAir(par2, par3, par4);
	}
	else
	{
		int j1;

		for (j1 = 1; j1 < 4 && par1World.getBlock(par2, i1 + j1, par4) == this; ++j1)
		{
			;
		}

		if (j1 == 3 && par1World.getBlock(par2, i1 + j1, par4) == Blocks.sandstone)
		{
			boolean flag = par1World.getBlock(par2 - 1, par3, par4) == this || par1World.getBlock(par2 + 1, par3, par4) == this;
			boolean flag1 = par1World.getBlock(par2, par3, par4 - 1) == this || par1World.getBlock(par2, par3, par4 + 1) == this;

			if (flag && flag1)
			{
				par1World.setBlockToAir(par2, par3, par4);
			}
			else
			{
				if ((par1World.getBlock(par2 + b0, par3, par4 + b1) != Blocks.sandstone || par1World.getBlock(par2 - b0, par3, par4 - b1) != this) && (par1World.getBlock(par2 - b0, par3, par4 - b1) != Blocks.sandstone || par1World.getBlock(par2 + b0, par3, par4 + b1) != this))
				{
					par1World.setBlockToAir(par2, par3, par4);
				}
			}
		}
		else
		{
			par1World.setBlockToAir(par2, par3, par4);
		}
	}
}

public void registerBlockIcons(IIconRegister par1)
{
	this.blockIcon = par1.registerIcon(this.getTextureName());
}
}

 

BlockCorruptedGrass:

package mod.mineworld.blocks.mod_dimension;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;

import java.util.Random;

import mod.mineworld.mod_dimension;
import mod.mineworld.mod_tabs;
import net.minecraft.block.Block;
import net.minecraft.block.BlockGrass;
import net.minecraft.block.material.Material;
import net.minecraft.client.renderer.texture.IIconRegister;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.init.Blocks;
import net.minecraft.item.Item;
import net.minecraft.util.IIcon;
import net.minecraft.world.ColorizerGrass;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class BlockCorruptedGrass extends BlockGrass
{
    private static final Logger logger = LogManager.getLogger();
    @SideOnly(Side.CLIENT)
    private IIcon icon_top;
    @SideOnly(Side.CLIENT)
    private IIcon icon_snowy;
    @SideOnly(Side.CLIENT)

    public BlockCorruptedGrass()
    {
        super();
        this.setTickRandomly(true);
        this.setCreativeTab(mod_tabs.tabDimensionBlocks);
    }

    /**
     * Gets the block's texture. Args: side, meta
     */
    @SideOnly(Side.CLIENT)
    public IIcon getIcon(int par1, int par2)
    {
        return par1 == 1 ? this.icon_top : (par1 == 0 ? Blocks.dirt.getBlockTextureFromSide(par1) : this.blockIcon);
    }

    /**
     * Ticks the block if it's been scheduled
     */
    public void updateTick(World par1World, int par2, int par3, int par4, Random par5)
    {
        if (!par1World.isRemote)
        {
            if (par1World.getBlockLightValue(par2, par3 + 1, par4) < 4 && par1World.getBlockLightOpacity(par2, par3 + 1, par4) > 2)
            {
                par1World.setBlock(par2, par3, par4, mod_dimension.corrupted_dirt);
            }
            else if (par1World.getBlockLightValue(par2, par3 + 1, par4) >= 9)
            {
                for (int l = 0; l < 4; ++l)
                {
                    int i1 = par2 + par5.nextInt(3) - 1;
                    int j1 = par3 + par5.nextInt(5) - 3;
                    int k1 = par4 + par5.nextInt(3) - 1;
                    Block block = par1World.getBlock(i1, j1 + 1, k1);

                    if (par1World.getBlock(i1, j1, k1) ==  mod_dimension.corrupted_dirt && par1World.getBlockMetadata(i1, j1, k1) == 0 && par1World.getBlockLightValue(i1, j1 + 1, k1) >= 4 && par1World.getBlockLightOpacity(i1, j1 + 1, k1) <= 2)
                    {
                        par1World.setBlock(i1, j1, k1,  mod_dimension.corrupted_grass);
                    }
                }
            }
        }
    }

    public Item getItemDropped(int par1, Random par2Random, int par3)
    {
        return Item.getItemFromBlock(mod_dimension.corrupted_dirt);
    }

    @SideOnly(Side.CLIENT)
    public IIcon getIcon(IBlockAccess par1IBlockAccess, int par2, int par3, int par4, int par5)
    {
        if (par5 == 1)
        {
            return this.icon_top;
        }
        else if (par5 == 0)
        {
            return mod_dimension.corrupted_dirt.getBlockTextureFromSide(par5);
        }
        else
        {
            Material material = par1IBlockAccess.getBlock(par2, par3 + 1, par4).getMaterial();
            return material != Material.snow && material != Material.craftedSnow ? this.blockIcon : this.icon_snowy;
        }
    }

    @SideOnly(Side.CLIENT)
    public void registerBlockIcons(IIconRegister par1IconRegister)
    {
        this.blockIcon = par1IconRegister.registerIcon(this.getTextureName() + "_side");
        this.icon_top = par1IconRegister.registerIcon(this.getTextureName() + "_top");
    }
    
}

 

BlockCorruptedStone:

package mod.mineworld.blocks.mod_dimension;

import java.util.Random;

import mod.mineworld.mod_dimension;
import mod.mineworld.mod_tabs;
import net.minecraft.block.BlockStone;
import net.minecraft.block.material.Material;
import net.minecraft.item.Item;

public class BlockCorruptedStone extends BlockStone {

public BlockCorruptedStone()
{
	super();
	this.setCreativeTab(mod_tabs.tabDimensionBlocks);
}

public Item getItemDropped(int par1, Random par2Random, int par3)
    {
        return Item.getItemFromBlock(mod_dimension.corrupted_cobblestone);
    }
}

 

BlockCorruptedWater:

package mod.mineworld.blocks.mod_dimension;

import mod.mineworld.MineWorld;
import net.minecraft.block.material.Material;
import net.minecraft.client.renderer.texture.IIconRegister;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.util.IIcon;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World;
import net.minecraftforge.fluids.BlockFluidClassic;
import net.minecraftforge.fluids.Fluid;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;

public class BlockCorruptedWater extends BlockFluidClassic {

        @SideOnly(Side.CLIENT)
        protected IIcon stillIcon;
        @SideOnly(Side.CLIENT)
        protected IIcon flowingIcon;
        
        public BlockCorruptedWater(Fluid fluid, Material material) {
                super(fluid, material);
        }
        
        @Override
        public IIcon getIcon(int side, int meta) {
                return (side == 0 || side == 1)? stillIcon : flowingIcon;
        }
        
        @SideOnly(Side.CLIENT)
        @Override
        public void registerBlockIcons(IIconRegister register) {
                stillIcon = register.registerIcon(MineWorld.MODID + ":mod_dimension/" + "corrupted_water_still");
                flowingIcon = register.registerIcon(MineWorld.MODID + ":mod_dimension/" + "corrupted_water_flow");
        }
        
        @Override
        public boolean canDisplace(IBlockAccess world, int x, int y, int z) {
                if (world.getBlock(x,  y,  z).getMaterial().isLiquid()) return false;
                return super.canDisplace(world, x, y, z);
        }
        
        @Override
        public boolean displaceIfPossible(World world, int x, int y, int z) {
                if (world.getBlock(x,  y,  z).getMaterial().isLiquid()) return false;
                return super.displaceIfPossible(world, x, y, z);
        }
        
}

 

BlockDimension:

package mod.mineworld.blocks.mod_dimension;

import mod.mineworld.mod_tabs;
import net.minecraft.block.Block;
import net.minecraft.block.material.Material;

public class BlockDimension extends Block{

public BlockDimension(Material par1) {
	super(par1);
	this.setCreativeTab(mod_tabs.tabDimensionBlocks);
}

}

 

And in the main sub-mod file:

Declarations

public static Block corrupted_grass;
public static Block corrupted_dirt;
public static Block corrupted_stone;
public static Block corrupted_cobblestone;
public static Block corrupted_water;
public static Block corrupted_portal;
public static BiomeGenBase biomeCorrupted;
public static Fluid corrupted_fluid = new Fluid("corrupted_fluid");

 

And inside the preInit method

corrupted_grass=new BlockCorruptedGrass().setBlockName("corrupted_grass").setHardness(0.6F).setStepSound(Block.soundTypeGrass).setBlockTextureName(MineWorld.MODID + ":mod_dimension/" + "corrupted_grass");
corrupted_dirt=new BlockDimension(Material.ground).setHardness(0.5F).setStepSound(Block.soundTypeGravel).setBlockName("corrupted_dirt").setBlockTextureName(MineWorld.MODID + ":mod_dimension/" + "corrupted_dirt");
corrupted_stone=new BlockCorruptedStone().setHardness(1.5F).setResistance(10.0F).setStepSound(Block.soundTypePiston).setBlockName("corrupted_stone").setBlockTextureName(MineWorld.MODID + ":mod_dimension/" + "corrupted_stone");
corrupted_cobblestone = new BlockDimension(Material.rock).setHardness(2.0F).setResistance(10.0F).setStepSound(Block.soundTypePiston).setBlockName("corrupted_cobblestone").setBlockTextureName(MineWorld.MODID + ":mod_dimension/" + "corrupted_cobblestone");
corrupted_portal = (new BlockCorruptedPortal()).setHardness(-1.0F).setStepSound(Block.soundTypeGlass).setLightLevel(0.75F).setBlockName("corrupted_portal").setBlockTextureName(MineWorld.MODID + ":mod_dimension/" + "corrupted_portal");
biomeCorrupted = new BiomeGenCorrupted(160).setBiomeName("Corrupted Plains");

GameRegistry.registerBlock(corrupted_grass, "corrupted_grass");
GameRegistry.registerBlock(corrupted_dirt, "corrupted_dirt");
GameRegistry.registerBlock(corrupted_stone, "corrupted_stone");
GameRegistry.registerBlock(corrupted_cobblestone, "corrupted_cobblestone");
FluidRegistry.registerFluid(corrupted_fluid);
corrupted_water = new BlockCorruptedWater(corrupted_fluid, Material.water).setBlockName("corrupted_water");
GameRegistry.registerBlock(corrupted_water, "corrupted_water");
GameRegistry.registerBlock(corrupted_portal, "corrupted_portal");
BiomeDictionary.registerBiomeType(biomeCorrupted, Type.FOREST, Type.MOUNTAIN);
DimensionManager.registerProviderType(3, WorldProviderCorrupted.class, false);
DimensionManager.registerDimension(2, 3);

 

Thanks in advice for all who will support me :D

Don't blame me if i always ask for your help. I just want to learn to be better :)

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • esto es lo que me marca con uno de los mods que tengo y no se la razón ya que estoy ocupando muchos mods a la vez y el código esta muy extenso  ---- Informe de fallos de Minecraft ---- // Apuesto a que los Cylons no tendrían este problema. Hora: 2024-07-18 17:46:01 Descripción: Se ha producido un error al cargar el mod java.lang.Exception: La carga del mod ha fallado     en net.minecraftforge.logging.CrashReportExtender.dumpModLoadingCrashReport(CrashReportExtender.java:55) ~[forge-1.19.2-43.4.2-universal.jar%23230!/:?] {re:classloading}     en net.minecraftforge.client.loading.ClientModLoader.completeModLoading(ClientModLoader.java:167) ~[forge-1.19.2-43.4.2-universal.jar%23230!/:?] {re:classloading,pl:runtimedistcleaner:A}     en net.minecraft.client.Minecraft.lambda$new$2(Minecraft.java:585) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:mixin,pl:accesstransformer:B,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,pl:mixin:APP:balm.mixins.json:MinecraftMixin,pl:mixin:APP:playerrevive.mixins.json:MinecraftAccessor,pl:mixin:A,pl:runtimedistcleaner:A}     en net.minecraft.Util.m_137521_(Util.java:605) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:classloading,xf:OptiFine:default}     en net.minecraft.client.Minecraft.lambda$new$3(Minecraft.java:579) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:mixin,pl:accesstransformer:B,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,pl:mixin:APP:balm.mixins.json:MinecraftMixin,pl:mixin:APP:playerrevive.mixins.json:MinecraftAccessor,pl:mixin:A,pl:runtimedistcleaner:A}     en net.minecraft.client.gui.screens.LoadingOverlay.m_6305_(LoadingOverlay.java:196) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:classloading,xf:OptiFine:default}     en net.minecraft.client.renderer.GameRenderer.m_109093_(GameRenderer.java:1290) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:mixin,pl:accesstransformer:B,xf:OptiFine:default,re:classloading,pl:accesstransformer:B,xf:OptiFine:default}     en net.minecraft.client.Minecraft.m_91383_(Minecraft.java:1115) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:mixin,pl:accesstransformer:B,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,pl:mixin:APP:balm.mixins.json:MinecraftMixin,pl:mixin:APP:playerrevive.mixins.json:MinecraftAccessor,pl:mixin:A,pl:runtimedistcleaner:A}     en net.minecraft.cliente.Minecraft.m_91374_(Minecraft.java:700) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:mixin,pl:accesstransformer:B,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,pl:mixin:APP:balm.mixins.json:MinecraftMixin,pl:mixin:APP:playerrevive.mixins.json:MinecraftAccessor,pl:mixin:A,pl:runtimedistcleaner:A}     en net.minecraft.client.main.Main.m_239872_(Main.java:212) ~[cliente-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:classloading,pl:runtimedistcleaner:A}     en net.minecraft.client.main.Main.main(Main.java:51) ~[client-1.19.2-20220805.130853-srg.jar%23225!/:?] {re:classloading,pl:runtimedistcleaner:A}     en jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Método nativo) ~[?:?] {}     en jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[?:?] {}     en jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] {}     en java.lang.reflect.Method.invoke(Method.java:568) ~[?:?] {}     en net.minecraftforge.fml.loading.targets.CommonClientLaunchHandler.lambda$launchService$0(CommonClientLaunchHandler.java:27) ~[fmlloader-1.19.2-43.4.2.jar%23101!/:?] {}     en cpw.mods.modlauncher.LaunchServiceHandlerDecorator.launch(LaunchServiceHandlerDecorator.java:30) [modlauncher-10.0.8.jar%2388!/:?] {}     en cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:53) [modlauncher-10.0.8.jar%2388!/:?] {} en cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:71) [modlauncher-10.0.8.jar     %2388!/:?] {}     en cpw.mods.modlauncher.run(Launcher.java:106) [modlauncher-10.0.8.jar%2388!/:?] {}     en cpw.mods.modlauncher.Launcher.main(Launcher.java:77) [modlauncher-10.0.8.jar%2388!/:?] {}     en cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:26) [modlauncher-10.0.8.jar%2388!/:?] {} en cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:23)     [modlauncher-10.0.8.jar%2388!/:?] {}     en cpw.mods.bootstraplauncher.BootstrapLauncher.main(BootstrapLauncher.java:141) [bootstraplauncher-1.1.2.jar:?] {} A continuación se muestra un recorrido detallado del error, su ruta de código y todos los detalles conocidos: --------------------------------------------------------------------------------------- -- Cabeza -- Hilo: Hilo de renderizado Stacktrace:     at corgitaco.corgilib.serialization.jankson.JanksonUtil.readConfig(JanksonUtil.java:139) ~[CorgiLib-forge-1.19.2-1.0.0.34.jar%23198!/:1.0.0.34] {re:classloading} -- MOD byg -- Detalles:     Archivo del mod: /C:/Users/jelia/AppData/Roaming/.minecraft/mods/Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar     Mensaje de error: Oh The Biomes You'll Go (byg) encontró un error durante la fase de evento completa         java.lang.IllegalArgumentException: Jankson file reading for "C:\Users\jelia\AppData\Roaming\.minecraft\config\byg\trades.json5" failed due to the following error(s): Jankson file reading for "C:\Users\jelia\AppData\Roaming\.minecraft\config\byg\trades.json5" failed due to the following error(s): Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "1": [ { "config": { "emerald_cost": 5, "item": "byg:aspen_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:baobab_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:blue_enchanted_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:pink_cherry_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:white_cherry_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:cika_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:cypress_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:ebony_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:ether_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:fir_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:green_enchanted_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:holly_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:jacaranda_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:indigo_jacaranda_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:lament_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:mahogany_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:mangrove_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:silver_maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:nightshade_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:palm_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:palo_verde_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:pine_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:rainbow_eucalyptus_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:redwood_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:skyris_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:willow_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:witch_hazel_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:zelkova_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:withering_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:araucaria_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:blue_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_zelkova_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:joshua_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orchard_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:yellow_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:yellow_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:skyris_vine", "max_uses": 12, "number_of_items": 2, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:poison_ivy", "max_uses": 12, "number_of_items": 2, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "3": [ { "config": { "emerald_cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 1, "item": "byg:dacite", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:dacite", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:soapstone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:soapstone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:red_rock", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:red_rock", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_and_emeralds_to_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "1": [ { "config": { "cost": 24, "item": "byg:cattail_sprout", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 10, "item": "byg:baobab_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 16, "item": "byg:aloe_vera", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 24, "item": "byg:green_apple", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "cost": 10, "item": "byg:joshua_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 2, "from_count": 16, "from_item": "minecraft:dirt", "max_uses": 4, "to_count": 16, "to_item": "byg:lush_dirt", "villager_xp": 4 }, "type": "byg:items_and_emeralds_to_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "2": [ { "config": { "cost": 10, "item": "byg:blueberries", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "4": [ { "config": { "emerald_cost": 3, "item": "byg:chain_plating", "max_uses": 12, "number_of_items": 7, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "1": [ { "config": { "cost": 10, "item": "minecraft:red_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:brown_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:green_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 8, "item": "byg:wood_blewit", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 8, "item": "byg:white_puffball_cap", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "emerald_cost": 4, "item": "byg:white_puffball_spores", "max_uses": 4, "number_of_items": 5, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 10, "item": "minecraft:crimson_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:warped_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:sythian_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 4, "item": "byg:witch_hazel_branch", "max_uses": 4, "number_of_items": 9, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 10, "item": "byg:witch_hazel_blossom", "max_uses": 10, "number_of_items": 1, "villager_xp": 3 }, "type": "byg:items_for_emeralds" } ], "5": [ { "config": { "cost": 10, "item": "byg:imparius_mushroom", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:shulkren_fungus", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:fungal_imparius", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" } ] } missed input: { "byg:forager": { "1": [ { "config": { "cost": 10, "item": "minecraft:red_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:brown_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:green_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 8, "item": "byg:wood_blewit", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 8, "item": "byg:white_puffball_cap", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "emerald_cost": 4, "item": "byg:white_puffball_spores", "max_uses": 4, "number_of_items": 5, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 10, "item": "minecraft:crimson_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:warped_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:sythian_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 4, "item": "byg:witch_hazel_branch", "max_uses": 4, "number_of_items": 9, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 10, "item": "byg:witch_hazel_blossom", "max_uses": 10, "number_of_items": 1, "villager_xp": 3 }, "type": "byg:items_for_emeralds" } ], "5": [ { "config": { "cost": 10, "item": "byg:imparius_mushroom", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:shulkren_fungus", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:fungal_imparius", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" } ] }, "minecraft:armorer": { "1": [], "2": [], "3": [], "4": [ { "config": { "emerald_cost": 3, "item": "byg:chain_plating", "max_uses": 12, "number_of_items": 7, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ], "5": [] }, "minecraft:butcher": { "1": [], "2": [ { "config": { "cost": 10, "item": "byg:blueberries", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [], "4": [], "5": [] }, "minecraft:farmer": { "1": [ { "config": { "cost": 24, "item": "byg:cattail_sprout", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 10, "item": "byg:baobab_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 16, "item": "byg:aloe_vera", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 24, "item": "byg:green_apple", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "cost": 10, "item": "byg:joshua_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 2, "from_count": 16, "from_item": "minecraft:dirt", "max_uses": 4, "to_count": 16, "to_item": "byg:lush_dirt", "villager_xp": 4 }, "type": "byg:items_and_emeralds_to_items" } ], "5": [] }, "minecraft:mason": { "1": [], "2": [], "3": [ { "config": { "emerald_cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 1, "item": "byg:dacite", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:dacite", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:soapstone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:soapstone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:red_rock", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:red_rock", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "5": [] } }     Mod Version: 2.0.1.6     Mod Issue URL: https://github.com/AOCAWOL/BYG/issues     Exception message: java.lang.IllegalArgumentException: Jankson file reading for "C:\Users\jelia\AppData\Roaming\.minecraft\config\byg\trades.json5" failed due to the following error(s): Jankson file reading for "C:\Users\jelia\AppData\Roaming\.minecraft\config\byg\trades.json5" failed due to the following error(s): Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "1": [ { "config": { "emerald_cost": 5, "item": "byg:aspen_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:baobab_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:blue_enchanted_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:pink_cherry_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:white_cherry_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:cika_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:cypress_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:ebony_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:ether_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:fir_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:green_enchanted_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:holly_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:jacaranda_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:indigo_jacaranda_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:lament_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:mahogany_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:mangrove_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:silver_maple_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:nightshade_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:palm_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:palo_verde_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:pine_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:rainbow_eucalyptus_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:redwood_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:skyris_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:willow_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:witch_hazel_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:zelkova_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:withering_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:araucaria_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:blue_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:brown_zelkova_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:joshua_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orange_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:orchard_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_oak_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:red_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:yellow_birch_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:yellow_spruce_sapling", "max_uses": 12, "number_of_items": 1, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:skyris_vine", "max_uses": 12, "number_of_items": 2, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 5, "item": "byg:poison_ivy", "max_uses": 12, "number_of_items": 2, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "3": [ { "config": { "emerald_cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 1, "item": "byg:dacite", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:dacite", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:soapstone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:soapstone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:red_rock", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:red_rock", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_and_emeralds_to_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "1": [ { "config": { "cost": 24, "item": "byg:cattail_sprout", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 10, "item": "byg:baobab_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 16, "item": "byg:aloe_vera", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 24, "item": "byg:green_apple", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "cost": 10, "item": "byg:joshua_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 2, "from_count": 16, "from_item": "minecraft:dirt", "max_uses": 4, "to_count": 16, "to_item": "byg:lush_dirt", "villager_xp": 4 }, "type": "byg:items_and_emeralds_to_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "2": [ { "config": { "cost": 10, "item": "byg:blueberries", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds missed input: { "4": [ { "config": { "emerald_cost": 3, "item": "byg:chain_plating", "max_uses": 12, "number_of_items": 7, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ] }; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:items_for_emeralds; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items; Unknown registry key in ResourceKey[minecraft:root / corgilib:villager_trades_item_listing]: byg:emerald_for_items missed input: { "1": [ { "config": { "cost": 10, "item": "minecraft:red_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:brown_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:green_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 8, "item": "byg:wood_blewit", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 8, "item": "byg:white_puffball_cap", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "emerald_cost": 4, "item": "byg:white_puffball_spores", "max_uses": 4, "number_of_items": 5, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 10, "item": "minecraft:crimson_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:warped_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:sythian_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 4, "item": "byg:witch_hazel_branch", "max_uses": 4, "number_of_items": 9, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 10, "item": "byg:witch_hazel_blossom", "max_uses": 10, "number_of_items": 1, "villager_xp": 3 }, "type": "byg:items_for_emeralds" } ], "5": [ { "config": { "cost": 10, "item": "byg:imparius_mushroom", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:shulkren_fungus", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:fungal_imparius", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" } ] } missed input: { "byg:forager": { "1": [ { "config": { "cost": 10, "item": "minecraft:red_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:brown_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:green_mushroom", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 8, "item": "byg:wood_blewit", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 8, "item": "byg:white_puffball_cap", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "emerald_cost": 4, "item": "byg:white_puffball_spores", "max_uses": 4, "number_of_items": 5, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 10, "item": "minecraft:crimson_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "minecraft:warped_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:sythian_fungus", "max_uses": 12, "villager_xp": 3 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 4, "item": "byg:witch_hazel_branch", "max_uses": 4, "number_of_items": 9, "villager_xp": 3 }, "type": "byg:items_for_emeralds" }, { "config": { "emerald_cost": 10, "item": "byg:witch_hazel_blossom", "max_uses": 10, "number_of_items": 1, "villager_xp": 3 }, "type": "byg:items_for_emeralds" } ], "5": [ { "config": { "cost": 10, "item": "byg:imparius_mushroom", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:shulkren_fungus", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 10, "item": "byg:fungal_imparius", "max_uses": 12, "villager_xp": 4 }, "type": "byg:emerald_for_items" } ] }, "minecraft:armorer": { "1": [], "2": [], "3": [], "4": [ { "config": { "emerald_cost": 3, "item": "byg:chain_plating", "max_uses": 12, "number_of_items": 7, "villager_xp": 2 }, "type": "byg:items_for_emeralds" } ], "5": [] }, "minecraft:butcher": { "1": [], "2": [ { "config": { "cost": 10, "item": "byg:blueberries", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [], "4": [], "5": [] }, "minecraft:farmer": { "1": [ { "config": { "cost": 24, "item": "byg:cattail_sprout", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "2": [ { "config": { "cost": 10, "item": "byg:baobab_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 16, "item": "byg:aloe_vera", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" }, { "config": { "cost": 24, "item": "byg:green_apple", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "3": [ { "config": { "cost": 10, "item": "byg:joshua_fruit", "max_uses": 12, "villager_xp": 2 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 2, "from_count": 16, "from_item": "minecraft:dirt", "max_uses": 4, "to_count": 16, "to_item": "byg:lush_dirt", "villager_xp": 4 }, "type": "byg:items_and_emeralds_to_items" } ], "5": [] }, "minecraft:mason": { "1": [], "2": [], "3": [ { "config": { "emerald_cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:rocky_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:mossy_stone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "4": [ { "config": { "emerald_cost": 1, "item": "byg:dacite", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:dacite", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:soapstone", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:soapstone", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" }, { "config": { "emerald_cost": 1, "item": "byg:red_rock", "max_uses": 12, "number_of_items": 12, "villager_xp": 2 }, "type": "byg:items_for_emeralds" }, { "config": { "cost": 1, "item": "byg:red_rock", "max_uses": 12, "villager_xp": 12 }, "type": "byg:emerald_for_items" } ], "5": [] } } Stacktrace:     at corgitaco.corgilib.serialization.jankson.JanksonUtil.readConfig(JanksonUtil.java:139) ~[CorgiLib-forge-1.19.2-1.0.0.34.jar%23198!/:1.0.0.34] {re:classloading}     at potionstudios.byg.common.entity.npc.TradesConfig.readConfig(TradesConfig.java:66) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:classloading}     at potionstudios.byg.common.entity.npc.TradesConfig.getConfig(TradesConfig.java:47) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:classloading}     at potionstudios.byg.config.BYGConfigHandler.lambda$loadAllConfigs$6(BYGConfigHandler.java:50) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:mixin,re:classloading}     at potionstudios.byg.config.BYGConfigHandler.tryCatchErrors(BYGConfigHandler.java:70) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:mixin,re:classloading}     at potionstudios.byg.config.BYGConfigHandler.loadAllConfigs(BYGConfigHandler.java:50) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:mixin,re:classloading}     at potionstudios.byg.config.BYGConfigHandler.loadAllConfigs(BYGConfigHandler.java:33) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:mixin,re:classloading}     at potionstudios.byg.BYG.commonLoad(BYG.java:63) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:mixin,re:classloading}     at potionstudios.byg.BYGForge.commonLoad(BYGForge.java:89) ~[Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar%23216!/:2.0.1.6] {re:classloading}     at net.minecraftforge.eventbus.EventBus.doCastFilter(EventBus.java:260) ~[eventbus-6.0.3.jar%2385!/:?] {}     at net.minecraftforge.eventbus.EventBus.lambda$addListener$11(EventBus.java:252) ~[eventbus-6.0.3.jar%2385!/:?] {}     at net.minecraftforge.eventbus.EventBus.post(EventBus.java:315) ~[eventbus-6.0.3.jar%2385!/:?] {}     at net.minecraftforge.eventbus.EventBus.post(EventBus.java:296) ~[eventbus-6.0.3.jar%2385!/:?] {}     at net.minecraftforge.fml.javafmlmod.FMLModContainer.acceptEvent(FMLModContainer.java:114) ~[javafmllanguage-1.19.2-43.4.2.jar%23227!/:?] {}     at net.minecraftforge.fml.ModContainer.lambda$buildTransitionHandler$4(ModContainer.java:123) ~[fmlcore-1.19.2-43.4.2.jar%23226!/:?] {}     at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) ~[?:?] {}     at java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1796) ~[?:?] {}     at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373) ~[?:?] {}     at java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182) ~[?:?] {}     at java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655) ~[?:?] {re:computing_frames}     at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622) ~[?:?] {re:computing_frames}     at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165) ~[?:?] {} -- System Details -- Details:     Minecraft Version: 1.19.2     Minecraft Version ID: 1.19.2     Operating System: Windows 10 (amd64) version 10.0     Java Version: 17.0.8, Microsoft     Java VM Version: OpenJDK 64-Bit Server VM (mixed mode), Microsoft     Memory: 883961880 bytes (843 MiB) / 1996488704 bytes (1904 MiB) up to 4160749568 bytes (3968 MiB)     CPUs: 8     Processor Vendor: GenuineIntel     Processor Name: Intel(R) Core(TM) i5-1035G1 CPU @ 1.00GHz     Identifier: Intel64 Family 6 Model 126 Stepping 5     Microarchitecture: Ice Lake (Client)     Frequency (GHz): 1.19     Number of physical packages: 1     Number of physical CPUs: 4     Number of logical CPUs: 8     Graphics card #0 name: Intel(R) UHD Graphics     Graphics card #0 vendor: Intel Corporation (0x8086)     Graphics card #0 VRAM (MB): 1024.00     Graphics card #0 deviceId: 0x8a56     Graphics card #0 versionInfo: DriverVersion=30.0.100.9864     Memory slot #0 capacity (MB): 4096.00     Memory slot #0 clockSpeed (GHz): 2.67     Memory slot #0 type: Unknown     Memory slot #1 capacity (MB): 4096.00     Memory slot #1 clockSpeed (GHz): 2.67     Memory slot #1 type: Unknown     Virtual memory max (MB): 16126.37     Virtual memory used (MB): 9429.52     Swap memory total (MB): 8192.00     Swap memory used (MB): 1427.37     JVM Flags: 8 total; -XX:+UnlockExperimentalVMOptions -XX:+UseG1GC -XX:G1NewSizePercent=20 -XX:G1ReservePercent=20 -XX:MaxGCPauseMillis=50 -XX:G1HeapRegionSize=16M -Xmx3967m -XX:HeapDumpPath=MojangTricksIntelDriversForPerformance_javaw.exe_minecraft.exe.heapdump     OptiFine Version: OptiFine_1.19.2_HD_U_I2     OptiFine Build: 20230623-171717     Render Distance Chunks: 2     Mipmaps: 3     Anisotropic Filtering: 1     Antialiasing: 0     Multitexture: false     Shaders: null     OpenGlVersion: 3.2.0 - Build 30.0.100.9864     OpenGlRenderer: Intel(R) UHD Graphics     OpenGlVendor: Intel     CpuCount: 8     ModLauncher: 10.0.8+10.0.8+main.0ef7e830     ModLauncher launch target: forgeclient     ModLauncher naming: srg     ModLauncher services:          mixin-0.8.5.jar mixin PLUGINSERVICE          eventbus-6.0.3.jar eventbus PLUGINSERVICE          fmlloader-1.19.2-43.4.2.jar slf4jfixer PLUGINSERVICE          fmlloader-1.19.2-43.4.2.jar object_holder_definalize PLUGINSERVICE          fmlloader-1.19.2-43.4.2.jar runtime_enum_extender PLUGINSERVICE          fmlloader-1.19.2-43.4.2.jar capability_token_subclass PLUGINSERVICE          accesstransformers-8.0.4.jar accesstransformer PLUGINSERVICE          fmlloader-1.19.2-43.4.2.jar runtimedistcleaner PLUGINSERVICE          modlauncher-10.0.8.jar mixin TRANSFORMATIONSERVICE          modlauncher-10.0.8.jar OptiFine TRANSFORMATIONSERVICE          modlauncher-10.0.8.jar fml TRANSFORMATIONSERVICE      FML Language Providers:          [email protected]         lowcodefml@null         javafml@null     Mod List:          client-1.19.2-20220805.130853-srg.jar             |Minecraft                     |minecraft                     |1.19.2              |DONE      |Manifest: a1:d4:5e:04:4f:d3:d6:e0:7b:37:97:cf:77:b0:de:ad:4a:47:ce:8c:96:49:5f:0a:cf:8c:ae:b2:6d:4b:8a:3f         FarmersDelight-1.19.2-1.2.2.jar                   |Farmer's Delight              |farmersdelight                |1.19.2-1.2.2        |DONE      |Manifest: NOSIGNATURE         TerraBlender-forge-1.19.2-2.0.1.166.jar           |TerraBlender                  |terrablender                  |2.0.1.166           |DONE      |Manifest: NOSIGNATURE         CozyHome-2.2.7-1.19.2.jar                         |Cozy Home                     |cozy_home                     |1.0.0               |DONE      |Manifest: NOSIGNATURE         EasyAnvils-v4.0.11-1.19.2-Forge.jar               |Easy Anvils                   |easyanvils                    |4.0.11              |DONE      |Manifest: 9a:09:85:98:65:c4:8c:11:c5:49:f6:d6:33:23:39:df:8d:b4:ff:92:84:b8:bd:a5:83:9f:ac:7f:2a:d1:4b:6a         trashslot-forge-1.19.2-12.1.0.jar                 |TrashSlot                     |trashslot                     |12.1.0              |DONE      |Manifest: NOSIGNATURE         beautify-1.4.3.jar                                |Beautify                      |beautify                      |1.4.3               |DONE      |Manifest: NOSIGNATURE         player-animation-lib-forge-1.0.2.jar              |Player Animator               |playeranimator                |1.0.2               |DONE      |Manifest: NOSIGNATURE         CreativeCore_FORGE_v2.9.3_mc1.19.2 - copia.jar    |CreativeCore                  |creativecore                  |2.9.3               |DONE      |Manifest: NOSIGNATURE         EasyMagic-v4.3.3-1.19.2-Forge.jar                 |Easy Magic                    |easymagic                     |4.3.3               |DONE      |Manifest: 9a:09:85:98:65:c4:8c:11:c5:49:f6:d6:33:23:39:df:8d:b4:ff:92:84:b8:bd:a5:83:9f:ac:7f:2a:d1:4b:6a         libraryferret-forge-1.19.2-4.0.0.jar              |Library ferret                |libraryferret                 |4.0.0               |DONE      |Manifest: NOSIGNATURE         curios-forge-1.19.2-5.1.6.2.jar                   |Curios API                    |curios                        |1.19.2-5.1.6.2      |DONE      |Manifest: NOSIGNATURE         wardrobe-1.0.3-1.19.2.jar                         |Wardrobe                      |wardrobe                      |1.0.3               |DONE      |Manifest: NOSIGNATURE         Croptopia-1.19.2-FORGE-2.2.2.jar                  |Croptopia                     |croptopia                     |2.2.2               |DONE      |Manifest: NOSIGNATURE         camera-1.19.2-1.0.4.jar                           |Camera Mod                    |camera                        |1.19.2-1.0.4        |DONE      |Manifest: NOSIGNATURE         CTM-1.19.2-1.1.6+8.jar                            |ConnectedTexturesMod          |ctm                           |1.19.2-1.1.6+8      |DONE      |Manifest: NOSIGNATURE         modernlife-1.19.2-1.59 (1).jar                    |Modern Life                   |modernlife                    |1.19.2-1.59         |DONE      |Manifest: NOSIGNATURE         citadel-2.1.3-1.19.jar                            |Citadel                       |citadel                       |2.1.3               |DONE      |Manifest: NOSIGNATURE         alexsmobs-1.21.1.jar                              |Alex's Mobs                   |alexsmobs                     |1.21.1              |DONE      |Manifest: NOSIGNATURE         artifacts-1.19.2-5.0.5.jar                        |Artifacts                     |artifacts                     |1.19.2-5.0.5        |DONE      |Manifest: NOSIGNATURE         CustomPlayerModels-1.19-0.6.17a.jar               |Customizable Player Models    |cpm                           |0.6.17a             |DONE      |Manifest: NOSIGNATURE         bettervillage-forge-1.19.2-3.2.0.jar              |Better village                |bettervillage                 |3.1.0               |DONE      |Manifest: NOSIGNATURE         elevatorid-1.19.2-1.8.9.jar                       |Elevator Mod                  |elevatorid                    |1.19.2-1.8.9        |DONE      |Manifest: NOSIGNATURE         resourcefullib-forge-1.19.2-1.1.24.jar            |Resourceful Lib               |resourcefullib                |1.1.24              |DONE      |Manifest: NOSIGNATURE         balm-forge-1.19.2-4.5.7.jar                       |Balm                          |balm                          |4.5.7               |DONE      |Manifest: NOSIGNATURE         PuzzlesLib-v4.4.2-1.19.2-Forge - copia.jar        |Puzzles Lib                   |puzzleslib                    |4.4.2               |DONE      |Manifest: 9a:09:85:98:65:c4:8c:11:c5:49:f6:d6:33:23:39:df:8d:b4:ff:92:84:b8:bd:a5:83:9f:ac:7f:2a:d1:4b:6a         Oh_The_Biomes_You'll_Go-forge-1.19.2-2.0.1.6.jar  |Oh The Biomes You'll Go       |byg                           |2.0.1.6             |ERROR     |Manifest: NOSIGNATURE         CorgiLib-forge-1.19.2-1.0.0.34.jar                |CorgiLib                      |corgilib                      |1.0.0.34            |DONE      |Manifest: NOSIGNATURE         cloth-config-8.3.115-forge.jar                    |Cloth Config v8 API           |cloth_config                  |8.3.115             |DONE      |Manifest: NOSIGNATURE         voicechat-forge-1.19.2-2.5.19.jar                 |Simple Voice Chat             |voicechat                     |1.19.2-2.5.19       |DONE      |Manifest: NOSIGNATURE         forge-1.19.2-43.4.2-universal.jar                 |Forge                         |forge                         |43.4.2              |DONE      |Manifest: 84:ce:76:e8:45:35:e4:0e:63:86:df:47:59:80:0f:67:6c:c1:5f:6e:5f:4d:b3:54:47:1a:9f:7f:ed:5e:f2:90         commonality-1.19.2-4.2.1.jar                      |Commonality                   |commonality                   |4.2.1               |DONE      |Manifest: NOSIGNATURE         apexcore-1.19.2-7.3.1.jar                         |ApexCore                      |apexcore                      |7.3.1               |DONE      |Manifest: NOSIGNATURE         fantasyfurniture-1.19.2-6.7.0.jar                 |Fantasy's Furniture           |fantasyfurniture              |6.7.0               |DONE      |Manifest: NOSIGNATURE         CosmeticArmorReworked-1.19.2-v1a (1).jar          |CosmeticArmorReworked         |cosmeticarmorreworked         |1.19.2-v1a          |DONE      |Manifest: 5e:ed:25:99:e4:44:14:c0:dd:89:c1:a9:4c:10:b5:0d:e4:b1:52:50:45:82:13:d8:d0:32:89:67:56:57:01:53         expandability-forge-7.0.0.jar                     |ExpandAbility                 |expandability                 |7.0.0               |DONE      |Manifest: NOSIGNATURE         PlayerRevive_FORGE_v2.0.14_mc1.19.2.jar           |PlayerRevive                  |playerrevive                  |2.0.14              |DONE      |Manifest: NOSIGNATURE         geckolib-forge-1.19-3.1.40 - copia.jar            |GeckoLib                      |geckolib3                     |3.1.40              |DONE      |Manifest: NOSIGNATURE         emotecraft-for-MC1.19.2-2.2.7-b.build.50-forge.jar|Emotecraft                    |emotecraft                    |2.2.7-b.build.50    |DONE      |Manifest: NOSIGNATURE         Corpse-forge-1.19.2-1.0.12.jar |Cadáver |cadáver |1.19.2-1.0.12 |HECHO |Manifiesto: NOSIGNATURE         chipped-forge-1.19.2-2.1.5.jar |Astillado |astillado |2.1.5 |HECHO |Manifiesto: NOSIGNATURE     Informe de fallos UUID: 452056ac-0e2c-4d3d-bed6-7e2edade8718     FML: 43.4     Forge: net.minecraftforge:43.4.2
    • version used : minecraft forge 1.20.1 Logs : https://bytebin.lucko.me/rtG4EA0vfb hi! so when i try to create a new minecraft world in single player, it just crashes?? does anyone has an idea what could be causing this ?
    • Hey today I was trying to play in 1.21 modpack that I made on fabric (my version of fabric is in 0.16.0) with this list of mods : - Entity Model Features (by traben_0) - Entity Texture Features (by traben_0) - Advanced Chat (by Wesley8081) - Ambient Environment (by Jaredlll08) - Ambient Souds 6 (by CreativeMD) - Animatica (by FoundationGames) - Armor Statues (by Fuzs) - Auto HUD (by Crendgrim) - Bad Packets (by badasintended) - Balm (by BlayTheNinth) - Better Beds (by Motschen) - Better Chunk Loading (by someaddon) - Better Compatibility Checker (by Gaz-) - Better FPS [Render Distance] (by someaddon) - Better Ping Display (by Quintinity) - Better Statistics Screen (by TheCSDev) - Better Armor HUD (by efekos) - Better F3 ( by cominixo) - Blur + (by Motschen) - Bobby (by Johni0702) - Cat Jam (by shmove) - Catalogue (by MrCrayfish) - Chat Heads (by dzwdz) - Cherished Worlds (by TheIllusiveC4) - Chunk Sending (by someaddon) - Chunks Fade In (by kerudion) - Chunky (by pop4959) - Cloth Config (by shedaniel) - Clumps (by Jaredlll08) - Cobweb (CrystalSpider) - Collective (by Serilum) - Configured (by MrCrayfish) - Connectivity (by someaddon) - Continuity (by Pepper_Bell) - Creative Core (by CreativeMD) - Cupboard (by someaddon) - Cut Through (by Fuzs) - Dark Loading Screen (by Neecko5b84) - Debugify (by XanderIsDev) - Double Doors (by Serilum) - Dynamic FPS (by juliand665) - Dynamic Lights (by Tschipcraft) - Easy Anvils (by Fuzs) - Easy Magic (by Fuzs) - Easy Shulker Boxes (by Fuzs) - Eating Animation (by theone-ss) - Enhanced Attack Indicator (by Mineash) - Enhanced Block Entities (by FoundationGames) - Enhanced Visuals (by CreativeMD) - Entity Culling (by tr7zw) - Environmental Water (by AgentMindStorm) - Essential (by SparkUniverse_) - Extra Thicc Packets (by JaselUmena) - Fabric (by modmuss50) - Fabric Language Kotlin (by modmuss50) - Falling Leaves (by RandomMcSomethin) - Fancy Block Particles (by Hantonik) - Fancy Health Bar (by efekos) - Farsight (by someaddon) - Fast IP Ping (by Fallen_Breath) - Ferrite Core (by  malte0811) - Fish On The Line (by Serilum) - Fix GPU Memory Leak  (by someaddon) - Forge Config API Port (by Fuzs) - FPS Reducer (by bre2el) - Freecam (by hashalite) - Fzzy Config (by fzzyhmstrs) - Get It Together (by bl4ckscor3) - Global Packs (by JTK222) - Harvest With Ease (by CrystalSpider) - Ichuntil Util (by iChun) - Immediately Fast (by RaphilMC) - Immersive UI (by SSKirillSS) - Indium (by comp500) - Inventory HUD+ (by dmitrylovin) - Iris Shaders (by coderbot) - Item Physic Full (by CreativeMD) - Jade (by Snownee) - Journey Map (by techbrew) - Just Enough Breeding (by Christofmeg) - Just Enough Items (by mezz) - Just Enough Professions (by Mrbysco) - Language Reload (by Jerozgen) - Leaves Be Gone (by Fuzs) - Let Me Despawn (by frikinjay) - Let Sleeping Dogs Lie (by iChun) - Lithium (by JellySquid) - Loading Backgrounds (by Lupin) - Mineblock's Repeated Utilities (by itsmineblock11) - Menulogue (by MrCrayfish) - Mob Plaques (by Fuzs) - Mod Menu (by Prospector) - Model Gap Fix (by MehVahdJukaar) - Mouse Tweaks (by YaLTeR) - Nether Portal Fix (by BlayTheNinth) - Nicer Skies (by ztereohype) - Noisium (by Steveplays28) - Not Enough Animations (by tr7zw) - Opti GUI (by opekope2) - Packet Fixer (by TonimatasDEV) - Particle Core (by fzzyhmstrs) - Passive Shields (by Serilum) - Pick Up Notifier (by Fuzs) - Ping Wheel (by LukenSkyne) - Puzzle (by Motschen) - Puzzles LIB (by Fuzs) - Reese's Sodium Options (by FlashyReese) - Resource Pack Overrides (by Fuzs) - Server Country Flags (by khajiitos) - Server Performance (by someaddon) - Skin Layer 3D (by tr7zw) - Sodium (by JellySquid) - Sodium Extra (by FlashyReese) - Sodium Shadowy Path Blocks (by Rynnavinx) - Sound Physics Remastered (by henkelmax) - Sounds (by itsmineblock11) - Spark (by lucko) - Stack Refill (by Serilum) - Structure Essentials (by someaddon) - TCD Commons API (by TheCSDev) - Text Placeholder API (by Patbox) - Villager Names (by Serilum) - Visual Overhaul (by Motschen) - Visual Workbench (by Fuzs) - Visuality (by PinkGoosik) - Wakes (by Goby56) - Wavey Capes (by tr7zw) - YDM'S Weapon Master  (by YourDailyModderx) - Yet Another Config LIB (by XanderIsDev) - Zoomify (by XanderIsDev) And When I load it it work, I can create a world and even let him open forever at least I didn't move cause if so the game just crash and tell me this message :   Encountered an unexpected exception net.minecraft.class_148: Ticking entity at net.minecraft.server.MinecraftServer.method_3813(MinecraftServer.java:1025) at net.minecraft.server.MinecraftServer.method_3748(MinecraftServer.java:912) at net.minecraft.class_1132.method_3748(class_1132.java:114) at net.minecraft.server.MinecraftServer.method_29741(MinecraftServer.java:697) at net.minecraft.server.MinecraftServer.method_29739(MinecraftServer.java:281) at java.base/java.lang.Thread.run(Thread.java:1583) Caused by: java.lang.NullPointerException: Cannot invoke "net.minecraft.class_4706.isEmpty()" because "tickets" is null at net.minecraft.class_3204.canNoneExpire(class_3204.java:1034) at net.minecraft.class_3204.handler$dln000$lithium$unregisterExpiringTicket(class_3204.java:1075) at net.minecraft.class_3204.method_17645(class_3204.java:172) at net.minecraft.class_3204.method_17292(class_3204.java:194) at net.minecraft.class_3215.method_17300(class_3215.java:443) at com.betterchunkloading.chunk.PlayerChunkData.checkPrediction(PlayerChunkData.java:406) at com.betterchunkloading.chunk.PlayerChunkData.checkDirection(PlayerChunkData.java:353) at com.betterchunkloading.chunk.PlayerChunkData.trackPlayerMovement(PlayerChunkData.java:177) at com.betterchunkloading.chunk.PlayerChunkData.onChunkChanged(PlayerChunkData.java:130) at com.betterchunkloading.event.EventHandler.onPlayerTick(EventHandler.java:200) at net.minecraft.class_3222.handler$zed000$betterchunkloading$onPlayerTick(class_3222.java:2618) at net.minecraft.class_3222.method_5773(class_3222.java:564) at net.minecraft.class_3218.mixinextras$bridge$method_5773$202(class_3218.java) at net.minecraft.class_3218.wrapOperation$eei000$puzzleslib$tickNonPassenger(class_3218.java:7797) at net.minecraft.class_3218.method_18762(class_3218.java:770) at net.minecraft.class_1937.method_18472(class_1937.java:498) at net.minecraft.class_3218.method_31420(class_3218.java:408) at net.minecraft.class_5574.method_31791(class_5574.java:54) at net.minecraft.class_3218.method_18765(class_3218.java:372) at net.minecraft.server.MinecraftServer.method_3813(MinecraftServer.java:1021) ... 5 more Sorry guys if it obvious but actually I'm an old player of Minecraft but I'm new in modding so yup. But Thanks everyone by advance to help me with this.
    • These forums are for Minecraft Forge, not Fabric. You would probably be better served posting this question wherever fabric support is given, most likely their discord server.
    • Add the new latest.log (logs-folder) with sites like https://mclo.gs/ and paste the link to it here
  • Topics

×
×
  • Create New...

Important Information

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