NAME

dtRdr::TOC - a linked Table of Contents tree

SYNOPSIS

This pod needs work.

Constructor

new

Create a new TOC item.

my $toc = dtRdr::TOC->new( $book, $id, $range,
  {
    title   => $title,
    visible => 1|0,
    info => {
      my_thing => $foo,
    }
  },
  );

where

book is the book object for this TOC entry,

id is a unique identifier within this tree,

range is a dtRdr::Range object that represents the text to which this TOC entry refers,

title is the display title for the TOC entry,

info => {foo => 'bar'} is some information for your own later reference.

and

A final, optional argument parent is the parent TOC item for this item. You should typically not need the parent argument. See create_child() for why.

create_child

my $child = $toc->create_child($id, $range, \%info);

TODO

And maybe something in Range -- see Metadata.pm's feature envy

my ($node, $bytes) = $toc->node_before_location($loc);

foreach my $node (@toc) { if($start < $loc and $loc < $stop) { last; } }

Accessors

All accessors are get_foo() and set_foo(). foo() is an alias to get_foo().

id

Returns the ID for this TOC object

my $id = $toc->id;

book

Returns something representing the book object (maybe just an identifier for it) for this TOC object.

TREATING THE RESULT AS A BOOK MAY BREAK YOUR CODE!

my $bookid = $toc->book;

range

Returns the range object for this TOC object

my $range = $toc->range;

get_title

returns the title for this TOC node

$toc->title

get_visible

$toc->visible and print "visible!\n";

Returns true or false indicating whether the TOC item should be displayed in the TOC widget.

Tree Operations

get_children

Returns all the child TOC objects for this TOC object. Returns the empty list if there are none.

my @children = $toc->get_children;

descendants

Recursive children

my @descendants = $toc->descendants;

older_siblings

Nodes before this, at the same level.

$toc->older_siblings;

younger_siblings

Nodes after this, at same level

$toc->younger_siblings

next_sibling

Returns the next sibling or undef if there is none.

$younger = $toc->next_sibling;

prev_sibling

Returns the previous sibling or undef if there is none.

$older = $toc->prev_sibling;

parent

Returns the parent TOC object for the current object, or undef if there is no parent TOC object.

$toc->parent

ancestors

Returns all of the node's ancestors (from parent upward.)

my @ancestors = $toc->ancestors;

has_children

True if the node has children.

$toc->has_children

add_child

Add a child TOC entry to this TOC entry.

$toc->add_child($child);

get_child

Get the child with index $i.

my $child = $toc->get_child($i);

get_root

my $root = $toc->get_root;
$root ||= $toc; # it was the root

is_root

$toc->is_root;

_walk_to_node

Walks to the tree vector given by a list of successive child indices.

my $node = $toc->_walk_to_node(@list);

_add_to_index

$root->_add_to_index($self);

get_by_id

my $node = $toc->get_by_id($id);

enclosing_node

Searches for the node which encloses the given offset.

$toc->enclosing_node($offset);

Meta Accessors

get_info

$toc->get_info($key);

set_info

$toc->set_info($key, $val);

validate_ranges

my $bool = $toc->validate_ranges;

_dump

print $toc->_dump;

rmap

Depth-first recursion. At each level, $sub is called as $sub->($node, \%ctrl).

The %ctrl hash allows you to send commands back to the dispatcher.

my $sub = sub {
  my ($node, $ctrl) = @_;
  if(something($node)) {
    $ctrl->{prune} = 1; # do not follow children
  }
};
$toc->rmap($sub);

_rmap

deprecated

$toc->_rmap($sub);

_while_gutted

$toc->_while_gutted(sub {my $braindead = shift;});

_unhook

Drop book, parent, and _index. Turn ranges into [$id, $start, $end].

$simple = $toc->_unhook;

_rehook

...re-attach the book (as well as rebuilding the index.)

$obj->_rehook($book);

unhooked

my $plain = $toc->unhooked;

yaml_dump

Maybe Deprecated - do your own dumps?

my $yaml = $toc->yaml_dump;

yaml_load

Load the TOC from a YAML string (or reference if you need the speed) and re-attach the book (as well as rebuilding the index.)

my $re_toc = dtRdr::TOC->yaml_load($yaml, $book);

my $re_toc = dtRdr::TOC->yaml_load(\$yaml, $book);

stb_load

Load from a Storable.pm binary file.

my $re_toc = dtRdr::TOC->stb_load(\$stb, $book);

freeze

$stored = $toc->freeze;

thaw

$toc->thaw($book);

AUTHOR

Eric Wilhelm <ewilhelm at cpan dot org>

COPYRIGHT

Copyright (C) 2006 Eric L. Wilhelm and OSoft, All Rights Reserved.

NO WARRANTY

Absolutely, positively NO WARRANTY, neither express or implied, is offered with this software. You use this software at your own risk. In case of loss, no person or entity owes you anything whatsoever. You have been warned.

LICENSE

The dotReader(TM) is OSI Certified Open Source Software licensed under the GNU General Public License (GPL) Version 2, June 1991. Non-encrypted and encrypted packages are usable in connection with the dotReader(TM). The ability to create, edit, or otherwise modify content of such encrypted packages is self-contained within the packages, and NOT provided by the dotReader(TM), and is addressed in a separate commercial license.

You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.