X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=make_static.PL;h=758efc1f39349e85975563488c3ba2a9ecf90dd6;hb=d5bf9a1d1fc3583bc058a90ce28efeb34819744b;hp=0a10891e04c3264a835fc4a5d1c9cb95475c1cdd;hpb=cf2b01396b310e9c46c9acb1b835f4e222e2c9bf;p=plack-app-gruntmaster.git diff --git a/make_static.PL b/make_static.PL index 0a10891..758efc1 100644 --- a/make_static.PL +++ b/make_static.PL @@ -5,11 +5,18 @@ use warnings; use CSS::Minifier::XS qw//; use JavaScript::Minifier::XS qw//; -use File::Slurp qw/read_file write_file/; +use Digest::SHA qw/sha256_base64/; +use IO::Compress::Gzip qw/gzip/; +use File::Slurp qw/read_file write_file edit_file_lines/; mkdir 'static'; mkdir 'static/css'; +sub gzip_file { + my ($file) = @_; + gzip $file => "$file.gz", -Level => 9, Minimal => 1; +} + sub make_css { my $common_css; $common_css .= read_file $_ for ; @@ -18,6 +25,7 @@ sub make_css { my $css = read_file $_; $css .= $common_css; write_file "static/css/$theme.css", CSS::Minifier::XS::minify $css; + gzip_file "static/css/$theme.css"; } } @@ -32,6 +40,7 @@ sub make_js { $js .= read_file $_ for ; write_file 'static/js.js', JavaScript::Minifier::XS::minify $js; } + gzip_file 'static/js.js'; } my $css_mtime = -M 'static/css/slate.css' // 0; @@ -49,3 +58,10 @@ for () { last } } + +edit_file_lines { + my ($file) = m,(static.*\.(?:css|js)),; + return unless $file; + my $hash = sha256_base64 scalar read_file $file; + s/integrity=".*"/integrity="sha256-$hash="/; +} 'tmpl/skel.en'