From: Marius Gavrilescu Date: Wed, 22 Apr 2015 07:24:09 +0000 (+0300) Subject: Merge branch 'master' into newmc X-Git-Url: http://git.ieval.ro/?a=commitdiff_plain;h=6f5debb62f9d49098b660b626890a46dbbf7346f;hp=-c;p=gruntmaster-page.git Merge branch 'master' into newmc Conflicts: make_static.PL --- 6f5debb62f9d49098b660b626890a46dbbf7346f diff --combined Makefile.PL index b66d483,0d62f05..a1698a1 --- a/Makefile.PL +++ b/Makefile.PL @@@ -10,11 -10,10 +10,11 @@@ WriteMakefile LICENSE => 'AGPL_3', SIGN => 1, clean => { - FILES => 'static/css/ static/js/' + FILES => 'static/css/ static/js/ static/logos/' }, BUILD_REQUIRES => { qw/CSS::Minifier::XS 0 + SVG::SpriteMaker 0 File::Slurp 0 Test::MockTime 0 Test::More 0 @@@ -32,6 -31,7 +32,7 @@@ warnings 0 File::Slurp 0 + File::Which 0 Gruntmaster::Data 0 HTML::Element::Library 0 HTML::TreeBuilder 0 diff --combined make_static.PL index 24e56a8,9fd5bca..06c9eee --- a/make_static.PL +++ b/make_static.PL @@@ -6,17 -6,18 +6,20 @@@ use CSS::Minifier::XS qw/minify/ use Digest::SHA qw/sha256_base64/; use IO::Compress::Gzip qw/gzip/; use File::Slurp qw/read_file write_file edit_file_lines/; +use SVG::SpriteMaker; + use File::Which; use List::Util qw/first/; mkdir 'static'; mkdir 'static/css'; mkdir 'static/js'; +mkdir 'static/logos'; sub gzip_file { my ($file) = @_; - gzip $file => "$file.gz", -Level => 9, Minimal => 1; + my $zopfli = which 'zopfli'; + system $zopfli => $file if $zopfli; + gzip $file => "$file.gz", -Level => 9, Minimal => 1 unless $zopfli; } sub write_gzfile { @@@ -25,25 -26,6 +28,25 @@@ gzip_file $file } +sub sprite_name { + my ($name) = $_[0] =~ m,/(.*)\.svg,; + "logo-$name" +} + +sub make_logos { + my @logos = ; + my $logos = make_sprite \&sprite_name, @logos; + my @logos_light; + for () { + my $light = s/logos/logos-light/r; + push @logos_light, -f $light ? $light : $_; + } + my $logos_light = make_sprite \&sprite_name, @logos_light; + + write_gzfile 'static/logos/dark.svg', $logos->render; + write_gzfile 'static/logos/light.svg', $logos_light->render; +} + sub read_css_into_blocks { my ($file) = @_; my (@blocks, $block); @@@ -86,14 -68,6 +89,14 @@@ sub make_js system 'cp', '-rp', 'js', 'static/'; } +my $sprite_mtime = -M 'static/logos/dark.svg' // 0; +for (, ) { + if (!$sprite_mtime || $sprite_mtime > -M) { + make_logos; + last + } +} + my $css_mtime = -M 'static/css/slate.css' // 0; for (, ) { if (!$css_mtime || $css_mtime > -M) { @@@ -115,4 -89,4 +118,4 @@@ edit_file_lines return unless $file; my $hash = sha256_base64 scalar read_file $file; s/integrity=".*"/integrity="sha256-$hash="/; -} 'tmpl/skel.en' +} 'tmpl/skel.en';