From 35d85fc1c8ac6aa801bdd6436e44efb80d689a25 Mon Sep 17 00:00:00 2001 From: Mischa POSLAWSKY Date: Tue, 2 May 2017 22:45:13 +0200 Subject: [PATCH] termcol: hue order for ppu tables --- termcol.inc.pl | 2 ++ termcol.plp | 9 +++++---- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/termcol.inc.pl b/termcol.inc.pl index 520dbe2..3411852 100644 --- a/termcol.inc.pl +++ b/termcol.inc.pl @@ -323,6 +323,7 @@ use Shiar_Sheet::Colour 1.05; ] } 0..13 } ], + hueorder => [6..12, 1..5, 13, 0], }, shovel => { name => 'NES for Shovel Knight', @@ -344,6 +345,7 @@ use Shiar_Sheet::Colour 1.05; [qw( 22123B:0S 360900:1S 824E00:2S 9E9E5C:3S )], ], parent => 'ppu', + hueorder => [6..12, 1..5, 13, 0, 14], }, 64 => { diff --git a/termcol.plp b/termcol.plp index 3880a62..6d69f0c 100644 --- a/termcol.plp +++ b/termcol.plp @@ -115,6 +115,8 @@ sub coltable { } ref $info eq 'HASH' or return; + my $order = $get{order} && $get{order}.'order'; + my $reorder = $info->{$order} // $palettes->{ $info->{parent} }->{$order}; my $caption = $info->{name} // $term; $caption = sprintf('<%s %s>%s', @@ -134,6 +136,8 @@ sub coltable { print coltable_hsv(@{$_}) for $info->{rgbmap} || (); if (my $table = $info->{table}) { + $table = [ @{$table}[@{$reorder}] ] if $reorder; + for my $row (@$table) { if (!$row) { say ''; @@ -158,10 +162,7 @@ sub coltable { } if (my $palette = $info->{list}) { - my $order = $get{order} && $get{order}.'order'; - my $colours = colorder($palette, - $info->{$order} // $palettes->{ $info->{parent} }->{$order} - ); + my $colours = colorder($palette, $reorder); my $rows = 8; my $columns = ceil(@{$palette} / $rows); -- 2.30.0