SYNOPSIS

  use strict;
  use HTML::Display;

  # guess the best value from $ENV{PERL_HTML_DISPLAY_CLASS}
  # or $ENV{PERL_HTML_DISPLAY_COMMAND}
  # or the operating system, in that order
  my $browser = HTML::Display->new();
  warn "# Displaying HTML using " . ref $browser;
  my $location = "http://www.google.com/";
  $browser->display(html => $html, location => $location);

  # Or, for a one-off job :
  display("<html><body><h1>Hello world!</h1></body></html>");

DESCRIPTION

This module abstracts the task of displaying \s-1HTML\s0 to the user. The displaying is done by launching a browser and navigating it to either a temporary file with the \s-1HTML\s0 stored in it, or, if possible, by pushing the \s-1HTML\s0 directly into the browser window.

The module tries to automagically select the \*(L"correct\*(R" browser, but if it dosen't find a good browser, you can modify the behaviour by setting some environment variables :

PERL_HTML_DISPLAY_CLASS

If HTML::Display already provides a class for the browser you want to use, setting \*(C`PERL_HTML_DISPLAY_CLASS\*(C' to the name of the class will make HTML::Display use that class instead of what it detects.

PERL_HTML_DISPLAY_COMMAND

If there is no specialized class yet, but your browser can be controlled via the command line, then setting \*(C`PERL_HTML_DISPLAY_COMMAND\*(C' to the string to navigate to the \s-1URL\s0 will make HTML::Display use a \*(C`system()\*(C' call to the string. A %s in the value will be replaced with the name of the temporary file containing the \s-1HTML\s0 to display. The hash %HTML::Display::os_default contains pairs of class names for the different operating systems and routines that test whether this script is currently running under it. If you you want to dynamically add a new class or replace a class (or the rule), modify %os_default :

# Install class for MagicOS $HTML::Display::os_default{"HTML::Display::MagicOS"} = sub { $^O =~ qr/magic/i }; Will display the \s-1HTML\s0. The following arguments are valid :

base => Base to which all relative links will be resolved html => Scalar containing the HTML to be displayed file => Scalar containing the name of the file to be displayed This file will possibly be copied into a temporary file!

location (synonymous to base)

If only one argument is passed, then it is taken as if

html => $_[0]

was passed.

EXPORTS

The subroutine \*(C`display\*(C' is exported by default

COMMAND LINE USAGE

Display some \s-1HTML\s0 to the user :

perl -MHTML::Display -e "display '<html><body><h1>Hello world</body></html>'"

Display a web page to the user :

perl -MLWP::Simple -MHTML::Display -e "display get 'http://www.google.com'"

Display the same page with the images also working :

perl -MLWP::Simple -MHTML::Display -e "display html => get('http://www.google.com'), location => 'http://www.google.com'"

AUTHOR

Copyright (c) 2004-2007 Max Maischein \*(C`<[email protected]>\*(C'

LICENSE

This module is released under the same terms as Perl itself.