X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=make_static.PL;h=4857bf0ccd37e2a367a75d1b037070df167023fa;hb=aefbc42eea7ef293b2fe6db72158e3494a742000;hp=5594f75d81b12b19132918f1f06e4ef05b84a90d;hpb=2ca77f50fce7c0cc299359a766058240255941f5;p=gruntmaster-page.git diff --git a/make_static.PL b/make_static.PL index 5594f75..4857bf0 100644 --- a/make_static.PL +++ b/make_static.PL @@ -6,42 +6,91 @@ use CSS::Minifier::XS qw//; use CSS::SpriteMaker; use JavaScript::Minifier::XS qw//; +use IO::Compress::Gzip qw/gzip/; use File::Slurp qw/read_file write_file/; mkdir 'static'; mkdir 'static/css'; -my $maker = Local::CSS::SpriteMaker->new( - css_class_prefix => 'logo-', - rc_override_classname => sub { - my ($name) = @_; - $name =~ s/-light/.logo-light/r; +sub make_sprite { + my $maker = Local::CSS::SpriteMaker->new( + css_class_prefix => 'logo-', + rc_override_classname => sub { + my ($name) = @_; + $name =~ s/-light/.logo-light/r; + } + ); + + $maker->make_sprite( + source_images => ['logos/'], + target_file => 'static/logos.png', + add_extra_padding => 10, + ); + + $maker->print_css( + filename => 'css/logos.css', + sprite_filename => '/static/logos.png', + ); + + system 'pngnq-s9', '-s1', 'static/logos.png'; + system 'optipng', '-o7', '-zm1-9', 'static/logos-nq8.png'; + rename 'static/logos-nq8.png', 'static/logos.png'; +} + +sub gzip_file { + my ($file) = @_; + gzip $file => "$file.gz", -Level => 9, Minimal => 1; +} + +sub make_css { + my $common_css; + $common_css .= read_file $_ for ; + for () { + my ($theme) = m,themes/(.*)\.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"; + } +} + +sub make_js { + if (-f 'compiler.jar') { + system java => -jar => 'compiler.jar', qw,-O SIMPLE --create_source_map static/js.map --js_output_file static/js.js --language_in ECMASCRIPT5_STRICT --source_map_location_mapping js/|/static/js/,, ; + my $js = read_file 'static/js.js'; + write_file 'static/js.js', '//# sourceMappingURL=/static/js.map', "\n", $js; + system 'cp', '-rp', 'js', 'static/'; + } else { + my $js; + $js .= read_file $_ for ; + write_file 'static/js.js', JavaScript::Minifier::XS::minify $js; } -); - -$maker->make_sprite( - source_images => ['logos/'], - target_file => 'static/logos.png', - add_extra_padding => 10, -); - -$maker->print_css( - filename => 'css/logos.css', - sprite_filename => 'https://static.mindcoding.ro/static/logos.png', -); - -my $common_css; -$common_css .= read_file $_ for ; -for () { - my ($theme) = m,themes/(.*)\.css,; - my $css = read_file $_; - $css .= $common_css; - write_file "static/css/$theme.css", CSS::Minifier::XS::minify $css; + gzip_file 'static/js.js'; } -my $js; -$js .= read_file $_ for ; -write_file 'static/js.js', JavaScript::Minifier::XS::minify $js; +my $sprite_mtime = -M 'static/logos.png' // 0; +for () { + if (!$sprite_mtime || $sprite_mtime > -M) { + make_sprite; + last + } +} + +my $css_mtime = -M 'static/css/slate.css' // 0; +for (, ) { + if (!$css_mtime || $css_mtime > -M) { + make_css; + last + } +} + +my $js_mtime = -M 'static/js.js' // 0; +for () { + if (!$js_mtime || $js_mtime > -M) { + make_js; + last + } +} package Local::CSS::SpriteMaker; @@ -55,7 +104,7 @@ sub _get_stylesheet_string { @ret = sort @ret; unshift @ret, <