r13101 - in /branches/upstream/libhtml-wikiconverter-moinmoin-perl: ./ current/ current/lib/ current/lib/HTML/ current/lib/HTML/WikiConverter/ current/t/

js at users.alioth.debian.org js at users.alioth.debian.org
Mon Jan 21 11:07:59 UTC 2008


Author: js
Date: Mon Jan 21 11:07:59 2008
New Revision: 13101

URL: http://svn.debian.org/wsvn/?sc=1&rev=13101
Log:
[svn-inject] Installing original source of libhtml-wikiconverter-moinmoin-perl

Added:
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Changes
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/MANIFEST
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/META.yml
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Makefile.PL
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/README
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/MoinMoin.pm
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/00-load.t
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/boilerplate.t
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/moinmoin.t
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod-coverage.t
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod.t
    branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/runtests.pl

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Changes
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Changes?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Changes (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Changes Mon Jan 21 11:07:59 2008
@@ -1,0 +1,23 @@
+# Change log for HTML::WikiConverter::MoinMoin
+
+version: 0.53
+date:    Thu Jul 20 19:00:00 EST 2006
+changes:
+  - add attribute types
+  - require Params::Validate
+  - require HTML::WikiConverter 0.60
+
+version: 0.52
+date:    Wed June 07 15:00:00 EST 2006
+changes:
+  - (bug #17813) implement anchors
+
+version: 0.51
+date:    Tue Mar 21 2006
+changes:
+  - (bug #18083) fix tests that used 'strip_comments' attribute, which no longer exists
+
+version: 0.50
+date:    Tue Jan 10 2006
+changes:
+  - branched from main HTML::WikiConverter codebase.

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/MANIFEST
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/MANIFEST?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/MANIFEST (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/MANIFEST Mon Jan 21 11:07:59 2008
@@ -1,0 +1,12 @@
+Changes
+MANIFEST
+META.yml # Will be created by "make dist"
+Makefile.PL
+README
+lib/HTML/WikiConverter/MoinMoin.pm
+t/00-load.t
+t/boilerplate.t
+t/moinmoin.t
+t/pod-coverage.t
+t/pod.t
+t/runtests.pl

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/META.yml
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/META.yml?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/META.yml (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/META.yml Mon Jan 21 11:07:59 2008
@@ -1,0 +1,14 @@
+# http://module-build.sourceforge.net/META-spec.html
+#XXXXXXX This is a prototype!!!  It will change in the future!!! XXXXX#
+name:         HTML-WikiConverter-MoinMoin
+version:      0.53
+version_from: lib/HTML/WikiConverter/MoinMoin.pm
+installdirs:  site
+requires:
+    HTML::WikiConverter:           0.5
+    Params::Validate:              0
+    Test::More:                    0
+    URI:                           0
+
+distribution_type: module
+generated_by: ExtUtils::MakeMaker version 6.17

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Makefile.PL
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Makefile.PL?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Makefile.PL (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/Makefile.PL Mon Jan 21 11:07:59 2008
@@ -1,0 +1,19 @@
+use strict;
+use warnings;
+use ExtUtils::MakeMaker;
+
+WriteMakefile(
+    NAME                => 'HTML::WikiConverter::MoinMoin',
+    AUTHOR              => 'David J. Iberri <diberri at cpan.org>',
+    VERSION_FROM        => 'lib/HTML/WikiConverter/MoinMoin.pm',
+    ABSTRACT_FROM       => 'lib/HTML/WikiConverter/MoinMoin.pm',
+    PL_FILES            => {},
+    PREREQ_PM => {
+        'Test::More' => 0,
+        'HTML::WikiConverter' => 0.50,
+        'Params::Validate' => 0,
+        'URI' => 0,
+    },
+    dist                => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
+    clean               => { FILES => 'HTML-WikiConverter-MoinMoin-*' },
+);

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/README
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/README?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/README (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/README Mon Jan 21 11:07:59 2008
@@ -1,0 +1,63 @@
+HTML::WikiConverter::MoinMoin
+=============================
+
+HTML::WikiConverter::MoinMoin adds the MoinMoin dialect to
+HTML::WikiConverter allowing the conversion of HTML to MoinMoin
+markup.
+
+SYNOPSIS
+
+Converting HTML to wiki markup is easy:
+
+  use HTML::WikiConverter;
+  my $wc = new HTML::WikiConverter( dialect => 'MoinMoin' );
+  print $wc->html2wiki( $html );
+
+Or from the command line:
+
+  % html2wiki --dialect MoinMoin input.html > output.wiki
+
+There's also a web interface if you're so inclined:
+
+  http://diberri.dyndns.org/wikipedia/html2wiki/
+
+CHANGES IN 0.53
+
+  * Update for 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::MoinMoin
+
+You can also look for information at:
+
+    Search CPAN
+        http://search.cpan.org/dist/HTML-WikiConverter-MoinMoin
+
+    CPAN Request Tracker:
+        http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-WikiConverter-MoinMoin
+
+    AnnoCPAN, annotated CPAN documentation:
+        http://annocpan.org/dist/HTML-WikiConverter-MoinMoin
+
+    CPAN Ratings:
+        http://cpanratings.perl.org/d/HTML-WikiConverter-MoinMoin
+
+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.

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/MoinMoin.pm
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/MoinMoin.pm?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/MoinMoin.pm (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/lib/HTML/WikiConverter/MoinMoin.pm Mon Jan 21 11:07:59 2008
@@ -1,0 +1,257 @@
+package HTML::WikiConverter::MoinMoin;
+
+use warnings;
+use strict;
+
+use base 'HTML::WikiConverter';
+our $VERSION = '0.53';
+
+use Params::Validate ':types';
+use URI;
+
+=head1 NAME
+
+HTML::WikiConverter::MoinMoin - Convert HTML to MoinMoin markup
+
+=head1 SYNOPSIS
+
+  use HTML::WikiConverter;
+  my $wc = new HTML::WikiConverter( dialect => 'MoinMoin' );
+  print $wc->html2wiki( $html );
+
+=head1 DESCRIPTION
+
+This module contains rules for converting HTML into MoinMoin
+markup. See L<HTML::WikiConverter> for additional usage details.
+
+=cut
+
+sub rules {
+  my %rules = (
+    p   => { block => 1, trim => 'both', line_format => 'multi' },
+    pre => { block => 1, start => "{{{\n", end => "\n}}}" },
+
+    i      => { start => "''", end => "''", line_format => 'single' },
+    em     => { alias => 'i' },
+    b      => { start => "'''", end => "'''", line_format => 'single' },
+    strong => { alias => 'b' },
+    u      => { start => '__', end => '__', line_format => 'single' },
+
+    sup   => { start => '^', end => '^', line_format => 'single' },
+    sub   => { start => ',,', end => ',,', line_format => 'single' },
+    code  => { start => '`', end => '`', line_format => 'single' },
+    tt    => { alias => 'code' },
+    small => { start => '~-', end => '-~', line_format => 'single' },
+    big   => { start => '~+', end => '+~', line_format => 'single' },
+
+    a => { replace => \&_link },
+    img => { replace => \&_image },
+
+    ul => { line_format => 'multi', block => 1, line_prefix => '  ' },
+    ol => { alias => 'ul' },
+
+    li => { start => \&_li_start, trim => 'leading' },
+
+    dl => { line_format => 'multi' },
+    dt => { trim => 'both', end => ':: ' },
+    dd => { trim => 'both' },
+
+    hr => { replace => "\n----\n" },
+    br => { replace => '[[BR]]' },
+
+    table => { block => 1, line_format => 'multi' },
+    tr => { end => "||\n", line_format => 'single' },
+    td => { start => \&_td_start, end => ' ', trim => 'both' },
+    th => { alias => 'td' },
+  );
+
+  # Headings (h1-h6)
+  my @headings = ( 1..6 );
+  foreach my $level ( @headings ) {
+    my $tag = "h$level";
+    my $affix = ( '=' ) x ($level+1);
+    $affix = '======' if $level == 6;
+    $rules{$tag} = { start => $affix.' ', end => ' '.$affix, block => 1, trim => 'both', line_format => 'single' };
+  }
+
+  return \%rules;
+}
+
+=head1 ATTRIBUTES
+
+In addition to the regular set of attributes recognized by the
+L<HTML::WikiConverter> constructor, this dialect also accepts the
+following attributes that can be passed into the C<new()>
+constructor. See L<HTML::WikiConverter/ATTRIBUTES> for usage details.
+
+=head2 enable_anchor_macro
+
+Possible values: C<0>, C<1>. Enables C<[[Anchor(s)]]> formatting. See
+L<http://moinmoin.wikiwikiweb.de/HelpOnMacros> for details.
+
+=cut
+
+sub attributes { {
+  enable_anchor_macro => { default => 0, type => BOOLEAN }
+} }
+
+my %att2prop = (
+  width => 'width',
+  bgcolor => 'background-color',
+);
+
+sub _td_start {
+  my( $self, $td, $rules ) = @_;
+
+  my $prefix = '||';
+
+  my @style = ( );
+
+  push @style, '|'.$td->attr('rowspan') if $td->attr('rowspan');
+  push @style, '-'.$td->attr('colspan') if $td->attr('colspan');
+
+  # If we're the first td in the table, then include table settings
+  if( ! $td->parent->left && ! $td->left ) {
+    my $table = $td->look_up( _tag => 'table' );
+    my $attstr = _attrs2style( $table, qw/ width bgcolor / );
+    push @style, "tablestyle=\"$attstr\"" if $attstr;
+  }
+
+  # If we're the first td in this tr, then include tr settings
+  if( ! $td->left ) {
+    my $attstr = $td->parent->attr('style');
+    push @style, "rowstyle=\"$attstr\"" if $attstr;
+  }
+
+  # Include td settings
+  my $attstr = join ' ', map { "$_=\"".$td->attr($_)."\"" } grep $td->attr($_), qw/ id class style /;
+  push @style, $attstr if $attstr;
+
+  my $opts = @style ? '<'.join(' ', at style).'>' : '';
+
+  return $prefix.$opts.' ';
+}
+
+sub _attrs2style {
+  my( $node, @attrs ) = @_;
+  return unless $node;
+  my %attrs = map { $_ => $node->attr($_) } grep $node->attr($_), @attrs;
+  my $attstr = join '; ', map "$att2prop{$_}:$attrs{$_}", keys %attrs;
+  return $attstr || '';
+}
+
+sub _li_start {
+  my( $self, $node, $rules ) = @_;
+  my $bullet = '';
+  $bullet = '*'  if $node->parent->tag eq 'ul';
+  $bullet = '1.' if $node->parent->tag eq 'ol';
+  return "\n$bullet ";
+}
+
+sub _link {
+  my( $self, $node, $rules ) = @_;
+
+  # (bug #17813)
+  my $name = $node->attr('name');
+  return sprintf '[[Anchor(%s)]]', $name if $self->enable_anchor_macro and $name;
+
+  my $url = $node->attr('href') || '';
+  my $text = $self->get_elem_contents($node) || '';
+
+  # (bug #17813)
+  if( $self->_abs2rel($url) =~ /^#/ ) {
+    $url = $self->_abs2rel($url);
+  }
+
+  return $url if $url eq $text;
+  return "[$url $text]";
+}
+
+sub _abs2rel {
+  my( $self, $uri ) = @_;
+  return $uri unless $self->base_uri;
+  return URI->new($uri)->rel($self->base_uri)->as_string;
+}
+
+sub _image {
+  my( $self, $node, $rules ) = @_;
+  return $node->attr('src') || '';
+}
+
+sub preprocess_node {
+  my( $self, $node ) = @_;
+  $self->strip_aname($node) if $node->tag eq 'a';
+  $self->caption2para($node) if $node->tag eq 'caption';
+
+  # (bug #17813)
+  if( $node->tag eq 'a' and $node->attr('name') ) {
+    my $name = $node->attr('name');
+    $node->preinsert( new HTML::Element('a', name => $name) );
+    $node->attr( name => undef );
+  }
+}
+
+my @protocols = qw( http https mailto );
+my $urls  = '(' . join('|', @protocols) . ')';
+my $ltrs  = '\w';
+my $gunk  = '\/\#\~\:\.\?\+\=\&\%\@\!\-';
+my $punc  = '\.\:\?\-\{\(\)\}';
+my $any   = "${ltrs}${gunk}${punc}";
+my $url_re = "\\b($urls:\[$any\]+?)(?=\[$punc\]*\[^$any\])";
+
+sub postprocess_output {
+  my( $self, $outref ) = @_;
+  $$outref =~ s/($url_re)\[\[BR\]\]/$1 [[BR]]/go;
+}
+
+=head1 AUTHOR
+
+David J. Iberri, C<< <diberri at cpan.org> >>
+
+=head1 BUGS
+
+Please report any bugs or feature requests to
+C<bug-html-wikiconverter-moinmoin at rt.cpan.org>, or through the web
+interface at
+L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=HTML-WikiConverter-MoinMoin>.
+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::MoinMoin
+
+You can also look for information at:
+
+=over 4
+
+=item * AnnoCPAN: Annotated CPAN documentation
+
+L<http://annocpan.org/dist/HTML-WikiConverter-MoinMoin>
+
+=item * CPAN Ratings
+
+L<http://cpanratings.perl.org/d/HTML-WikiConverter-MoinMoin>
+
+=item * RT: CPAN's request tracker
+
+L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-WikiConverter-MoinMoin>
+
+=item * Search CPAN
+
+L<http://search.cpan.org/dist/HTML-WikiConverter-MoinMoin>
+
+=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;

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/00-load.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/00-load.t?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/00-load.t (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/00-load.t Mon Jan 21 11:07:59 2008
@@ -1,0 +1,9 @@
+#!perl -T
+
+use Test::More tests => 1;
+
+BEGIN {
+	use_ok( 'HTML::WikiConverter::MoinMoin' );
+}
+
+diag( "Testing HTML::WikiConverter::MoinMoin $HTML::WikiConverter::MoinMoin::VERSION, Perl $], $^X" );

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/boilerplate.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/boilerplate.t?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/boilerplate.t (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/boilerplate.t Mon Jan 21 11:07:59 2008
@@ -1,0 +1,48 @@
+#!perl -T
+
+use strict;
+use warnings;
+use Test::More tests => 3;
+
+sub not_in_file_ok {
+    my ($filename, %regex) = @_;
+    open my $fh, "<", $filename
+        or die "couldn't open $filename for reading: $!";
+
+    my %violated;
+
+    while (my $line = <$fh>) {
+        while (my ($desc, $regex) = each %regex) {
+            if ($line =~ $regex) {
+                push @{$violated{$desc}||=[]}, $.;
+            }
+        }
+    }
+
+    if (%violated) {
+        fail("$filename contains boilerplate text");
+        diag "$_ appears on lines @{$violated{$_}}" for keys %violated;
+    } else {
+        pass("$filename contains no boilerplate text");
+    }
+}
+
+not_in_file_ok(README =>
+    "The README is used..."       => qr/The README is used/,
+    "'version information here'"  => qr/to provide version information/,
+);
+
+not_in_file_ok(Changes =>
+    "placeholder date/time"       => qr(Date/time)
+);
+
+sub module_boilerplate_ok {
+    my ($module) = @_;
+    not_in_file_ok($module =>
+        'the great new $MODULENAME'   => qr/ - The great new /,
+        'boilerplate description'     => qr/Quick summary of what the module/,
+        'stub function definition'    => qr/function[12]/,
+    );
+}
+
+module_boilerplate_ok('lib/HTML/WikiConverter/MoinMoin.pm');

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/moinmoin.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/moinmoin.t?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/moinmoin.t (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/moinmoin.t Mon Jan 21 11:07:59 2008
@@ -1,0 +1,246 @@
+local $/;
+require 't/runtests.pl';
+runtests( data => <DATA>, dialect => 'MoinMoin' );
+close DATA;
+
+__DATA__
+add space between [[BR]] and URL
+__H__
+<html><a href="http://example.com">http://example.com</a><br /></html>
+__W__
+http://example.com [[BR]]
+__NEXT__
+wrap in html
+__H__
+<a href="http://google.com">GOOGLE</a><br/>
+NewLine
+__W__
+[http://google.com GOOGLE][[BR]] NewLine
+__NEXT__
+bold
+__H__
+<html><b>bold</b></html>
+__W__
+'''bold'''
+__NEXT__
+italics
+__H__
+<html><i>italics</i></html>
+__W__
+''italics''
+__NEXT__
+bold and italics
+__H__
+<html><b>bold</b> and <i>italics</i></html>
+__W__
+'''bold''' and ''italics''
+__NEXT__
+bold-italics nested
+__H__
+<html><i><b>bold-italics</b> nested</i></html>
+__W__
+'''''bold-italics''' nested''
+__NEXT__
+strong
+__H__
+<html><strong>strong</strong></html>
+__W__
+'''strong'''
+__NEXT__
+emphasized
+__H__
+<html><em>emphasized</em></html>
+__W__
+''emphasized''
+__NEXT__
+underlined
+__H__
+<html><u>text</u></html>
+__W__
+__text__
+__NEXT__
+one-line phrasals
+__H__
+<html><i>phrasals
+in one line</i></html>
+__W__
+''phrasals in one line''
+__NEXT__
+sup
+__H__
+<html>x<sup>2</sup></html>
+__W__
+x^2^
+__NEXT__
+sub
+__H__
+<html>H<sub>2</sub>O</html>
+__W__
+H,,2,,O
+__NEXT__
+code
+__H__
+<html><code>$name = 'stan';</code></html>
+__W__
+`$name = 'stan';`
+__NEXT__
+tt
+__H__
+<html><tt>tt text</tt></html>
+__W__
+`tt text`
+__NEXT__
+small
+__H__
+<html>some <small>small</small> text</html>
+__W__
+some ~-small-~ text
+__NEXT__
+big
+__H__
+<html>some <big>big</big> text</html>
+__W__
+some ~+big+~ text
+__NEXT__
+paragraph blocking
+__H__
+<html><p>p1</p><p>p2</p></html>
+__W__
+p1
+
+p2
+__NEXT__
+lists
+__H__
+<html><ul><li>1</li><li>2</li></ul></html>
+__W__
+  * 1
+  * 2
+__NEXT__
+nested lists
+__H__
+<html><ul><li>1<ul><li>1a</li><li>1b</li></ul></li><li>2</li></ul>
+__W__
+  * 1
+    * 1a
+    * 1b
+  * 2
+__NEXT__
+nested lists (different types)
+__H__
+<html><ul><li>1<ul><li>a<ol><li>i</li></ol></li><li>b</li></ul></li><li>2</li></ul></html>
+__W__
+  * 1
+    * a
+      1. i
+    * b
+  * 2
+__NEXT__
+hr
+__H__
+<html><hr /></html>
+__W__
+----
+__NEXT__
+pre
+__H__
+<html><pre>this
+  is
+    preformatted
+      text</pre></html>
+__W__
+{{{
+this
+  is
+    preformatted
+      text
+}}}
+__NEXT__
+h1
+__H__
+<h1>h1</h1>
+__W__
+== h1 ==
+__NEXT__
+h2
+__H__
+<h2>h2</h2>
+__W__
+=== h2 ===
+__NEXT__
+h3
+__H__
+<h3>h3</h3>
+__W__
+==== h3 ====
+__NEXT__
+h4
+__H__
+<h4>h4</h4>
+__W__
+===== h4 =====
+__NEXT__
+h5
+__H__
+<h5>h5</h5>
+__W__
+====== h5 ======
+__NEXT__
+h6
+__H__
+<h6>h6</h6>
+__W__
+====== h6 ======
+__NEXT__
+img
+__H__
+<html><img src="thing.gif" /></html>
+__W__
+http://www.test.com/thing.gif
+__NEXT__
+external links
+__H__
+<html><a href="test.html">thing</a></html>
+__W__
+[http://www.test.com/test.html thing]
+__NEXT__
+external link (plain)
+__H__
+<html><a href="http://www.test.com">http://www.test.com</a></html>
+__W__
+http://www.test.com
+__NEXT__
+definition list
+__H__
+<html><dl><dt>cookies</dt><dd>delicious delicacies</dd></dl></html>
+__W__
+cookies:: delicious delicacies
+__NEXT__
+simple table
+__H__
+<html><table><tr><td>name</td><td>david</td></tr></table>
+__W__
+|| name || david ||
+__NEXT__
+table w/ attrs
+__H__
+<html>
+  <table bgcolor="white" width="100%">
+    <tr>
+      <td colspan=2 id="thing">thing</td>
+    </tr>
+    <tr>
+      <td>next</td>
+      <td id="crazy">crazy</td>
+    </tr>
+  </table>
+</html>
+__W__
+||<-2 tablestyle="width:100%; background-color:white" id="thing"> thing ||
+|| next ||<id="crazy"> crazy ||
+__NEXT__
+anchors (bug #17813) ::enable_anchor_macro(1)
+__H__
+<p><a name="here" href="#here">here</a></p>
+__W__
+[[Anchor(here)]][#here here]

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod-coverage.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod-coverage.t?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod-coverage.t (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod-coverage.t Mon Jan 21 11:07:59 2008
@@ -1,0 +1,25 @@
+#!perl -T
+
+use Test::More;
+eval "use Test::Pod::Coverage 1.04";
+plan skip_all => "Test::Pod::Coverage 1.04 required for testing POD coverage" if $@;
+all_pod_coverage_ok( { also_private => [
+  # These methods are documented in HTML::WikiConverter::Dialects
+  qr/
+     get_elem_contents
+    |get_wiki_page
+    |get_attr_str
+    |is_camel_case
+    |rule
+    |rules
+    |attribute
+    |attributes
+    |preprocess_tree
+    |preprocess_node
+    |postprocess_output
+    |caption2para
+    |strip_aname
+    |base_url
+    |wiki_url
+  /x
+] } );

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod.t?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod.t (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/pod.t Mon Jan 21 11:07:59 2008
@@ -1,0 +1,6 @@
+#!perl -T
+
+use Test::More;
+eval "use Test::Pod 1.14";
+plan skip_all => "Test::Pod 1.14 required for testing POD" if $@;
+all_pod_files_ok();

Added: branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/runtests.pl
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/runtests.pl?rev=13101&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/runtests.pl (added)
+++ branches/upstream/libhtml-wikiconverter-moinmoin-perl/current/t/runtests.pl Mon Jan 21 11:07:59 2008
@@ -1,0 +1,132 @@
+#!/usr/bin/perl
+use warnings;
+use strict;
+
+use Test::More;
+use File::Spec;
+use HTML::Entities;
+use HTML::WikiConverter;
+*e = \&encode_entities;
+
+my $more_tests = <<END_TESTS;
+__NEXT__
+entities (1)
+__H__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__W__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__NEXT__
+entities (2)
+__H__
+To enter a '<' in your input, use "&amp;lt;"
+__W__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__NEXT__
+strip comments
+__H__
+A <!-- stripped --> comment
+__W__
+A  comment
+__NEXT__
+strip head
+__H__
+<html>
+<head><title>fun stuff</title></head>
+<body>
+<p>Crazy stuff here</p>
+</body>
+</html>
+__W__
+Crazy stuff here
+__NEXT__
+strip scripts
+__H__
+<html>
+<head><script>bogus stuff</script></head>
+<body>
+<script>maliciousCode()</script>
+<p>benevolent text</p>
+</body>
+</html>
+__W__
+benevolent text
+END_TESTS
+
+sub runtests {
+  my %arg = @_;
+
+  $arg{wrap_in_html} = 1;
+  $arg{base_uri} ||= 'http://www.test.com';
+  my $minimal = $arg{minimal} || 0;
+
+  my $data = $arg{data} || '';
+  $data .= entity_tests() . $more_tests unless $minimal;
+
+  my @tests = split /__NEXT__\n/, $data;
+  my $numtests = @tests;
+  #$numtests += 1 unless $minimal; # file test
+  plan tests => $numtests;
+
+  # Delete unrecognized HTML::WikiConverter options
+  delete $arg{$_} for qw/ data minimal /;
+
+  my $wc = new HTML::WikiConverter(%arg);
+  foreach my $test ( @tests ) {
+    $test =~ s/^(.*?)\n//; my $name = $1;
+    my( $html, $wiki ) = split /__W__\n/, $test;
+    $html =~ s/__H__\n//;
+
+    $name =~ s{\s*\:\:(\w+\([^\)]*?\))}{
+      my $method_call = $1;
+      eval "\$wc->$method_call;";
+      die "Failed test call ($name): $@" if $@;
+      '';
+    }ge;
+
+    for( $html, $wiki ) { s/^\n+//; s/\n+$// }
+    is( $wc->html2wiki($html), $wiki, $name );
+  }
+
+  #file_test($wc) unless $minimal;
+}
+
+sub entity_tests {
+  my $tmpl = "__NEXT__\n%s\n__H__\n%s\n__W__\n%s\n"; # test-name, html-input, expected-wiki-output
+
+  my $data = '';
+  my @chars = ( '<', '>', '&' );
+  foreach my $char ( @chars ) {
+    ( my $charname = e($char) ) =~ s/[&;]//g;
+    $data .= sprintf $tmpl, "literal ($charname)", $char, e($char)
+          .  sprintf $tmpl, "encode ($charname)", e($char), e($char)
+          .  sprintf $tmpl, "meta ($charname)", e(e($char)), e(e($char));
+  }
+
+  return $data;
+}
+
+sub _slurp {
+  my $path = shift;
+  open H, $path or die "couldn't open $path: $!";
+  local $/;
+  my $c = <H>;
+  close H;
+  return $c;
+}
+
+sub file_test {
+  my $wc = shift;
+  my $lc_dialect = lc $wc->dialect;
+  my $infile = File::Spec->catfile( 't', 'complete.html' );
+  my $outfile = File::Spec->catfile( 't', "complete.$lc_dialect" );
+
+  SKIP: {
+    skip "Couldn't find $infile (ignore this)", 1 unless -e $infile;
+    skip "Couldn't find $outfile (ignore this)", 1 unless -e $outfile;
+    my( $got, $expect ) = ( $wc->html2wiki( file => $infile, slurp => 1 ), _slurp($outfile) );
+    for( $got, $expect ) { s/^\n+//; s/\n+$// }
+    is( $got, $expect, 'read from file' );
+  };
+}
+
+1;




More information about the Pkg-perl-cvs-commits mailing list