The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Term::ExtendedColor::Xresources - Query and set various Xresources

SYNOPSIS

    use Term::ExtendedColor::Xresources qw(
      get_xterm_color
      set_xterm_color
      set_foreground_color
      set_background_color
    );

    # make color index 220 represent red instead of yellow
    set_xterm_color({ 220 => 'ff0000'});

    # get RGB values for all defined colors
    my $colors = get_xterm_color({
      index => [0 .. 255], # default
      type  => 'hex',      # default is base 10
    });

    # change the background color to red...
    set_background_color('ff0000');

    # .. and the foreground color to yellow
    set_foreground_color('ffff00');

DESCRIPTION

Term::ExtendedColor::Xresources provides functions for changing and querying the underlying X terminal emulator for various X resources.

EXPORTS

None by default.

FUNCTIONS

set_xterm_color()

  # Switch yellow and red
  my $new_colors = set_xterm_color({
    220 => 'ff0000',
    196 => 'ffff00',
  });

  print $_ for values %{$new_colors};

  # or just...

  set_xterm_color({ 100 => ff0066});

Expects a hash reference where the keys are color indexes (0 .. 255) and the values hexadecimal representations of the color values.

Changes the colors if called in void context. Else, returns a hash with the indexes as keys and the appropriate escape sequences as values.

get_xterm_color()

  my $defined_colors = get_xterm_color({ index => [0 .. 255], type => 'dec' });

  print $defined_colors->{4}->{red}, "\n";
  print $defined_colors->{8}->{rgb}, "\n";

0 - 15 is the standard ANSI colors, all above them are extended colors.

Returns a hash reference with the index colors as keys. By default the color values are in decimal.

The color values can be accessed by using their name:

  my $red = $colors->{10}->{red};

Or by using the short notation:

  my $red = $colors->{10}->{r};

The full color string can be retrieved like so:

  my $rgb = $colors->{10}->{rgb};

The raw element is the full, raw response from the terminal, including escape sequences.

The following arguments are supported:

index => $index | \@indexes

Arrayref of color indexes to look up and return. Defaults to [0..255], i.e. all indexes. Alternately a single index may be passed.

type => 'dec' | 'hex'

May be 'dec' or 'hex'. The default is 'dec' (decimal) which returns color values as integers between 0 and 255, and returns a 'rgb' string of the form '$r/$g/$b' e.g. '255/0/0'. If 'hex' is passed, returns color values in base 16, zero-padded to two characters (between 00 and ff) and a 'rgb' string of the form '$r$g$b' e.g. 'ff0000'

get_xterm_colors()

The same thing as get_xterm_color(). Will be deprecated.

set_foreground_color()

  set_foreground_color('ff0000');

  my $fg = set_foreground_color('c0ffee');

Sets the foreground color if called in void context. Else, the appropriate escape sequence is returned.

set_background_color()

  set_background_color('121212');

  my $bg = set_foreground_color('000000');

Sets the foreground color if called in void context. Else, the appropriate escape sequence is returned.

SEE ALSO

Term::ExtendedColor

AUTHOR

  Magnus Woldrich
  CPAN ID: WOLDRICH
  m@japh.se
  http://japh.se

CONTRIBUTORS

None required yet.

COPYRIGHT

Copyright 2010, 2011 the Term::ExtendedColor::Xresources "AUTHOR" and "CONTRIBUTORS" as listed above.

LICENSE

This library is free software; you may redistribute it and/or modify it under the same terms as Perl itself.