NAME

Text::Hatena - Perl extension for formatting text with Hatena Style.

SYNOPSIS

use Text::Hatena;

my $parser = Text::Hatena->new(
  permalink => 'http://www.example.com/entry/123',
);
$parser->parse($text);
my $html = $parser->html;

DESCRIPTION

Text::Hatena parses text with Hatena Style and generates html string. Hatena Style is a set of text syntax which is originally used in Hatena Diary (http://d.hatena.ne.jp/).

You can get html string from simple text with syntax like Wiki.

METHODS

Here are common methods of Text::Hatena.

new
$parser = Text::Hatena->new;
$parser = Text::Hatena->new(
  permalink => 'http://www.example.com/entry/123',
  ilevel => 1,
  invalidnode => [qw(h4 h5)],
  sectionanchor => '@',
);

creates an instance of Text::Hatena.

permalink is the uri of your document. It is used in H3 section anchor.

ilevel is the base indent level.

invalidnode is an array reference of invalid nodes. The node in the array will be skipped.

sectionanchor is the string of H3 section anchor.

parse
$parser->parse($text);

parses text and generates html.

html
$html = $parser->html;

returns html string generated.

Text::Hatena Syntax

Text::Hatena supports some simple markup language, which is similar to the Wiki format.

Paragraphs

Basically each line becomes a paragraph. If you want to force a newline in a paragraph, you can use a line break markup of HTML.

You can add footnotes by using double parentheses.

Hatena is in Tokyo((The biggest city in Japan)).

Text::Hatena treats a blank line as the end of a block. A blank line after a paragraph does not affect the output. Two blank lines are translated into a line break, three blank lines are translated into two line breaks and so on.

To stop generating paragraphs automatically, start a line with >< (greater-than sign and less-than sign). The first > (greater-than sign) will be omitted. If you end a line with ><, it will stop. The last < (less-than sign) will be omitted.

><div class="foo">A div block without paragraph.</div><

><form action="foo.cgi" method="put">
To insert a from, write as you see here.
<input type="text" name="a" />
<input type="submit" />
</form><
Headlines

To create a section headline, start a line with a star followed by an anchor, a star, some tags of categories and a section title. An anchor and tags are optional. If you omit an anchor, Text::Hatena generates it automatically.

*A line with a star becomes section headline
*sa*You can specify a string for anchor name
*[foo][bar]You can specify some tags of categories
*sa*[foo][bar]You can mix them

More stars mean deeper levels of headlines. You can use up to three stars for headlines.

**Start a line with two stars to create a 4th level headline
***Start a line with three stars to create a 5th level headline.
Lists and Tables

Text::Hatena supports ordered and unordered lists. Start every line with a minus (-) for unordered lists or a plus (+) for ordered ones. More marks mean deeper levels. You can show the end of the lists by a blank line.

-Start a line with minuses to create an unordered list item.

+Start a line with pluses to create an ordered list item.
++They can be nested.

Text::Hatena supports definition lists. Start every line with a colon followed by a term, a colon, and a description.

:term:description

You can create tables by using a simple syntax. Table rows have to start and end with a vertical bar (|). Separete every cell with a vertical bar (|). To turn cells into headers, begin them with a star.

|*header1|*header2|
|colum1|colum2|
Blockquotes

To make a blockquote, enclose line(s) with >> (double greater-than sign) and << (double less-than sign). Marks should be placed in separate lines; don't start quoting line(s) with >> or end them with <<. Blockquotes may be nested.

>>
To make a blockquote, enclose line(s) with >> (double greater-than sign)
and << (double less-than sign).
<<
Preformatted texts

To make a preformatted text, enclose line(s) with >| (a greater-than sign followed by a vertical bar) and |< (a vertical var followed by a less-than sign).

Every >| should be placed in separate lines; don't start preformatted line(s) with >|. But some preformatted texts may be closed by |< after the last lines without separating lines.

>|
To make a preformatted text, enclose line(s) with >|
(a greater-than sign followed by a vertical bar) and |<
(a vertical var followed by a less-than sign).
|<

This also works well.

>|
To make a preformatted text, enclose line(s) with >|
(a greater-than sign followed by a vertical bar) and |<
(a vertical var followed by a less-than sign).|<

To encode special characters into HTML entities, use >|| and ||< for >| and |<. The characters to be replaced are less-than signs (<), greater-than signs (>), double quotes ("), and ampersands (&).

>||
To encode special characters into HTML entities,
use >|| and ||< for >| and |<.
||<

SEE ALSO

http://d.hatena.ne.jp/ (Japanese)

CREDITS

Thanks to id:tociyuki <http://d.hatena.ne.jp/tociyuki/> for helping some implementations and writing syntax guide. Thanks to id:charsbar <http://d.hatena.ne.jp/charsbar/> for helping to refine the guide.

AUTHOR

Junya Kondo, <jkondo@hatena.ne.jp>

COPYRIGHT AND LICENSE

Copyright (C) 2005 by Junya Kondo

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