Provided by: libhtml-tagtree-perl_1.03-1.1_all bug

NAME

          HTML::TagTree - An HTML generator via a tree of 'tag' objects.

SYNOPSIS

          use HTML::TagTree;

          my $html = HTML::TagTree->new('html');   # Define the top of the tree of objects.
          my $head = $html->head();                # Put a 'head' branch on the tree.
          my $body = $html->body();                # Put a 'body' branch on the tree
          $head->title("This is the Title of Gary's Page, the opening title...");
          $head->meta('', 'name=author CONTENT="Dan DeBrito"');
          $body->div->h1('Hello Dolly');           # Example of method chaining to create
                                                   # a long branch.
          my $table = $body->table('', 'width=100% border=1');
          my $row1 = $table->tr();
          $row1->td('cell a');
          $row1->td('cell b');
          $table->tr->td('This is a new row with new cell');
          $table->tr->td('This is a another new row with new data');

          # Print to STDOUT the actual HTML representation of the tree
          $html->print_html();

          # Put HTML into a scalar variable
          my $html_source = $html->get_html_text();

          # Force destruction of object tree
          $html->release();

DESCRIPTION

             HTLM::TagTrees allows easy building of a tree objects where
             each object represents: 1) a tag 2) its value and 3) any
             tag attributes. Valid HTML is build of the tree via a method call.

FEATURES

          Smart quoting of tag parameters:
          Doing something like this:
             $body->div('','id=nav onclick="alert(\"Hello World\"');
          the HTML module will render HTML that looks like:
             <div id="nav" onclick='alert("Hello World")' \>

          Reduce whitespace in your HTML rendering by turning
          on the no_whitespace_flag.
          my $no_whitespace_html_text = $html->get_html_text('',1);

          # Or..
          my $indent_level = 0;
          my $no_whitespace_flag = 1;
          print $html_obj->get_html_text($indent_level, $no_whitespace_flag);

INITIALIZATION

             HTML::TagTree->new(tag_name,[value],[attributes])
                Returns a TagTree object

METHODS

             Every HTML tag type is an object method.
             $obj->tag_name(content,attributes);
                Returns:
                   object for valid creation
                   undef if tag_name is not a valid name;
                Arguments:
                   content:
                      Untagged data that goes in between open and close tag. eg
                         <b>content</b>
                      Content my be a Perl scalar, a ref to a scalar,
                      or ref to a subroutine. Dereferencing occurs at the
                      time of HTML rendering (via print_html()
                      or get_html_text() methods).
                   attributes:
                      Attributes of this HTML tag.
                      Attributes argument may be a Perl scalar, a ref to a scalar,
                      or a ref to a subroutine. Dereferencing occurs at the
                      time of HTML rendering.
                      Example of attributes:
                         'id=first_name name=fn class=str_cl'
             get_html_text(indent_level, no_whitespace_flag)
                Returns valid HTML representation of tag tree starting at the object.
                Arguments:
                   indent_level:
                      Starting amount of indentation. Typically leave undef or 0.
                   no_whitespace_flag:
                      Set to '1' to prevent insertion of linefeeds and whitespace padding
                      for legibility.
             print_html()
                Prints the valid HTML to STDOUT
             release()
                Destroys all children objects so no objects reference
                this object (and it can be destroyed when it goes out of scope).
             set_valid_tags( tag_names )
                Clears and sets what the valid tag names are for which
                objects can be created.

FUNCTIONS

             HTML::TagTree::get_http_header();
                Returns the generic HTTP header:
                   "Content-type: text/html\nStatus: 200  OK\n\n";

ABSTRACT

             The philosophy of HTML::TagTree is to let you create
             one region of code with lots of business logic
             for rendering many possible resulting HTML files/output.
             This differs from the approach of using business logic code
             to decide which HTML template (of many) to render.
             So rather than maintaining many HTML templates, you
             maintain a Perl file that does all possible customizations
             of HTML generation.

             This module strives to minimize typing. Object treeing is
             just a simple method call, eg:
                $body->h1->b->i('This is a bold, italic heading');

             HTML::TagTree removes the worries of making simple HTML syntax
             errors such as no matching closing tag for an open tag.

VERSION

       HTML::TagTree version 1.03.

PREREQUISITES

       No prerequisites.

AUTHOR

       Dan DeBrito (<ddebrito@gmail.com>)

COPYRIGHT

       Copyright (c) 2007 - 2011 by Dan DeBrito. All rights reserved.

LICENSE

       This package is free software; you can redistribute it and/or modify it under the same
       terms as Perl itself, i.e., under the terms of the "Artistic License" or the "GNU General
       Public License".

       Please refer to the files "Artistic.txt", "GNU_GPL.txt" and "GNU_LGPL.txt" in this
       distribution for details!

DISCLAIMER

       This package is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
       without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

       See the "GNU General Public License" for more details.