diff options
author | ivan <ivan> | 2004-06-18 10:28:11 +0000 |
---|---|---|
committer | ivan <ivan> | 2004-06-18 10:28:11 +0000 |
commit | 4dbd0e09bd8fe1958eb294ebd425878c420afe6a (patch) | |
tree | 911f6ae9a5e2d085110410a35dcffd2bf1f30724 /bin/masonize | |
parent | 5d154e4e153a66c2349ee0c6ca942fa017bfb139 (diff) |
masonize fix: avoid newline prepend fix from borking indented first <%, fixes customer search by otaker under mason, closes: Bug#830
Diffstat (limited to 'bin/masonize')
-rwxr-xr-x | bin/masonize | 28 |
1 files changed, 18 insertions, 10 deletions
diff --git a/bin/masonize b/bin/masonize index 3139e0af5..169ba718f 100755 --- a/bin/masonize +++ b/bin/masonize @@ -6,34 +6,38 @@ foreach $file ( split(/\n/, `find . -depth -print`) ) { @file = <F>; #print "$file ". scalar(@file). "\n"; close $file; - system("chmod u+w $file"); - open(W,">$file") or die "can't open $file for writing: $!"; - select W; $| = 1; select STDOUT; $newline = ''; #avoid prepending extraneous newlines $all = join('',@file); + $w = ''; + $mode = 'html'; while ( length($all) ) { if ( $mode eq 'html' ) { if ( $all =~ /^(.+?)(<%=?.*)$/s && $1 !~ /<%/s ) { - print W $1; + $w .= $1; $all = $2; next; } elsif ( $all =~ /^<%=(.*)$/s ) { - print W '<%'; + $w .= '<%'; $all = $1; $mode = 'perlv'; #die; next; } elsif ( $all =~ /^<%(.*)$/s ) { - print W $newline; $newline = "\n"; + $w .= $newline; $newline = "\n"; $all = $1; $mode = 'perlc'; + + #avoid newline prepend fix from borking indented first <% + $w =~ s/\n\s+\z/\n/; + $w .= "\n" if $w =~ /.+\z/; + next; } elsif ( $all !~ /<%/s ) { - print W $all; + $w .= $all; last; } else { warn length($all); die; @@ -43,7 +47,7 @@ foreach $file ( split(/\n/, `find . -depth -print`) ) { } elsif ( $mode eq 'perlv' ) { if ( $all =~ /^(.*?%>)(.*)$/s ) { - print W $1; + $w .= $1; $all=$2; $mode = 'html'; next; @@ -53,13 +57,13 @@ foreach $file ( split(/\n/, `find . -depth -print`) ) { } elsif ( $mode eq 'perlc' ) { if ( $all =~ /^([^\n]*?)%>(.*)$/s ) { - print W "%$1\n"; + $w .= "%$1\n"; $all=$2; $mode='html'; next; } if ( $all =~ /^([^\n]*)\n(.*)$/s ) { - print W "%$1\n"; + $w .= "%$1\n"; $all=$2; next; } @@ -68,5 +72,9 @@ foreach $file ( split(/\n/, `find . -depth -print`) ) { } + system("chmod u+w $file"); + select W; $| = 1; select STDOUT; + open(W,">$file") or die "can't open $file for writing: $!"; + print W $w; close W; } |