strip html from anchors
[sysadmin-cookbook-html] / bin / html.pl
index 768fce4..0b0d8e2 100755 (executable)
@@ -8,6 +8,7 @@ my $recepies = 'recepies/';
 
 use File::Find;
 use File::Slurp;
+use File::Path;
 use Data::Dump qw/dump/;
 use XML::Simple;
 use Regexp::Common qw /URI/;
@@ -55,13 +56,18 @@ find({ follow => 0, no_chdir => 1, wanted => sub {
 my $last_level = 0;
 my $toc_html = '';
 sub header {
-       my ($level, $content) = @_;
-       my $display = $content;
+       my ($level, $name) = @_;
+
+       my $display = $name;
        $display =~ s{^\d+[\.-]}{};
        $display =~ s{-}{ }g;
        $display =~ s{\.\w+$}{};
-       $content =~ s{\W+}{_}g;
-       html qq|<a name=$content></a>|;
+
+       my $anchor = $name;
+       $anchor =~ s{</?[^>]+>}{}g;
+       $anchor =~ s{\W+}{_}g;
+
+       html qq|<a name=$anchor></a>|;
        html qq|<h$level>$display</h$level>|;
 
        if ( $last_level > $level ) {
@@ -69,13 +75,19 @@ sub header {
        } elsif ( $last_level < $level ) {
                $toc_html .= "<ul>";
        }
-       $toc_html .= qq|<li><a href="#$content">$display</li>|;
+       $toc_html .= qq|<li><a href="#$anchor">$display</li>|;
        $last_level = $level;
 }
 
 my $to_path = '';
 our @item;
 
+sub mkfilepath {
+       my $path = shift;
+       $path =~ s{/[^/]+$}{};
+       mkpath $path unless -d $path;
+}
+
 sub new_feed {
        my $name = shift;
        my $feed = XML::FeedPP::RSS->new();
@@ -95,7 +107,9 @@ sub add_item {
 
        my $item_feed = new_feed( $name );
        add_feed_item_description($item_feed, $name, "http://sysadmin-cookbook.rot13.org/#$name", $content);
-       $item_feed->to_file("rss/$name.xml");
+       my $file = "rss/$name.xml";
+       mkfilepath $file;
+       $item_feed->to_file($file);
 
        warn "# $name\n";
 }
@@ -113,12 +127,18 @@ foreach my $path ( sort @names ) {
        next if ( -d $path && ! -e "$path/.svn" );
 
        my $name = $path;
+#      $name =~ s{^$recepies.*?([^/]+)$}{$1} || next;
        $name =~ s{^$recepies.*?([^/]+)$}{$1} || next;
-       next unless $name;
+
+       my @just_path = split m{/}, $path;
+       @just_path = splice @just_path, 1, -1;
 
        if ( -d $path ) {
                add_item( splice(@item,0) );
-               header 1,$name;
+               my $h1 = join(' ',@just_path);
+               $h1 = qq|<span class="p">$h1</span> | if $h1;
+               $h1 .= $name;
+               header 1, $h1;
                $to_path = '';
                push @item, $name;
        } elsif ( -l $path ) {
@@ -152,6 +172,10 @@ h1 {
        padding: 0.3em;
 }
 
+h1 .p {
+       color: #888;
+}
+
 .toc {
        font-size: 80%;
 }