, dialect => 'PmWiki' );
close DATA;
__DATA__
aname
__H__
__W__
!! [[#introduction]]Introduction
__NEXT__
aname w/ content
__H__
__W__
!! [[#intro]]Introduction '''stuff'''
__NEXT__
aname w/ href
__H__
__W__
!! [[#intro]][[http://www.google.com | Google]]
__NEXT__
ext. link
__H__
http://www.google.com
__W__
http://www.google.com
__NEXT__
ext. link w/ alt text
__H__
Google
__W__
[[http://www.google.com | Google]]
__NEXT__
bold
__H__
bold
__W__
'''bold'''
__NEXT__
italics
__H__
italics
__W__
''italics''
__NEXT__
bold and italics
__H__
bold and italics
__W__
'''bold''' and ''italics''
__NEXT__
bold-italics nested
__H__
bold-italics nested
__W__
'''''bold-italics'' nested'''
__NEXT__
strong
__H__
strong
__W__
'''strong'''
__NEXT__
emphasized
__H__
emphasized
__W__
''emphasized''
__NEXT__
deleted
__H__
deleted text
__W__
{-deleted text-}
__NEXT__
inserted
__H__
inserted text
__W__
{+inserted text+}
__NEXT__
one-line phrasals
__H__
phrasals
in one line
__W__
''phrasals in one line''
__NEXT__
paragraph blocking
__H__
p1
p2
__W__
p1
p2
__NEXT__
lists
__H__
__W__
* 1
* 2
__NEXT__
nested lists
__H__
__W__
* 1
** 1a
** 1b
* 2
__NEXT__
nested lists (different types)
__H__
__W__
* 1
** a
### i
** b
* 2
:: foo: bar
__NEXT__
hr
__H__
__W__
----
__NEXT__
br
__H__
stuff
stuff two
__W__
stuff \\
stuff two
__NEXT__
sub
__H__
H2O
__W__
H'_2_'O
__NEXT__
sup
__H__
x2
__W__
x'^2^'
__NEXT__
small
__H__
small text
__W__
'-small text-'
__NEXT__
big
__H__
big text
__W__
'+big text+'
__NEXT__
code
__H__
$name = 'stan';
__W__
@@$name = 'stan';@@
__NEXT__
tt
__H__
tt text
__W__
@@tt text@@
__NEXT__
indent
__H__
indented text
__W__
->indented text
__NEXT__
nested indent
__H__
stuff
double-indented stuff
__W__
->stuff
-->double-indented stuff
__NEXT__
h1
__H__
h1
__W__
! h1
__NEXT__
h2
__H__
h2
__W__
!! h2
__NEXT__
h3
__H__
h3
__W__
!!! h3
__NEXT__
h4
__H__
h4
__W__
!!!! h4
__NEXT__
h5
__H__
h5
__W__
!!!!! h5
__NEXT__
h6
__H__
h6
__W__
!!!!!! h6
__NEXT__
__H__
First | Last |
Barney | Rubble |
Foo | Bar |
__W__
|| border="1" width="50%"
||!First ||!Last ||
||Barney ||Rubble ||
||Foo ||Bar ||
__NEXT__
table w/ colspan
__H__
Table |
Heading |
Example |
Left |
Center |
Right |
A |
B |
C |
|
single |
|
|
multi span |
__W__
|| border="1" width="50%" align="center"
||!Table ||!Heading ||!Example ||
||!Left || Center || Right||
||A ||! B || C||
|| || single || ||
|| || multi span ||||
__NEXT__
pre
__H__
this
is pre-
formatted
text
__W__
this
is pre-
formatted
text
__NEXT__
pre w/ formatting
__H__
this
is pre-
formatted text
with special formatting
__W__
this
is pre-
formatted tex'^t^'
with '''special''' {-formatting-}
__NEXT__
br on separate lines (bug #18287)
__H__
line1
line2
__W__
line1 \\
line2
HTML-WikiConverter-PmWiki-0.51/META.yml 0100644 0004734 0023422 00000000632 10460004746 016426 0 ustar diberri hoc # http://module-build.sourceforge.net/META-spec.html
#XXXXXXX This is a prototype!!! It will change in the future!!! XXXXX#
name: HTML-WikiConverter-PmWiki
version: 0.51
version_from: lib/HTML/WikiConverter/PmWiki.pm
installdirs: site
requires:
HTML::WikiConverter: 0.6
Test::More: 0
distribution_type: module
generated_by: ExtUtils::MakeMaker version 6.17
HTML-WikiConverter-PmWiki-0.51/Changes 0100644 0004734 0023422 00000000605 10460004630 016440 0 ustar diberri hoc # Change log for HTML::WikiConverter::PmWiki
version: 0.51
date: Thu Jul 20 2006
changes:
- (bug 18562) Line breaks converted to "[[<<]]" within tables (thanks pcascon)
- (bug 18287) Fixed
tag problem in connection with new line in HTML
- require HTML::WikiConverter 0.60
version: 0.50
date: Tue Jan 10 2006
changes:
- Branched from main HTML::WikiConverter codebase.
HTML-WikiConverter-PmWiki-0.51/lib/ 0040755 0004734 0023422 00000000000 10460004746 015725 5 ustar diberri hoc HTML-WikiConverter-PmWiki-0.51/lib/HTML/ 0040755 0004734 0023422 00000000000 10460004746 016471 5 ustar diberri hoc HTML-WikiConverter-PmWiki-0.51/lib/HTML/WikiConverter/ 0040755 0004734 0023422 00000000000 10460004746 021264 5 ustar diberri hoc HTML-WikiConverter-PmWiki-0.51/lib/HTML/WikiConverter/PmWiki.pm 0100644 0004734 0023422 00000014352 10415176061 023024 0 ustar diberri hoc package HTML::WikiConverter::PmWiki;
use warnings;
use strict;
use base 'HTML::WikiConverter';
our $VERSION = '0.51';
=head1 NAME
HTML::WikiConverter::PmWiki - Convert HTML to PmWiki markup
=head1 SYNOPSIS
use HTML::WikiConverter;
my $wc = new HTML::WikiConverter( dialect => 'PmWiki' );
print $wc->html2wiki( $html );
=head1 DESCRIPTION
This module contains rules for converting HTML into PmWiki markup. See
L for additional usage details.
=cut
sub rules {
my %rules = (
hr => { replace => "\n----\n" },
br => { replace => \&_br },
h1 => { start => '! ', block => 1, trim => 'both', line_format => 'single' },
h2 => { start => '!! ', block => 1, trim => 'both', line_format => 'single' },
h3 => { start => '!!! ', block => 1, trim => 'both', line_format => 'single' },
h4 => { start => '!!!! ', block => 1, trim => 'both', line_format => 'single' },
h5 => { start => '!!!!! ', block => 1, trim => 'both', line_format => 'single' },
h6 => { start => '!!!!!! ', block => 1, trim => 'both', line_format => 'single' },
blockquote => { start => \&_blockquote_start, trim => 'both', block => 1, line_format => 'multi' },
pre => { line_prefix => ' ', block => 1 },
p => { block => 1, trim => 'both', line_format => 'multi' },
b => { start => "'''", end => "'''", line_format => 'single' },
strong => { alias => 'b' },
i => { start => "''", end => "''", line_format => 'single' },
em => { alias => 'i' },
tt => { start => '@@', end => '@@', trim => 'both', line_format => 'single' },
code => { alias => 'tt' },
big => { start => "'+", end => "+'", line_format => 'single' },
small => { start => "'-", end => "-'", line_format => 'single' },
sup => { start => "'^", end => "^'", line_format => 'single' },
sub => { start => "'_", end => "_'", line_format => 'single' },
ins => { start => '{+', end => '+}', line_format => 'single' },
del => { start => '{-', end => '-}', line_format => 'single' },
ul => { line_format => 'multi', block => 1 },
ol => { alias => 'ul' },
li => { start => \&_li_start, trim => 'leading' },
dl => { alias => 'ul' },
dt => { start => \&_li_start, line_format => 'single', trim => 'both' },
dd => { start => ': ' },
a => { replace => \&_link },
img => { replace => \&_image },
table => { start => \&_table_start, block => 1 },
tr => { start => "\n||", line_format => 'single' },
td => { start => \&_td_start, end => \&_td_end, trim => 'both' },
th => { alias => 'td' }
);
return \%rules;
}
sub _br {
my( $self, $node, $rules ) = @_;
return " [[<<]] " if $node->look_up( _tag => 'table' );
return " \\\\\n";
}
sub _table_start {
my( $self, $node, $rules ) = @_;
my @attrs = qw/ border cellpadding cellspacing width bgcolor align /;
return '|| '.$self->get_attr_str( $node, @attrs );
}
sub _td_start {
my( $self, $node, $rules ) = @_;
my $prefix = $node->tag eq 'th' ? '!' : '';
my $align = $node->attr('align') || 'left';
$prefix .= ' ' if $align eq 'center' or $align eq 'right';
return $prefix;
}
sub _td_end {
my( $self, $node, $rules ) = @_;
my $colspan = $node->attr('colspan') || 1;
my $suffix = ( '||' ) x $colspan;
my $align = $node->attr('align') || 'left';
$suffix = ' '.$suffix if $align eq 'center' or $align eq 'left';
return $suffix;
}
sub _blockquote_start {
my( $self, $node, $rules ) = @_;
my @parent_bqs = $node->look_up( _tag => 'blockquote' );
my $depth = @parent_bqs;
my $start = ( '-' ) x $depth;
return "\n".$start.'>';
}
sub _li_start {
my( $self, $node, $rules ) = @_;
my @parent_lists = $node->look_up( _tag => qr/ul|ol|dl/ );
my $depth = @parent_lists;
my $bullet = '';
$bullet = '*' if $node->parent->tag eq 'ul';
$bullet = '#' if $node->parent->tag eq 'ol';
$bullet = ':' if $node->parent->tag eq 'dl';
my $prefix = ( $bullet ) x $depth;
return "\n".$prefix.' ';
}
sub _link {
my( $self, $node, $rules ) = @_;
return $self->_anchor($node, $rules) if $node->attr('name');
my $url = $node->attr('href') || '';
my $text = $self->get_elem_contents($node) || '';
return $url if $text eq $url;
return "[[$url | $text]]";
}
sub _anchor {
my( $self, $node, $rules ) = @_;
my $name = $node->attr('name') || '';
return "[[#$name]]";
}
sub _image {
my( $self, $node, $rules ) = @_;
return $node->attr('src') || '';
}
sub preprocess_node {
my( $self, $node ) = @_;
my $tag = $node->tag || '';
$self->_move_aname($node) if $tag eq 'a' and $node->attr('name');
$self->caption2para($node) if $tag eq 'caption';
if( $tag eq '~text' and $node->left and $node->left->tag and $node->left->tag eq 'br' and !$node->look_up(_tag => 'pre') ) {
( my $text = $node->attr('text') ) =~ s/^\s+//;
$node->attr( text => $text );
}
}
sub _move_aname {
my( $self, $node ) = @_;
my $name = $node->attr('name') || '';
$node->attr( name => undef );
my $aname = new HTML::Element( 'a', name => $name );
$node->preinsert($aname);
# Keep 'a href's around
$node->replace_with_content->delete unless $node->attr('href');
}
=head1 AUTHOR
David J. Iberri, C<< >>
=head1 BUGS
Please report any bugs or feature requests to
C, or through the web
interface at
L.
I will be notified, and then you'll automatically be notified of
progress on your bug as I make changes.
=head1 SUPPORT
You can find documentation for this module with the perldoc command.
perldoc HTML::WikiConverter::PmWiki
You can also look for information at:
=over 4
=item * AnnoCPAN: Annotated CPAN documentation
L
=item * CPAN Ratings
L
=item * RT: CPAN's request tracker
L
=item * Search CPAN
L
=back
=head1 COPYRIGHT & LICENSE
Copyright 2006 David J. Iberri, all rights reserved.
This program is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=cut
1;
HTML-WikiConverter-PmWiki-0.51/MANIFEST 0100644 0004734 0023422 00000000275 10361006625 016307 0 ustar diberri hoc Changes
MANIFEST
META.yml # Will be created by "make dist"
Makefile.PL
README
lib/HTML/WikiConverter/PmWiki.pm
t/00-load.t
t/boilerplate.t
t/pmwiki.t
t/pod-coverage.t
t/pod.t
t/runtests.pl
HTML-WikiConverter-PmWiki-0.51/Makefile.PL 0100644 0004734 0023422 00000001111 10460004645 017116 0 ustar diberri hoc use strict;
use warnings;
use ExtUtils::MakeMaker;
WriteMakefile(
NAME => 'HTML::WikiConverter::PmWiki',
AUTHOR => 'David J. Iberri ',
VERSION_FROM => 'lib/HTML/WikiConverter/PmWiki.pm',
ABSTRACT_FROM => 'lib/HTML/WikiConverter/PmWiki.pm',
PL_FILES => {},
PREREQ_PM => {
'Test::More' => 0,
'HTML::WikiConverter' => 0.60,
},
dist => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
clean => { FILES => 'HTML-WikiConverter-PmWiki-*' },
);
HTML-WikiConverter-PmWiki-0.51/README 0100644 0004734 0023422 00000003106 10460004615 016027 0 ustar diberri hoc HTML::WikiConverter::PmWiki
===========================
HTML::WikiConverter::PmWiki adds the PmWiki dialect to
HTML::WikiConverter allowing the conversion of HTML to PmWiki markup.
SYNOPSIS
Converting HTML to wiki markup is easy:
use HTML::WikiConverter;
my $wc = new HTML::WikiConverter( dialect => 'PmWiki' );
print $wc->html2wiki( $html );
Or from the command line:
% html2wiki --dialect PmWiki input.html > output.wiki
There's also a web interface if you're so inclined:
http://diberri.dyndns.org/html2wiki.html
CHANGES IN 0.51
* (bug 18562) Line breaks converted to "[[<<]]" within tables (thanks pcascon)
* (bug 18287) Fixed
tag problem in connection with new line in HTML
* Require HTML::WikiConverter 0.60
INSTALLATION
To install this module, run the following commands:
perl Makefile.PL
make
make test
make install
SUPPORT AND DOCUMENTATION
After installing, you can find documentation for this module with the
perldoc command.
perldoc HTML::WikiConverter::PmWiki
You can also look for information at:
Search CPAN
http://search.cpan.org/dist/HTML-WikiConverter-PmWiki
CPAN Request Tracker:
http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-WikiConverter-PmWiki
AnnoCPAN, annotated CPAN documentation:
http://annocpan.org/dist/HTML-WikiConverter-PmWiki
CPAN Ratings:
http://cpanratings.perl.org/d/HTML-WikiConverter-PmWiki
COPYRIGHT AND LICENCE
Copyright (C) 2006 David J. Iberri
This program is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.