X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/909a8fb315ca7feceeb811d56e0b06934b3de6da..e75dbcba340459a1bef997680a7d1bf152039a32:/source.plp?ds=sidebyside diff --git a/source.plp b/source.plp index 7b0ebec..469f49e 100644 --- a/source.plp +++ b/source.plp @@ -84,17 +84,19 @@ else { my $parsed = $hl->marked; print "
\n"; foreach (@$parsed) { - my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || 'span'); + my ($type, $contents) = @{$_}; + $contents = Encode::decode_utf8($contents); + my $tag = $type && ($TYPETAG{$type} || 'span'); my $arg = ''; - print "<$tag$arg class=\"sy-\l$_->[0]\">" if $tag; - if (!$_->[0] || $_->[0] eq 'Constant' - and $_->[1] =~ s{^(['"]?)(/?[a-z0-9_.]+\.(?:plp?|css|js))(?=\1$)}{}) { + print "<$tag$arg class=\"sy-\l$type\">" if $tag; + if (!$type || $type eq 'Constant' + and $contents =~ s{^(['"]?)(/?[a-z0-9_.]+\.(?:plp?|css|js))(?=\1$)}{}) { printf '%s%s', $1, "/source/$2", $2; } - if (!$_->[0] and $_->[1] =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { + if (!$type and $contents =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { printf '%s%s', $1, "/source/$2", $2; } - print Text::VimColor::_xml_escape(Encode::decode_utf8($_->[1])); + print Text::VimColor::_xml_escape($contents); print "$tag>" if $tag; } print "\n";