1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
use strict;
use warnings;
use Irssi 20140603;
our $VERSION = '1.1';
our %IRSSI = (
authors => 'Irssi staff',
contact => 'staff@irssi.org',
url => 'https://irssi.org',
name => 'cubes',
description => '256 colour test script for Irssi.',
license => 'Public Domain',
);
sub cubes {
my $t = $_[0];
my $w = Irssi::active_win;
my $C = MSGLEVEL_CLIENTCRAP;
my $N = MSGLEVEL_NEVER | $C;
my $T = $t ? "X" : "x";
my $M = $t ? "" : "99,";
my $P = sub {
$w->print(@_)
};
$P->("%_bases", $C);
$P->( do {
join '', map { "%${T}0${_}0$_" } '0' .. '9', 'A' .. 'F'
}, $N);
$P->("%_cubes", $C);
$P->( do {
my $y = $_*6;
join '', map {
my $x = $_;
map { "%${T}$x$_$x$_" } @{['0' .. '9', 'A' .. 'Z']}[$y .. $y+5]
} 1 .. 6
}, $N)
for 0 .. 5;
$P->("%_grays", $C);
$P->( do {
join '', map { "%${T}7${_}7$_" } 'A' .. 'X'
}, $N);
$P->("%_mIRC extended colours", $C);
my $x;
$x .= sprintf "\cC$M%02d%02d", $_, $_
for 0 .. 15;
$P->($x, $N);
for my $z (0 .. 6) {
my $x;
$x .= sprintf "\cC$M%02d%02d", $_, $_
for 16 + ($z * 12) .. 16 + ($z * 12) + 11;
$P->($x, $N);
}
}
Irssi::command_bind 'cubes' => sub { cubes(0); };
Irssi::command_bind 'cubes_text' => sub { cubes(1); };
|