3 # pod2grutatxt - Converts POD format to Grutatxt
4 # http://triptico.com/software/grutatxt.html
6 # Copyright (C) 2008 Angel Ortega <angel@triptico.com>
8 # This program is free software; you can redistribute it and/or modify
9 # it under the terms of the GNU General Public License as published by
10 # the Free Software Foundation; either version 2 of the License, or
11 # (at your option) any later version.
13 # This program is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 # GNU General Public License for more details.
18 # You should have received a copy of the GNU General Public License
19 # along with this program; if not, write to the Free Software
20 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 # http://www.triptico.com
26 package GrutatxtParser
;
27 use base
'Pod::Parser';
29 my $_deferred_title = 0;
38 return $title . "\n" . $s . "\n\n";
43 my ($parser, $command, $paragraph, $line_num) = @_;
45 my $out_fh = $parser->output_handle();
46 my $out = $parser->interpolate($paragraph, $line_num);
48 if ($command =~ /^head(\d)/) {
49 my $c = ('=', '-', '~', '~', '~')[$1];
50 my ($t) = ($out =~ /^([^\n]+)/s);
57 $out = _build_header
($t, $c);
60 elsif ($command eq 'item') {
63 elsif ($command eq 'over') {
66 elsif ($command eq 'for') {
67 my @w = split(/\s+/, $out);
70 $out = '<<' . $k . "\n" . join(' ', @w) . "\n>>\n";
72 elsif ($command eq 'begin') {
73 my @w = split(/\s+/, $out);
76 $out = '<<' . $k . "\n";
78 elsif ($command eq 'end') {
86 my ($parser, $paragraph, $line_num) = @_;
87 ## Format verbatim paragraph; sample actions might be:
88 my $out_fh = $parser->output_handle();
89 print $out_fh $paragraph;
93 my ($parser, $paragraph, $line_num) = @_;
94 ## Translate/Format this block of text; sample actions might be:
95 my $out_fh = $parser->output_handle();
96 my $expansion = $parser->interpolate($paragraph, $line_num);
98 if ($_deferred_title) {
99 my ($t) = ($expansion =~ /^([^\n]+)/s);
100 $expansion = _build_header
($t, '=');
101 $_deferred_title = 0;
104 print $out_fh $expansion;
107 sub interior_sequence
{
108 my ($parser, $seq_command, $seq_argument) = @_;
110 ## Expand an interior sequence; sample actions might be:
111 return "*$seq_argument*" if ($seq_command eq 'B');
112 return "`$seq_argument'" if ($seq_command =~ /^(C|F)$/);
113 return "_${seq_argument}_" if ($seq_command eq 'I');
114 return $seq_argument;
119 ## Create a parser object and have it parse file whose name was
120 ## given on the command-line (use STDIN if no files were given).
121 $parser = new GrutatxtParser
();
122 $parser->parse_from_filehandle(\
*STDIN
) if (@ARGV == 0);
123 for (@ARGV) { $parser->parse_from_file($_); }