1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-10-26 11:27:38 +00:00

Get rid of setPaletteColour table overload

This commit is contained in:
Lignum
2017-05-07 15:04:09 +02:00
parent 941d47908f
commit c10e1ba78c
3 changed files with 6 additions and 76 deletions

View File

@@ -120,50 +120,6 @@ public class TermAPI implements ILuaAPI
} }
} }
public static void setColour( Terminal terminal, HashMap<Object, Object> colours) throws LuaException
{
final double lg2 = Math.log( 2 );
for(Map.Entry<Object, Object> e : colours.entrySet())
{
if(e.getKey() instanceof Double)
{
int index = 15 - (int)( Math.log( (Double)e.getKey() ) / lg2 );
try
{
if (e.getValue() instanceof HashMap)
{
@SuppressWarnings({ "unchecked" }) // There isn't really a nice way around this :(
HashMap<Object, Object> colour = (HashMap<Object, Object>) e.getValue();
setColour(
terminal,
index,
( (Double)colour.get( 1.0 ) ).floatValue(),
( (Double)colour.get( 2.0 ) ).floatValue(),
( (Double)colour.get( 3.0 ) ).floatValue()
);
}
else if (e.getValue() instanceof Double)
{
float[] rgb = Palette.decodeRGB8( ((Double)e.getValue()).intValue() );
setColour(
terminal,
index,
rgb[0], rgb[1], rgb[2]
);
}
}
catch(ClassCastException cce)
{
throw new LuaException( "Malformed colour table " + cce.getMessage() );
}
}
}
}
@Override @Override
public Object[] callMethod( ILuaContext context, int method, Object[] args ) throws LuaException public Object[] callMethod( ILuaContext context, int method, Object[] args ) throws LuaException
{ {
@@ -337,14 +293,6 @@ public class TermAPI implements ILuaAPI
case 20: case 20:
{ {
// setPaletteColour/setPaletteColor // setPaletteColour/setPaletteColor
if(args.length >= 1 && args[0] instanceof HashMap)
{
@SuppressWarnings( { "unchecked" } ) // There isn't really a nice way around this :(
HashMap<Object, Object> colourTbl = (HashMap<Object, Object>)args[0];
setColour( m_terminal, colourTbl );
return null;
}
if(args.length == 2 && args[0] instanceof Double && args[1] instanceof Double) if(args.length == 2 && args[0] instanceof Double && args[1] instanceof Double)
{ {
int colour = 15 - parseColour( args, true ); int colour = 15 - parseColour( args, true );
@@ -364,7 +312,7 @@ public class TermAPI implements ILuaAPI
return null; return null;
} }
throw new LuaException( "Expected table or number, number or number, number, number, number" ); throw new LuaException( "Expected number, number or number, number, number, number" );
} }
case 21: case 21:
case 22: case 22:

View File

@@ -232,14 +232,6 @@ public class MonitorPeripheral implements IPeripheral
// setPaletteColour/setPaletteColor // setPaletteColour/setPaletteColor
Terminal terminal = m_monitor.getTerminal().getTerminal(); Terminal terminal = m_monitor.getTerminal().getTerminal();
if(args.length >= 1 && args[0] instanceof HashMap )
{
@SuppressWarnings( { "unchecked" } ) // There isn't really a nice way around this :(
HashMap<Object, Object> colourTbl = (HashMap<Object, Object>)args[0];
dan200.computercraft.core.apis.TermAPI.setColour( terminal, colourTbl );
return null;
}
if(args.length == 2 && args[0] instanceof Double && args[1] instanceof Double) if(args.length == 2 && args[0] instanceof Double && args[1] instanceof Double)
{ {
int colour = 15 - dan200.computercraft.core.apis.TermAPI.parseColour( args, true ); int colour = 15 - dan200.computercraft.core.apis.TermAPI.parseColour( args, true );
@@ -259,7 +251,7 @@ public class MonitorPeripheral implements IPeripheral
return null; return null;
} }
throw new LuaException( "Expected table or number, number, number, number" ); throw new LuaException( "Expected number, number or number, number, number, number" );
} }
case 22: case 22:
case 23: case 23:

View File

@@ -107,7 +107,9 @@ function create( parent, nX, nY, nWidth, nHeight, bStartVisible )
end end
local function updatePalette() local function updatePalette()
return parent.setPaletteColour( tPalette ) for k,v in pairs( tPalette ) do
parent.setPaletteColour( k, table.unpack( v ) )
end
end end
local function internalBlit( sText, sTextColor, sBackgroundColor ) local function internalBlit( sText, sTextColor, sBackgroundColor )
@@ -287,19 +289,7 @@ function create( parent, nX, nY, nWidth, nHeight, bStartVisible )
end end
function window.setPaletteColour( colour, r, g, b ) function window.setPaletteColour( colour, r, g, b )
if type(colour) == "table" then if type(colour) == "number" and type(r) == "number" and g == nil and b == nil then
for k,v in pairs(colour) do
if type(v) == "number" then
local vr, vg, vb = colours.rgb8( v )
tPalette[k] = { vr, vg, vb }
parent.setPaletteColour( k, vr, vg, vb )
elseif type(v) == "table" then
tPalette[k] = v
parent.setPaletteColour( k, table.unpack( v ) )
end
end
return
elseif type(colour) == "number" and type(r) == "number" and g == nil and b == nil then
tPalette[ colour ] = { colours.rgb8( r ) } tPalette[ colour ] = { colours.rgb8( r ) }
elseif type(colour) == "number" and type(r) == "number" and type(g) == "number" and type(b) == "number" then elseif type(colour) == "number" and type(r) == "number" and type(g) == "number" and type(b) == "number" then
local tCol = tPalette[ colour ] local tCol = tPalette[ colour ]