MrPablo2000 Posted August 2, 2019 Share Posted August 2, 2019 (edited) I tried to solve this problem, but i don't know how. I tried to make a block, what is a cable(such as a redstone wire), but it must connect also with up and down(for example - redstone conduits ). I tried to understand vanilla redstone wire code, and modify it to my needs - but it doesn't working(it's crashing). Code CommonProxy Spoiler package com.lanterns.proxy; import com.lanterns.ModBlocks; import com.lanterns.ModTut; import com.lanterns.blocks.*; import net.minecraft.block.Block; import net.minecraft.creativetab.CreativeTabs; import net.minecraft.item.Item; import net.minecraft.item.ItemBlock; import net.minecraftforge.event.RegistryEvent; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.common.event.FMLInitializationEvent; import net.minecraftforge.fml.common.event.FMLPostInitializationEvent; import net.minecraftforge.fml.common.event.FMLPreInitializationEvent; import net.minecraftforge.fml.common.eventhandler.SubscribeEvent; @Mod.EventBusSubscriber public class CommonProxy { // Config instance public void preInit(FMLPreInitializationEvent e) { } public void init(FMLInitializationEvent e) { } public void postInit(FMLPostInitializationEvent e) { } @SubscribeEvent public static void registerBlocks(RegistryEvent.Register<Block> event) { event.getRegistry().register(new ModelBlock()); event.getRegistry().register(new OROLantern(false).setRegistryName("oro").setCreativeTab(CreativeTabs.REDSTONE)); event.getRegistry().register(new OROLantern(true).setRegistryName("oroactive")); event.getRegistry().register(new Zyrandol(false).setRegistryName("z").setCreativeTab(CreativeTabs.REDSTONE)); event.getRegistry().register(new Zyrandol(true).setRegistryName("zactive")); event.getRegistry().register(new SlupGora().setRegistryName("slupgora")); } @SubscribeEvent public static void registerItems(RegistryEvent.Register<Item> event) { event.getRegistry().register(new ItemBlock(ModBlocks.modelBlock).setRegistryName(ModBlocks.modelBlock.getRegistryName())); event.getRegistry().register(new ItemBlock(ModBlocks.oro).setRegistryName(ModBlocks.oro.getRegistryName())); event.getRegistry().register(new ItemBlock(ModBlocks.oroActive).setRegistryName(ModBlocks.oroActive.getRegistryName())); event.getRegistry().register(new ItemBlock(ModBlocks.zyrandol).setRegistryName(ModBlocks.zyrandol.getRegistryName())); event.getRegistry().register(new ItemBlock(ModBlocks.zyrandolActive).setRegistryName(ModBlocks.zyrandolActive.getRegistryName())); event.getRegistry().register(new ItemBlock(ModBlocks.slupGora).setRegistryName(ModBlocks.slupGora.getRegistryName())); } } SlupGora: Spoiler package com.lanterns.blocks; import java.util.EnumSet; import java.util.List; import java.util.Random; import java.util.Set; import javax.annotation.Nullable; import com.google.common.collect.Lists; import com.google.common.collect.Sets; import com.lanterns.ModBlocks; import net.minecraft.block.Block; import net.minecraft.block.BlockRedstoneDiode; import net.minecraft.block.material.Material; import net.minecraft.block.properties.IProperty; import net.minecraft.block.properties.PropertyEnum; import net.minecraft.block.properties.PropertyInteger; import net.minecraft.block.state.BlockFaceShape; import net.minecraft.block.state.BlockStateContainer; import net.minecraft.block.state.IBlockState; import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.init.Blocks; import net.minecraft.init.Items; import net.minecraft.item.Item; import net.minecraft.item.ItemStack; import net.minecraft.util.BlockRenderLayer; import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumParticleTypes; import net.minecraft.util.IStringSerializable; import net.minecraft.util.Mirror; import net.minecraft.util.Rotation; import net.minecraft.util.math.AxisAlignedBB; import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.MathHelper; import net.minecraft.world.IBlockAccess; import net.minecraft.world.World; import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.fml.relauncher.SideOnly; public class SlupGora extends Block { public static final PropertyEnum<SlupGora.EnumAttachPosition> NORTH = PropertyEnum.<SlupGora.EnumAttachPosition>create("north", SlupGora.EnumAttachPosition.class); public static final PropertyEnum<SlupGora.EnumAttachPosition> EAST = PropertyEnum.<SlupGora.EnumAttachPosition>create("east", SlupGora.EnumAttachPosition.class); public static final PropertyEnum<SlupGora.EnumAttachPosition> SOUTH = PropertyEnum.<SlupGora.EnumAttachPosition>create("south", SlupGora.EnumAttachPosition.class); public static final PropertyEnum<SlupGora.EnumAttachPosition> WEST = PropertyEnum.<SlupGora.EnumAttachPosition>create("west", SlupGora.EnumAttachPosition.class); public static final PropertyEnum<SlupGora.EnumAttachPosition> UP = PropertyEnum.<SlupGora.EnumAttachPosition>create("up", SlupGora.EnumAttachPosition.class); public static final PropertyEnum<SlupGora.EnumAttachPosition> DOWN = PropertyEnum.<SlupGora.EnumAttachPosition>create("down", SlupGora.EnumAttachPosition.class); public static final PropertyInteger POWER = PropertyInteger.create("power", 0, 15); protected static final AxisAlignedBB[] REDSTONE_WIRE_AABB = new AxisAlignedBB[] {new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 1.0D, 0.0625D, 1.0D)}; private boolean canProvidePower = true; /** List of blocks to update with redstone. */ private final Set<BlockPos> blocksNeedingUpdate = Sets.<BlockPos>newHashSet(); public SlupGora() { super(Material.CIRCUITS); this.setDefaultState(this.blockState.getBaseState().withProperty(NORTH, SlupGora.EnumAttachPosition.NONE).withProperty(EAST, SlupGora.EnumAttachPosition.NONE).withProperty(SOUTH, SlupGora.EnumAttachPosition.NONE).withProperty(WEST, SlupGora.EnumAttachPosition.NONE).withProperty(UP, SlupGora.EnumAttachPosition.NONE).withProperty(DOWN, SlupGora.EnumAttachPosition.NONE).withProperty(POWER, Integer.valueOf(0))); } @SideOnly(Side.CLIENT) public void initModel() { ModelLoader.setCustomModelResourceLocation(Item.getItemFromBlock(this), 0, new ModelResourceLocation(getRegistryName(), "inventory")); } public AxisAlignedBB getBoundingBox(IBlockState state, IBlockAccess source, BlockPos pos) { return REDSTONE_WIRE_AABB[getAABBIndex(state.getActualState(source, pos))]; } private static int getAABBIndex(IBlockState state) { int i = 0; boolean flag = state.getValue(NORTH) != SlupGora.EnumAttachPosition.NONE; boolean flag1 = state.getValue(EAST) != SlupGora.EnumAttachPosition.NONE; boolean flag2 = state.getValue(SOUTH) != SlupGora.EnumAttachPosition.NONE; boolean flag3 = state.getValue(WEST) != SlupGora.EnumAttachPosition.NONE; boolean flag4 = state.getValue(UP) != SlupGora.EnumAttachPosition.NONE; boolean flag5 = state.getValue(DOWN) != SlupGora.EnumAttachPosition.NONE; if (flag || flag2 && !flag && !flag1 && !flag3) { i |= 1 << EnumFacing.NORTH.getHorizontalIndex(); } if (flag1 || flag3 && !flag && !flag1 && !flag2) { i |= 1 << EnumFacing.EAST.getHorizontalIndex(); } if (flag2 || flag && !flag1 && !flag2 && !flag3) { i |= 1 << EnumFacing.SOUTH.getHorizontalIndex(); } if (flag3 || flag1 && !flag && !flag2 && !flag3) { i |= 1 << EnumFacing.WEST.getHorizontalIndex(); } if (flag4 || flag5 && !flag4) { i |= 1 << EnumFacing.UP.getHorizontalIndex(); } if (flag5 || flag4 && !flag5) { i |= 1 << EnumFacing.DOWN.getHorizontalIndex(); } return i; } /** * Get the actual Block state of this Block at the given position. This applies properties not visible in the * metadata, such as fence connections. */ public IBlockState getActualState(IBlockState state, IBlockAccess worldIn, BlockPos pos) { state = state.withProperty(WEST, this.getAttachPosition(worldIn, pos, EnumFacing.WEST)); state = state.withProperty(EAST, this.getAttachPosition(worldIn, pos, EnumFacing.EAST)); state = state.withProperty(NORTH, this.getAttachPosition(worldIn, pos, EnumFacing.NORTH)); state = state.withProperty(SOUTH, this.getAttachPosition(worldIn, pos, EnumFacing.SOUTH)); state = state.withProperty(UP, this.getAttachPosition(worldIn, pos, EnumFacing.UP)); state = state.withProperty(DOWN, this.getAttachPosition(worldIn, pos, EnumFacing.DOWN)); return state; } private SlupGora.EnumAttachPosition getAttachPosition(IBlockAccess worldIn, BlockPos pos, EnumFacing direction) { BlockPos blockpos = pos.offset(direction); IBlockState iblockstate = worldIn.getBlockState(pos.offset(direction)); if (!canConnectTo(worldIn.getBlockState(blockpos), direction, worldIn, blockpos) || !canConnectUpwardsTo(worldIn, blockpos.down())) { boolean flag = worldIn.getBlockState(blockpos).getBlock() == ModBlocks.slupGora; if (flag && canConnectUpwardsTo(worldIn, blockpos.up())) { return SlupGora.EnumAttachPosition.UP; } return SlupGora.EnumAttachPosition.NONE; } else { return SlupGora.EnumAttachPosition.SIDE; } } @Nullable public AxisAlignedBB getCollisionBoundingBox(IBlockState blockState, IBlockAccess worldIn, BlockPos pos) { return NULL_AABB; } /** * Used to determine ambient occlusion and culling when rebuilding chunks for render */ public boolean isOpaqueCube(IBlockState state) { return false; } public boolean isFullCube(IBlockState state) { return false; } /** * Checks if this block can be placed exactly at the given position. */ public boolean canPlaceBlockAt(World worldIn, BlockPos pos) { return true; } private IBlockState updateSurroundingRedstone(World worldIn, BlockPos pos, IBlockState state) { state = this.calculateCurrentChanges(worldIn, pos, pos, state); List<BlockPos> list = Lists.newArrayList(this.blocksNeedingUpdate); this.blocksNeedingUpdate.clear(); for (BlockPos blockpos : list) { worldIn.notifyNeighborsOfStateChange(blockpos, this, false); } return state; } private IBlockState calculateCurrentChanges(World worldIn, BlockPos pos1, BlockPos pos2, IBlockState state) { IBlockState iblockstate = state; int i = ((Integer)state.getValue(POWER)).intValue(); int j = 0; j = this.getMaxCurrentStrength(worldIn, pos2, j); this.canProvidePower = false; int k = worldIn.isBlockIndirectlyGettingPowered(pos1); this.canProvidePower = true; if (k > 0 && k > j - 1) { j = k; } int l = 0; for (EnumFacing enumfacing : EnumFacing.Plane.HORIZONTAL) { BlockPos blockpos = pos1.offset(enumfacing); boolean flag = blockpos.getX() != pos2.getX() || blockpos.getZ() != pos2.getZ(); if (flag) { l = this.getMaxCurrentStrength(worldIn, blockpos, l); } if (flag && pos1.getY() >= pos2.getY()) { l = this.getMaxCurrentStrength(worldIn, blockpos.up(), l); } else if (!(worldIn.getBlockState(blockpos).getBlock() == ModBlocks.slupGora) && flag && pos1.getY() <= pos2.getY()) { l = this.getMaxCurrentStrength(worldIn, blockpos.down(), l); } } if (l > j) { j = l - 1; } else if (j > 0) { --j; } else { j = 0; } if (k > j - 1) { j = k; } if (i != j) { state = state.withProperty(POWER, Integer.valueOf(j)); if (worldIn.getBlockState(pos1) == iblockstate) { worldIn.setBlockState(pos1, state, 2); } this.blocksNeedingUpdate.add(pos1); for (EnumFacing enumfacing1 : EnumFacing.values()) { this.blocksNeedingUpdate.add(pos1.offset(enumfacing1)); } } return state; } /** * Calls World.notifyNeighborsOfStateChange() for all neighboring blocks, but only if the given block is a redstone * wire. */ private void notifyWireNeighborsOfStateChange(World worldIn, BlockPos pos) { if (worldIn.getBlockState(pos).getBlock() == this) { worldIn.notifyNeighborsOfStateChange(pos, this, false); for (EnumFacing enumfacing : EnumFacing.values()) { worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false); } } } /** * Called after the block is set in the Chunk data, but before the Tile Entity is set */ public void onBlockAdded(World worldIn, BlockPos pos, IBlockState state) { if (!worldIn.isRemote) { this.updateSurroundingRedstone(worldIn, pos, state); for (EnumFacing enumfacing : EnumFacing.Plane.VERTICAL) { worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false); } for (EnumFacing enumfacing1 : EnumFacing.Plane.HORIZONTAL) { this.notifyWireNeighborsOfStateChange(worldIn, pos.offset(enumfacing1)); } for (EnumFacing enumfacing2 : EnumFacing.Plane.HORIZONTAL) { BlockPos blockpos = pos.offset(enumfacing2); if (worldIn.getBlockState(blockpos).getBlock() == ModBlocks.slupGora) { this.notifyWireNeighborsOfStateChange(worldIn, blockpos.up()); } else { this.notifyWireNeighborsOfStateChange(worldIn, blockpos.down()); } } } } /** * Called serverside after this block is replaced with another in Chunk, but before the Tile Entity is updated */ public void breakBlock(World worldIn, BlockPos pos, IBlockState state) { super.breakBlock(worldIn, pos, state); if (!worldIn.isRemote) { for (EnumFacing enumfacing : EnumFacing.values()) { worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false); } this.updateSurroundingRedstone(worldIn, pos, state); for (EnumFacing enumfacing1 : EnumFacing.Plane.HORIZONTAL) { this.notifyWireNeighborsOfStateChange(worldIn, pos.offset(enumfacing1)); } for (EnumFacing enumfacing2 : EnumFacing.Plane.HORIZONTAL) { BlockPos blockpos = pos.offset(enumfacing2); if (worldIn.getBlockState(blockpos).getBlock() == ModBlocks.slupGora) { this.notifyWireNeighborsOfStateChange(worldIn, blockpos.up()); } else { this.notifyWireNeighborsOfStateChange(worldIn, blockpos.down()); } } } } private int getMaxCurrentStrength(World worldIn, BlockPos pos, int strength) { if (worldIn.getBlockState(pos).getBlock() != this) { return strength; } else { int i = ((Integer)worldIn.getBlockState(pos).getValue(POWER)).intValue(); return i > strength ? i : strength; } } /** * Called when a neighboring block was changed and marks that this state should perform any checks during a neighbor * change. Cases may include when redstone power is updated, cactus blocks popping off due to a neighboring solid * block, etc. */ public void neighborChanged(IBlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos) { if (!worldIn.isRemote) { if (this.canPlaceBlockAt(worldIn, pos)) { this.updateSurroundingRedstone(worldIn, pos, state); } else { this.dropBlockAsItem(worldIn, pos, state, 0); worldIn.setBlockToAir(pos); } } } /** * Get the Item that this Block should drop when harvested. */ public Item getItemDropped(IBlockState state, Random rand, int fortune) { return Item.getItemFromBlock(ModBlocks.slupGora); } public int getStrongPower(IBlockState blockState, IBlockAccess blockAccess, BlockPos pos, EnumFacing side) { return !this.canProvidePower ? 0 : blockState.getWeakPower(blockAccess, pos, side); } public int getWeakPower(IBlockState blockState, IBlockAccess blockAccess, BlockPos pos, EnumFacing side) { if (!this.canProvidePower) { return 0; } else { int i = ((Integer)blockState.getValue(POWER)).intValue(); if (i == 0) { return 0; } else if (side == EnumFacing.UP) { return i; } else { EnumSet<EnumFacing> enumset = EnumSet.<EnumFacing>noneOf(EnumFacing.class); for (EnumFacing enumfacing : EnumFacing.Plane.HORIZONTAL) { if (this.isPowerSourceAt(blockAccess, pos, enumfacing)) { enumset.add(enumfacing); } } if (side.getAxis().isHorizontal() && enumset.isEmpty()) { return i; } else if (enumset.contains(side) && !enumset.contains(side.rotateYCCW()) && !enumset.contains(side.rotateY())) { return i; } else { return 0; } } } } private boolean isPowerSourceAt(IBlockAccess worldIn, BlockPos pos, EnumFacing side) { BlockPos blockpos = pos.offset(side); IBlockState iblockstate = worldIn.getBlockState(blockpos); boolean flag = iblockstate.getBlock() == ModBlocks.slupGora; boolean flag1 = worldIn.getBlockState(pos.up()).getBlock() == ModBlocks.slupGora; if (!flag1 && flag && canConnectUpwardsTo(worldIn, blockpos.up())) { return true; } else if (canConnectTo(iblockstate, side, worldIn, pos)) { return true; } else if (iblockstate.getBlock() == Blocks.POWERED_REPEATER && iblockstate.getValue(BlockRedstoneDiode.FACING) == side) { return true; } else { return !flag && canConnectUpwardsTo(worldIn, blockpos.down()); } } protected static boolean canConnectUpwardsTo(IBlockAccess worldIn, BlockPos pos) { return canConnectTo(worldIn.getBlockState(pos), null, worldIn, pos); } protected static boolean canConnectTo(IBlockState blockState, @Nullable EnumFacing side, IBlockAccess world, BlockPos pos) { Block block = blockState.getBlock(); if (block == Blocks.REDSTONE_WIRE) { return true; } if (block == ModBlocks.oro) { return true; } if (block == ModBlocks.oroActive) { return true; } if (block == ModBlocks.slupGora) { return true; } if (block == Blocks.LEVER) { return true; } return false; } /** * Can this block provide power. Only wire currently seems to have this change based on its state. */ public boolean canProvidePower(IBlockState state) { return this.canProvidePower; } @SideOnly(Side.CLIENT) public static int colorMultiplier(int p_176337_0_) { float f = (float)p_176337_0_ / 15.0F; float f1 = f * 0.6F + 0.4F; if (p_176337_0_ == 0) { f1 = 0.3F; } float f2 = f * f * 0.7F - 0.5F; float f3 = f * f * 0.6F - 0.7F; if (f2 < 0.0F) { f2 = 0.0F; } if (f3 < 0.0F) { f3 = 0.0F; } int i = MathHelper.clamp((int)(f1 * 255.0F), 0, 255); int j = MathHelper.clamp((int)(f2 * 255.0F), 0, 255); int k = MathHelper.clamp((int)(f3 * 255.0F), 0, 255); return -16777216 | i << 16 | j << 8 | k; } public ItemStack getItem(World worldIn, BlockPos pos, IBlockState state) { return new ItemStack(Item.getItemFromBlock(ModBlocks.slupGora)); } /** * Convert the given metadata into a BlockState for this Block */ public IBlockState getStateFromMeta(int meta) { return this.getDefaultState().withProperty(POWER, Integer.valueOf(meta)); } @SideOnly(Side.CLIENT) public BlockRenderLayer getBlockLayer() { return BlockRenderLayer.CUTOUT; } /** * Convert the BlockState into the correct metadata value */ public int getMetaFromState(IBlockState state) { return ((Integer)state.getValue(POWER)).intValue(); } /** * Returns the blockstate with the given rotation from the passed blockstate. If inapplicable, returns the passed * blockstate. */ public IBlockState withRotation(IBlockState state, Rotation rot) { switch (rot) { case CLOCKWISE_180: return state.withProperty(NORTH, state.getValue(SOUTH)).withProperty(EAST, state.getValue(WEST)).withProperty(SOUTH, state.getValue(NORTH)).withProperty(WEST, state.getValue(EAST)); case COUNTERCLOCKWISE_90: return state.withProperty(NORTH, state.getValue(EAST)).withProperty(EAST, state.getValue(SOUTH)).withProperty(SOUTH, state.getValue(WEST)).withProperty(WEST, state.getValue(NORTH)); case CLOCKWISE_90: return state.withProperty(NORTH, state.getValue(WEST)).withProperty(EAST, state.getValue(NORTH)).withProperty(SOUTH, state.getValue(EAST)).withProperty(WEST, state.getValue(SOUTH)); default: return state; } } /** * Returns the blockstate with the given mirror of the passed blockstate. If inapplicable, returns the passed * blockstate. */ public IBlockState withMirror(IBlockState state, Mirror mirrorIn) { switch (mirrorIn) { case LEFT_RIGHT: return state.withProperty(NORTH, state.getValue(SOUTH)).withProperty(SOUTH, state.getValue(NORTH)); case FRONT_BACK: return state.withProperty(EAST, state.getValue(WEST)).withProperty(WEST, state.getValue(EAST)); default: return super.withMirror(state, mirrorIn); } } protected BlockStateContainer createBlockState() { return new BlockStateContainer(this, new IProperty[] {NORTH, EAST, SOUTH, WEST, POWER}); } /** * Get the geometry of the queried face at the given position and state. This is used to decide whether things like * buttons are allowed to be placed on the face, or how glass panes connect to the face, among other things. * <p> * Common values are {@code SOLID}, which is the default, and {@code UNDEFINED}, which represents something that * does not fit the other descriptions and will generally cause other things not to connect to the face. * * @return an approximation of the form of the given face */ public BlockFaceShape getBlockFaceShape(IBlockAccess worldIn, IBlockState state, BlockPos pos, EnumFacing face) { return BlockFaceShape.UNDEFINED; } static enum EnumAttachPosition implements IStringSerializable { UP("up"), SIDE("side"), NONE("none"); private final String name; private EnumAttachPosition(String name) { this.name = name; } public String toString() { return this.getName(); } public String getName() { return this.name; } } } CrashReport: Spoiler [16:05:31] [main/INFO] [GradleStart]: Extra: [] [16:05:32] [main/INFO] [GradleStart]: Running with arguments: [--userProperties, {}, --assetsDir, C:/Users/Ryszard/.gradle/caches/minecraft/assets, --assetIndex, 1.12, --accessToken{REDACTED}, --version, 1.12.2, --tweakClass, net.minecraftforge.fml.common.launcher.FMLTweaker, --tweakClass, net.minecraftforge.gradle.tweakers.CoremodTweaker] [16:05:32] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker [16:05:32] [main/INFO] [LaunchWrapper]: Using primary tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker [16:05:32] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.gradle.tweakers.CoremodTweaker [16:05:32] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLTweaker [16:05:32] [main/INFO] [FML]: Forge Mod Loader version 14.23.5.2768 for Minecraft 1.12.2 loading [16:05:32] [main/INFO] [FML]: Java is Java HotSpot(TM) 64-Bit Server VM, version 1.8.0_181, running on Windows 10:amd64:10.0, installed at C:\Program Files\Java\jdk1.8.0_181\jre [16:05:32] [main/ERROR] [FML]: Apache Maven library folder was not in the format expected. Using default libraries directory. [16:05:32] [main/ERROR] [FML]: Full: C:\Users\Ryszard\.gradle\caches\modules-2\files-2.1\org.apache.maven\maven-artifact\3.5.3\7dc72b6d6d8a6dced3d294ed54c2cc3515ade9f4\maven-artifact-3.5.3.jar [16:05:32] [main/ERROR] [FML]: Trimmed: c:/users/ryszard/.gradle/caches/modules-2/files-2.1/org.apache.maven/maven-artifact/3.5.3/ [16:05:33] [main/INFO] [FML]: Managed to load a deobfuscated Minecraft name- we are in a deobfuscated environment. Skipping runtime deobfuscation [16:05:33] [main/INFO] [FML]: Detected deobfuscated environment, loading log configs for colored console logs. 2019-08-02 16:05:37,867 main WARN Disabling terminal, you're running in an unsupported environment. [16:05:37] [main/INFO] [FML]: Ignoring missing certificate for coremod FMLCorePlugin (net.minecraftforge.fml.relauncher.FMLCorePlugin), we are in deobf and it's a forge core plugin [16:05:38] [main/INFO] [FML]: Ignoring missing certificate for coremod FMLForgePlugin (net.minecraftforge.classloading.FMLForgePlugin), we are in deobf and it's a forge core plugin [16:05:38] [main/INFO] [FML]: Searching D:\mod\lanterns1122\run\.\mods for mods [16:05:38] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.gradle.tweakers.CoremodTweaker [16:05:38] [main/INFO] [GradleStart]: Injecting location in coremod net.minecraftforge.fml.relauncher.FMLCorePlugin [16:05:38] [main/INFO] [GradleStart]: Injecting location in coremod net.minecraftforge.classloading.FMLForgePlugin [16:05:38] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker [16:05:38] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLDeobfTweaker [16:05:38] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.gradle.tweakers.AccessTransformerTweaker [16:05:38] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker [16:05:38] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker [16:05:38] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper [16:05:46] [main/ERROR] [FML]: FML appears to be missing any signature data. This is not a good thing [16:05:46] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper [16:05:46] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLDeobfTweaker [16:05:47] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.gradle.tweakers.AccessTransformerTweaker [16:05:47] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.TerminalTweaker [16:05:47] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.TerminalTweaker [16:05:47] [main/INFO] [LaunchWrapper]: Launching wrapped minecraft {net.minecraft.client.main.Main} [16:05:50] [main/INFO] [minecraft/Minecraft]: Setting user: Player282 [16:06:07] [main/WARN] [minecraft/GameSettings]: Skipping bad option: lastServer: [16:06:07] [main/INFO] [minecraft/Minecraft]: LWJGL Version: 2.9.4 [16:06:11] [main/INFO] [FML]: -- System Details -- Details: Minecraft Version: 1.12.2 Operating System: Windows 10 (amd64) version 10.0 Java Version: 1.8.0_181, Oracle Corporation Java VM Version: Java HotSpot(TM) 64-Bit Server VM (mixed mode), Oracle Corporation Memory: 831916784 bytes (793 MB) / 1038876672 bytes (990 MB) up to 2112618496 bytes (2014 MB) JVM Flags: 4 total; -Xincgc -Xmx1024M -Xms1024M -Xmx2048m IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0 FML: Loaded coremods (and transformers): GL info: ' Vendor: 'Intel' Version: '4.0.0 - Build 10.18.10.4276' Renderer: 'Intel(R) HD Graphics' [16:06:11] [main/INFO] [FML]: MinecraftForge v14.23.5.2768 Initialized [16:06:11] [main/INFO] [FML]: Starts to replace vanilla recipe ingredients with ore ingredients. [16:06:12] [main/INFO] [FML]: Replaced 1036 ore ingredients [16:06:14] [main/INFO] [FML]: Searching D:\mod\lanterns1122\run\.\mods for mods [16:06:15] [Thread-3/INFO] [FML]: Using sync timing. 200 frames of Display.update took 617442171 nanos [16:06:23] [main/INFO] [FML]: Forge Mod Loader has identified 5 mods to load [16:06:24] [main/INFO] [FML]: Attempting connection with missing mods [minecraft, mcp, FML, forge, modtut] at CLIENT [16:06:24] [main/INFO] [FML]: Attempting connection with missing mods [minecraft, mcp, FML, forge, modtut] at SERVER [16:06:29] [main/INFO] [minecraft/SimpleReloadableResourceManager]: Reloading ResourceManager: Default, FMLFileResourcePack:Forge Mod Loader, FMLFileResourcePack:Minecraft Forge, FMLFileResourcePack:Mod Tutorials [16:06:31] [main/INFO] [FML]: Processing ObjectHolder annotations [16:06:31] [main/INFO] [FML]: Found 1174 ObjectHolder annotations [16:06:31] [main/INFO] [FML]: Identifying ItemStackHolder annotations [16:06:31] [main/INFO] [FML]: Found 0 ItemStackHolder annotations [16:06:32] [main/INFO] [FML]: Configured a dormant chunk cache size of 0 [16:06:32] [main/INFO] [FML]: OBJLoader: Domain modtut has been added. [16:06:32] [Forge Version Check/INFO] [forge.VersionCheck]: [forge] Starting version check at http://files.minecraftforge.net/maven/net/minecraftforge/forge/promotions_slim.json [16:06:33] [Forge Version Check/INFO] [forge.VersionCheck]: [forge] Found status: UP_TO_DATE Target: null [16:06:34] [main/ERROR] [FML]: Exception caught during firing event net.minecraftforge.event.RegistryEvent$Register@4c697c25: java.lang.IllegalArgumentException: Cannot set property PropertyEnum{name=up, clazz=class com.lanterns.blocks.SlupGora$EnumAttachPosition, values=[up, side, none]} as it does not exist in BlockStateContainer{block=null, properties=[east, north, power, south, west]} at net.minecraft.block.state.BlockStateContainer$StateImplementation.withProperty(BlockStateContainer.java:221) ~[BlockStateContainer$StateImplementation.class:?] at com.lanterns.blocks.SlupGora.<init>(SlupGora.java:60) ~[SlupGora.class:?] at com.lanterns.proxy.CommonProxy.registerBlocks(CommonProxy.java:42) ~[CommonProxy.class:?] at net.minecraftforge.fml.common.eventhandler.ASMEventHandler_6_CommonProxy_registerBlocks_Register.invoke(.dynamic) ~[?:?] at net.minecraftforge.fml.common.eventhandler.ASMEventHandler.invoke(ASMEventHandler.java:90) ~[ASMEventHandler.class:?] at net.minecraftforge.fml.common.eventhandler.EventBus$1.invoke(EventBus.java:144) ~[EventBus$1.class:?] at net.minecraftforge.fml.common.eventhandler.EventBus.post(EventBus.java:182) [EventBus.class:?] at net.minecraftforge.registries.GameData.fireRegistryEvents(GameData.java:777) [GameData.class:?] at net.minecraftforge.fml.common.Loader.preinitializeMods(Loader.java:628) [Loader.class:?] at net.minecraftforge.fml.client.FMLClientHandler.beginMinecraftLoading(FMLClientHandler.java:252) [FMLClientHandler.class:?] at net.minecraft.client.Minecraft.init(Minecraft.java:513) [Minecraft.class:?] at net.minecraft.client.Minecraft.run(Minecraft.java:421) [Minecraft.class:?] at net.minecraft.client.main.Main.main(Main.java:118) [Main.class:?] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_181] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_181] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_181] at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_181] at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) [launchwrapper-1.12.jar:?] at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.12.jar:?] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_181] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_181] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_181] at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_181] at net.minecraftforge.gradle.GradleStartCommon.launch(GradleStartCommon.java:97) [start/:?] at GradleStart.main(GradleStart.java:25) [start/:?] [16:06:34] [main/ERROR] [FML]: Index: 3 Listeners: [16:06:34] [main/ERROR] [FML]: 0: NORMAL [16:06:34] [main/ERROR] [FML]: 1: net.minecraftforge.fml.common.eventhandler.EventBus$1@72e89ce2 [16:06:34] [main/ERROR] [FML]: 2: net.minecraftforge.fml.common.eventhandler.EventBus$1@1bb6b0f3 [16:06:34] [main/ERROR] [FML]: 3: net.minecraftforge.fml.common.eventhandler.EventBus$1@2b4b3918 [16:06:34] [main/INFO] [STDOUT]: [net.minecraft.init.Bootstrap:printToSYSOUT:629]: ---- Minecraft Crash Report ---- // I'm sorry, Dave. Time: 8/2/19 4:06 PM Description: Initializing game java.lang.IllegalArgumentException: Cannot set property PropertyEnum{name=up, clazz=class com.lanterns.blocks.SlupGora$EnumAttachPosition, values=[up, side, none]} as it does not exist in BlockStateContainer{block=null, properties=[east, north, power, south, west]} at net.minecraft.block.state.BlockStateContainer$StateImplementation.withProperty(BlockStateContainer.java:221) atcom.lanterns.blocks.SlupGora.<init>(SlupGora.java:60) at com.lanterns.proxy.CommonProxy.registerBlocks(CommonProxy.java:42) at net.minecraftforge.fml.common.eventhandler.ASMEventHandler_6_CommonProxy_registerBlocks_Register.invoke(.dynamic) at net.minecraftforge.fml.common.eventhandler.ASMEventHandler.invoke(ASMEventHandler.java:90) at net.minecraftforge.fml.common.eventhandler.EventBus$1.invoke(EventBus.java:144) at net.minecraftforge.fml.common.eventhandler.EventBus.post(EventBus.java:182) at net.minecraftforge.registries.GameData.fireRegistryEvents(GameData.java:777) at net.minecraftforge.fml.common.Loader.preinitializeMods(Loader.java:628) at net.minecraftforge.fml.client.FMLClientHandler.beginMinecraftLoading(FMLClientHandler.java:252) at net.minecraft.client.Minecraft.init(Minecraft.java:513) at net.minecraft.client.Minecraft.run(Minecraft.java:421) at net.minecraft.client.main.Main.main(Main.java:118) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) at net.minecraft.launchwrapper.Launch.main(Launch.java:28) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at net.minecraftforge.gradle.GradleStartCommon.launch(GradleStartCommon.java:97) at GradleStart.main(GradleStart.java:25) A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- Head -- Thread: Client thread Stacktrace: at net.minecraft.block.state.BlockStateContainer$StateImplementation.withProperty(BlockStateContainer.java:221) at com.lanterns.blocks.SlupGora.<init>(SlupGora.java:60) at com.lanterns.proxy.CommonProxy.registerBlocks(CommonProxy.java:42) at net.minecraftforge.fml.common.eventhandler.ASMEventHandler_6_CommonProxy_registerBlocks_Register.invoke(.dynamic) at net.minecraftforge.fml.common.eventhandler.ASMEventHandler.invoke(ASMEventHandler.java:90) at net.minecraftforge.fml.common.eventhandler.EventBus$1.invoke(EventBus.java:144) at net.minecraftforge.fml.common.eventhandler.EventBus.post(EventBus.java:182) at net.minecraftforge.registries.GameData.fireRegistryEvents(GameData.java:777) at net.minecraftforge.fml.common.Loader.preinitializeMods(Loader.java:628) at net.minecraftforge.fml.client.FMLClientHandler.beginMinecraftLoading(FMLClientHandler.java:252) at net.minecraft.client.Minecraft.init(Minecraft.java:513) -- Initialization -- Details: Stacktrace: at net.minecraft.client.Minecraft.run(Minecraft.java:421) at net.minecraft.client.main.Main.main(Main.java:118) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) at net.minecraft.launchwrapper.Launch.main(Launch.java:28) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at net.minecraftforge.gradle.GradleStartCommon.launch(GradleStartCommon.java:97) at GradleStart.main(GradleStart.java:25) -- System Details -- Details: Minecraft Version: 1.12.2 Operating System: Windows 10 (amd64) version 10.0 Java Version: 1.8.0_181, Oracle Corporation Java VM Version: Java HotSpot(TM) 64-Bit Server VM (mixed mode), Oracle Corporation Memory: 909443472 bytes (867 MB) / 1038876672 bytes (990 MB) up to 2112618496 bytes (2014 MB) JVM Flags: 4 total; -Xincgc -Xmx1024M -Xms1024M -Xmx2048m IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0 FML: MCP 9.42 Powered by Forge 14.23.5.2768 5 mods loaded, 5 mods active States: 'U' = Unloaded 'L' = Loaded 'C' = Constructed 'H' = Pre-initialized 'I' = Initialized 'J' = Post-initialized 'A' = Available 'D' = Disabled 'E' = Errored | State | ID | Version | Source | Signature | |:----- |:--------- |:------------ |:-------------------------------- |:--------- | | UCH | minecraft | 1.12.2 | minecraft.jar | None | | UCH | mcp | 9.42 | minecraft.jar | None | | UCH | FML | 8.0.99.99 | forgeSrc-1.12.2-14.23.5.2768.jar | None | | UCH | forge | 14.23.5.2768 | forgeSrc-1.12.2-14.23.5.2768.jar | None | | UCH | modtut | 0.0.1 | bin | None | Loaded coremods (and transformers): GL info: ' Vendor: 'Intel' Version: '4.0.0 - Build 10.18.10.4276' Renderer: 'Intel(R) HD Graphics' Launched Version: 1.12.2 LWJGL: 2.9.4 OpenGL: Intel(R) HD Graphics GL version 4.0.0 - Build 10.18.10.4276, Intel GL Caps: Using GL 1.3 multitexturing. Using GL 1.3 texture combiners. Using framebuffer objects because OpenGL 3.0 is supported and separate blending is supported. Shaders are available because OpenGL 2.1 is supported. VBOs are available because OpenGL 1.5 is supported. Using VBOs: Yes Is Modded: Definitely; Client brand changed to 'fml,forge' Type: Client (map_client.txt) Resource Packs: Current Language: English (US) Profiler Position: N/A (disabled) CPU: 4x Intel(R) Pentium(R) CPU N3540 @ 2.16GHz [16:06:34] [main/INFO] [STDOUT]: [net.minecraft.init.Bootstrap:printToSYSOUT:629]: #@!@# Game crashed! Crash report saved to: #@!@# D:\mod\lanterns1122\run\.\crash-reports\crash-2019-08-02_16.06.34-client.txt Picked up _JAVA_OPTIONS: -Xmx2048m Java HotSpot(TM) 64-Bit Server VM warning: Using incremental CMS is deprecated and will likely be removed in a future release Maybe You will know how to solve it. Edited August 2, 2019 by MrPablo2000 Quote Link to comment Share on other sites More sharing options...
Draco18s Posted August 2, 2019 Share Posted August 2, 2019 (edited) 21 minutes ago, MrPablo2000 said: Cannot set property PropertyEnum{name=up, clazz=class com.lanterns.blocks.SlupGora$EnumAttachPosition, values=[up, side, none]} as it does not exist in BlockStateContainer{block=null, properties=[east, north, power, south, west]} Error is pretty self explanatory. Edited August 2, 2019 by Draco18s Quote Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given. Link to comment Share on other sites More sharing options...
MrPablo2000 Posted August 2, 2019 Author Share Posted August 2, 2019 I change this, it isn't crashing now, but it still doesn't provide energy to up... Spoiler protected BlockStateContainer createBlockState() { return new BlockStateContainer(this, new IProperty[] {NORTH, EAST, SOUTH, WEST, UP, DOWN, POWER}); } Quote Link to comment Share on other sites More sharing options...
Animefan8888 Posted August 2, 2019 Share Posted August 2, 2019 1 hour ago, MrPablo2000 said: I change this, it isn't crashing now, but it still doesn't provide energy to up... Doesn't provide energy up? Do you mean that it doesn't transfer energy up or that it isn't connecting up? Quote VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect. Forge and vanilla BlockState generator. Link to comment Share on other sites More sharing options...
MrPablo2000 Posted August 2, 2019 Author Share Posted August 2, 2019 In the future I will add one model for all states - this is the electrical post element. Graphic connection doesn't interesting me - I only want to make this block connectable to up/down in "java" mean, to make it possible to provide power to up. (I don't know how to describe it..) Quote Link to comment Share on other sites More sharing options...
Animefan8888 Posted August 2, 2019 Share Posted August 2, 2019 50 minutes ago, MrPablo2000 said: to make it possible to provide power to up. Provide your TileEntity that handles all the energy. Quote VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect. Forge and vanilla BlockState generator. Link to comment Share on other sites More sharing options...
MrPablo2000 Posted August 2, 2019 Author Share Posted August 2, 2019 I mean redstone power, I haven't got my own energy system, just redstone. Quote Link to comment Share on other sites More sharing options...
Recommended Posts
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.