]> iEval git - gruntmaster-page.git/blobdiff - make_static.PL
Merge branch 'master' into newmc
[gruntmaster-page.git] / make_static.PL
index 5594f75d81b12b19132918f1f06e4ef05b84a90d..44f56fa6012f89f1d0093eb3ab101e0781b5613e 100644 (file)
@@ -4,44 +4,95 @@ use warnings;
 
 use CSS::Minifier::XS qw//;
 use CSS::SpriteMaker;
-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';
+mkdir 'static/js';
 
-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 <css/*.css>;
+       for (<css/themes/*>) {
+               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 {
+       system java => -jar => 'compiler.jar', qw,-O SIMPLE --create_source_map static/js/js.map --js_output_file static/js/all.js --language_in ECMASCRIPT6_STRICT --language_out ECMASCRIPT5_STRICT --source_map_location_mapping js/|/static/js/,, <js/*>;
+       my $js = read_file 'static/js/all.js';
+       write_file 'static/js/all.js', '//# sourceMappingURL=/static/js/js.map', "\n", $js;
+       system 'cp', '-rp', 'js', 'static/';
+       gzip_file 'static/js/all.js';
+}
+
+my $sprite_mtime = -M 'static/logos.png' // 0;
+for (<logos/*>) {
+       if (!$sprite_mtime || $sprite_mtime > -M) {
+               make_sprite;
+               last
+       }
+}
+
+my $css_mtime = -M 'static/css/slate.css' // 0;
+for (<css/*>, <css/themes/*>) {
+       if (!$css_mtime || $css_mtime > -M) {
+               make_css;
+               last
+       }
+}
+
+my $js_mtime = -M 'static/js.js' // 0;
+for (<js/*>) {
+       if (!$js_mtime || $js_mtime > -M) {
+               make_js;
+               last
        }
-);
-
-$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 <css/*.css>;
-for (<css/themes/*>) {
-       my ($theme) = m,themes/(.*)\.css,;
-       my $css = read_file $_;
-       $css .= $common_css;
-       write_file "static/css/$theme.css", CSS::Minifier::XS::minify $css;
 }
 
-my $js;
-$js .= read_file $_ for <js/*.js>;
-write_file 'static/js.js', JavaScript::Minifier::XS::minify $js;
+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';
 
 package
   Local::CSS::SpriteMaker;
@@ -55,7 +106,7 @@ sub _get_stylesheet_string {
        @ret = sort @ret;
        unshift @ret, <<EOF;
 a.logo {
-       background-image: url("https://static.mindcoding.ro/static/logos.png");
+       background-image: url("/static/logos.png");
        background-repeat: no-repeat;
        display: inline-block;
        vertical-align: middle;
This page took 0.027265 seconds and 4 git commands to generate.