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

NAME

Markdent::Parser - A markdown parser

VERSION

version 0.13

SYNOPSIS

  my $handler = Markdent::Handler::HTMLStream->new( ... );

  my $parser = Markdent::Parser->new(
      dialect => ...,
      handler => $handler,
  );

  $parse->parse( markdown => $markdown );

DESCRIPTION

This class provides the primary interface for creating a parser. It ties a block and span parser together with a handler.

By default, it will parse the standard Markdown dialect, but you can provide alternate block or span parser classes.

METHODS

This class provides the following methods:

Markdent::Parser->new(...)

This method creates a new parser. It accepts the following parameters:

  • dialect => $name

    You can use this as a shorthand to pick a block and/or span parser class.

    If the dialect parameter does not contain a namespace separator (::), the constructor looks for classes named Markdent::Dialect::${dialect}::BlockParser and Markdent::Dialect::${dialect}::SpanParser.

    If the dialect parameter does contain a namespace separator, it is used a prefix - $dialect::BlockParser and $dialect::SpanParser.

    If any relevant classes are found, they will be used by the parser.

    You can also specify an explicit block or span parser, but if the dialect has its own class of that type, an error will be thrown.

    If the dialect only specifies a block or span parser, but not both, then we fall back to using the appropriate parser for the Standard dialect.

  • block_parser_class => $class

    This default to Markdent::Dialect::Standard::BlockParser, but can be any class which implements the Markdent::Role::BlockParser role.

  • span_parser_class => $class

    This default to Markdent::Dialect::Standard::SpanParser, but can be any class which implements the Markdent::Role::SpanParser role.

  • handler => $handler

    This can be any object which implements the Markdent::Role::Handler role. It is required.

$parser->parse( markdown => $markdown )

This method parses the given document. The parsing will cause events to be fired which will be passed to the parser's handler.

ROLES

This class does the Markdent::Role::EventsAsMethods and Markdent::Role::Handler roles.

BUGS

See Markdent for bug reporting details.

AUTHOR

  Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2010 by Dave Rolsky.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.