mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-10-20 08:27:38 +00:00
Update CC: Tweaked to 1.13
Look, I originally had this split into several commits, but lots of other cleanups got mixed in. I then backported some of the cleanups to 1.12, did other tidy ups there, and eventually the web of merges was unreadable. Yes, this is a horrible mess, but it's still nicer than it was. Anyway, changes: - Flatten everything. For instance, there are now three instances of BlockComputer, two BlockTurtle, ItemPocketComputer. There's also no more BlockPeripheral (thank heavens) - there's separate block classes for each peripheral type. - Remove pretty much all legacy code. As we're breaking world compatibility anyway, we can remove all the code to load worlds from 1.4 days. - The command system is largely rewriten to take advantage of 1.13's new system. It's very fancy! - WidgetTerminal now uses Minecraft's "GUI listener" system. - BREAKING CHANGE: All the codes in keys.lua are different, due to the move to LWJGL 3. Hopefully this won't have too much of an impact. I don't want to map to the old key codes on the Java side, as there always ends up being small but slight inconsistencies. IMO it's better to make a clean break - people should be using keys rather than hard coding the constants anyway. - commands.list now allows fetching sub-commands. The ROM has already been updated to allow fancy usage such as commands.time.set("noon"). - Turtles, modems and cables can be waterlogged.
This commit is contained in:
@@ -6,77 +6,47 @@
|
||||
|
||||
package dan200.computercraft.shared.util;
|
||||
|
||||
import net.minecraft.item.EnumDyeColor;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.nbt.NBTTagCompound;
|
||||
import net.minecraftforge.common.util.Constants;
|
||||
import net.minecraftforge.oredict.OreDictionary;
|
||||
import org.apache.commons.lang3.ArrayUtils;
|
||||
import net.minecraft.tags.Tag;
|
||||
import net.minecraftforge.common.Tags;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import javax.annotation.Nullable;
|
||||
|
||||
public final class ColourUtils
|
||||
{
|
||||
private static final String[] DYES = new String[] {
|
||||
"dyeBlack", "dyeRed", "dyeGreen", "dyeBrown",
|
||||
"dyeBlue", "dyePurple", "dyeCyan", "dyeLightGray",
|
||||
"dyeGray", "dyePink", "dyeLime", "dyeYellow",
|
||||
"dyeLightBlue", "dyeMagenta", "dyeOrange", "dyeWhite"
|
||||
@SuppressWarnings( { "unchecked", "rawtypes" } )
|
||||
private static final Tag<Item>[] DYES = new Tag[] {
|
||||
Tags.Items.DYES_WHITE,
|
||||
Tags.Items.DYES_ORANGE,
|
||||
Tags.Items.DYES_MAGENTA,
|
||||
Tags.Items.DYES_LIGHT_BLUE,
|
||||
Tags.Items.DYES_YELLOW,
|
||||
Tags.Items.DYES_LIME,
|
||||
Tags.Items.DYES_PINK,
|
||||
Tags.Items.DYES_GRAY,
|
||||
Tags.Items.DYES_LIGHT_GRAY,
|
||||
Tags.Items.DYES_CYAN,
|
||||
Tags.Items.DYES_PURPLE,
|
||||
Tags.Items.DYES_BLUE,
|
||||
Tags.Items.DYES_BROWN,
|
||||
Tags.Items.DYES_GREEN,
|
||||
Tags.Items.DYES_RED,
|
||||
Tags.Items.DYES_BLACK,
|
||||
};
|
||||
|
||||
private static int[] ids;
|
||||
|
||||
@Nullable
|
||||
private ColourUtils() {}
|
||||
|
||||
public static int getStackColour( ItemStack stack )
|
||||
public static EnumDyeColor getStackColour( ItemStack stack )
|
||||
{
|
||||
if( ids == null )
|
||||
for( int i = 0; i < DYES.length; i++ )
|
||||
{
|
||||
int[] ids = ColourUtils.ids = new int[DYES.length];
|
||||
for( int i = 0; i < DYES.length; i++ )
|
||||
{
|
||||
ids[i] = OreDictionary.getOreID( DYES[i] );
|
||||
}
|
||||
Tag<Item> dye = DYES[i];
|
||||
if( dye.contains( stack.getItem() ) ) return EnumDyeColor.byId( i );
|
||||
}
|
||||
|
||||
for( int id : OreDictionary.getOreIDs( stack ) )
|
||||
{
|
||||
int index = ArrayUtils.indexOf( ids, id );
|
||||
if( index >= 0 ) return index;
|
||||
}
|
||||
|
||||
return -1;
|
||||
return null;
|
||||
}
|
||||
|
||||
public static int getHexColour( @Nonnull NBTTagCompound tag )
|
||||
{
|
||||
if( tag.hasKey( "colourIndex", Constants.NBT.TAG_ANY_NUMERIC ) )
|
||||
{
|
||||
return Colour.VALUES[tag.getInteger( "colourIndex" ) & 0xF].getHex();
|
||||
}
|
||||
else if( tag.hasKey( "colour", Constants.NBT.TAG_ANY_NUMERIC ) )
|
||||
{
|
||||
return tag.getInteger( "colour" );
|
||||
}
|
||||
else if( tag.hasKey( "color", Constants.NBT.TAG_ANY_NUMERIC ) )
|
||||
{
|
||||
return tag.getInteger( "color" );
|
||||
}
|
||||
else
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
public static Colour getColour( @Nonnull NBTTagCompound tag )
|
||||
{
|
||||
if( tag.hasKey( "colourIndex", Constants.NBT.TAG_ANY_NUMERIC ) )
|
||||
{
|
||||
return Colour.fromInt( tag.getInteger( "colourIndex" ) & 0xF );
|
||||
}
|
||||
else
|
||||
{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user