NAME LaTeX::Pod - Transform LaTeX source files to POD (Plain old documentation) SYNOPSIS use LaTeX::Pod; $parser = LaTeX::Pod->new('/path/to/source'); print $parser->convert; DESCRIPTION `LaTeX::Pod' converts LaTeX sources to Perl's POD (Plain old documentation). Currently only a subset of the available LaTeX language is supported; see SUPPORTED LANGUAGE SUBSET for further details. CONSTRUCTOR new The constructor requires that the path to the LaTeX source is defined: $parser = LaTeX::Pod->new('/path/to/source'); Returns the parser object. METHODS convert There is one public *method* available, namely `convert()': $pod = $parser->convert; Returns the computed POD as a string. SUPPORTED LANGUAGE SUBSET LaTeX currently supported: * abstracts * chapters * sections/subsections/subsubsections * description, enumerate and itemize lists * verbatim blocks (and indentation) * plain text * bold/italic/code font tags * umlauts * newlines * comments IMPLEMENTATION DETAILS The current implementation is based upon LaTeX::TOM (the framework being used for parsing the LaTeX source) and its clear distinction between various types of nodes. As an example, a `\chapter' command has a separate text associated with it as its content. `LaTeX::Pod' uses a "look-behind" mechanism for commands and their corresponding texts since they currently cannot be easily detected without such a mechanism. Thus `LaTeX::Pod' was designed with the intention to be *context-sensitive* aware. This is also being aimed at by eventually registering which type of node has been seen before the current one -- useful when constructing logical paragraphs made out of two or more nodes. `LaTeX::Pod' then finally unregisters the type of node seen when it is no longer required. In addition, a dispatch queue is built internally which is executed after all nodes have been processed. Considering that the POD format has a limited subset of directives, the complexity of keeping track of node occurences appears to be bearable. Leading and trailing newlines will be removed from the node's text extracted where needed; furthermore, trailing spaces and tabs will also be purged from each line of POD resulting. BUGS & CAVEATS It is highly recommended to ensure that the structure of the LaTeX input file follows the format specification strictly or the parser may not succeed. SEE ALSO LaTeX::TOM AUTHOR Steven Schubiger <schubiger@cpan.org> LICENSE This program is free software; you may redistribute it and/or modify it under the same terms as Perl itself. See http://dev.perl.org/licenses/