package net.minecraft.world.gen.layer;
import net.minecraft.world.biome.BiomeGenBase;
public class GenLayerShore extends GenLayer
{
public GenLayerShore(long par1, GenLayer par3GenLayer)
{
super(par1);
this.parent = par3GenLayer;
}
/**
* Returns a list of integer values generated by this layer. These may be interpreted as temperatures, rainfall
* amounts, or biomeList[] indices based on the particular GenLayer subclass.
*/
public int[] getInts(int par1, int par2, int par3, int par4)
{
int[] var5 = this.parent.getInts(par1 - 1, par2 - 1, par3 + 2, par4 + 2);
int[] var6 = IntCache.getIntCache(par3 * par4);
for (int var7 = 0; var7 < par4; ++var7)
{
for (int var8 = 0; var8 < par3; ++var8)
{
this.initChunkSeed((long)(var8 + par1), (long)(var7 + par2));
int var9 = var5[var8 + 1 + (var7 + 1) * (par3 + 2)];
int var10;
int var11;
int var12;
int var13;
if (var9 == BiomeGenBase.mushroomIsland.biomeID)
{
var10 = var5[var8 + 1 + (var7 + 1 - 1) * (par3 + 2)];
var11 = var5[var8 + 1 + 1 + (var7 + 1) * (par3 + 2)];
var12 = var5[var8 + 1 - 1 + (var7 + 1) * (par3 + 2)];
var13 = var5[var8 + 1 + (var7 + 1 + 1) * (par3 + 2)];
if (var10 != BiomeGenBase.ocean.biomeID && var11 != BiomeGenBase.ocean.biomeID && var12 != BiomeGenBase.ocean.biomeID && var13 != BiomeGenBase.ocean.biomeID)
{
var6[var8 + var7 * par3] = var9;
}
else
{
var6[var8 + var7 * par3] = BiomeGenBase.mushroomIslandShore.biomeID;
}
}
else if (var9 != BiomeGenBase.ocean.biomeID && var9 != BiomeGenBase.river.biomeID && var9 != BiomeGenBase.swampland.biomeID && var9 != BiomeGenBase.extremeHills.biomeID)
{
var10 = var5[var8 + 1 + (var7 + 1 - 1) * (par3 + 2)];
var11 = var5[var8 + 1 + 1 + (var7 + 1) * (par3 + 2)];
var12 = var5[var8 + 1 - 1 + (var7 + 1) * (par3 + 2)];
var13 = var5[var8 + 1 + (var7 + 1 + 1) * (par3 + 2)];
if (var10 != BiomeGenBase.ocean.biomeID && var11 != BiomeGenBase.ocean.biomeID && var12 != BiomeGenBase.ocean.biomeID && var13 != BiomeGenBase.ocean.biomeID)
{
var6[var8 + var7 * par3] = var9;
}
else
{
var6[var8 + var7 * par3] = BiomeGenBase.beach.biomeID;
}
}
else if (var9 == BiomeGenBase.extremeHills.biomeID)
{
var10 = var5[var8 + 1 + (var7 + 1 - 1) * (par3 + 2)];
var11 = var5[var8 + 1 + 1 + (var7 + 1) * (par3 + 2)];
var12 = var5[var8 + 1 - 1 + (var7 + 1) * (par3 + 2)];
var13 = var5[var8 + 1 + (var7 + 1 + 1) * (par3 + 2)];
if (var10 == BiomeGenBase.extremeHills.biomeID && var11 == BiomeGenBase.extremeHills.biomeID && var12 == BiomeGenBase.extremeHills.biomeID && var13 == BiomeGenBase.extremeHills.biomeID)
{
var6[var8 + var7 * par3] = var9;
}
else
{
var6[var8 + var7 * par3] = BiomeGenBase.extremeHillsEdge.biomeID;
}
}
else
{
var6[var8 + var7 * par3] = var9;
}
}
}
return var6;
}
}