Files
polymer/gulpfile.js

251 lines
7.1 KiB
JavaScript
Raw Normal View History

2016-02-16 11:43:39 -08:00
/**
* @license
2017-03-03 16:54:36 -08:00
* Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
2016-02-16 11:43:39 -08:00
* This code may only be used under the BSD style license found at http:polymer.github.io/LICENSE.txt
* The complete set of authors may be found at http:polymer.github.io/AUTHORS.txt
* The complete set of contributors may be found at http:polymer.github.io/CONTRIBUTORS.txt
* Code distributed by Google as part of the polymer project is also
* subject to an additional IP rights grant found at http:polymer.github.io/PATENTS.txt
*/
2017-01-10 15:02:48 -08:00
/* eslint-env node */
2016-02-16 11:43:39 -08:00
'use strict';
const gulp = require('gulp');
const gulpif = require('gulp-if');
const runseq = require('run-sequence');
const del = require('del');
const eslint = require('gulp-eslint');
const fs = require('fs');
const path = require('path');
2017-01-18 14:24:27 -08:00
const mergeStream = require('merge-stream');
const babel = require('gulp-babel');
const size = require('gulp-size');
const lazypipe = require('lazypipe');
const closure = require('google-closure-compiler').gulp();
const minimalDocument = require('./util/minimalDocument.js')
const DIST_DIR = 'dist';
const BUNDLED_DIR = path.join(DIST_DIR, 'bundled');
2017-01-18 14:24:27 -08:00
const COMPILED_DIR = path.join(DIST_DIR, 'compiled');
const POLYMER_LEGACY = 'polymer.html';
const POLYMER_ELEMENT = 'polymer-element.html';
const polymer = require('polymer-build');
const PolymerProject = polymer.PolymerProject;
2017-01-09 15:56:20 -08:00
const {Transform} = require('stream');
2017-01-10 15:02:48 -08:00
class OldNameStream extends Transform {
constructor(fileList) {
2017-01-09 15:56:20 -08:00
super({objectMode: true});
this.fileList = fileList;
2017-01-09 15:56:20 -08:00
}
_transform(file, enc, cb) {
if (this.fileList) {
const origFile = this.fileList.shift();
// console.log(`rename ${file.path} -> ${origFile.path}`)
file.path = origFile.path;
}
2017-01-10 15:02:48 -08:00
cb(null, file);
}
_flush(cb) {
if (this.fileList && this.fileList.length > 0) {
2017-01-10 15:02:48 -08:00
this.fileList.forEach((oldFile) => {
// console.log(`pumping fake file ${oldFile.path}`)
let newFile = oldFile.clone({deep: true, contents: false});
newFile.contents = new Buffer('');
this.push(newFile);
});
2017-01-09 15:56:20 -08:00
}
2017-01-10 15:02:48 -08:00
cb();
2017-01-09 15:56:20 -08:00
}
}
2017-03-29 15:52:01 -07:00
class Log extends Transform {
constructor(prefix = '') {
super({objectMode: true});
this.prefix = prefix;
}
_transform(file, enc, cb) {
console.log(this.prefix, file.path);
cb(null, file);
}
}
class Uniq extends Transform {
constructor() {
super({ objectMode: true });
this.map = {};
}
_transform(file, enc, cb) {
this.map[file.path] = file;
cb();
}
_flush(done) {
for (let filePath in this.map) {
let file = this.map[filePath];
this.push(file);
}
done();
}
}
let CLOSURE_LINT_ONLY = false;
let EXPECTED_WARNING_COUNT = 498;
gulp.task('clean', () => del(DIST_DIR));
2017-04-26 14:59:34 -07:00
gulp.task('closure', ['clean', 'generate-closure-externs'], () => {
2017-01-18 14:24:27 -08:00
2017-03-29 15:52:01 -07:00
let entry, splitRx, joinRx;
function full() {
entry = 'polymer.html';
splitRx = /polymer\.html_script_\d+\.js$/;
joinRx = /polymer\.html/;
}
function element() {
entry = 'polymer-element.html';
splitRx = /polymer-element\.html_script_\d+\.js$/;
joinRx = /polymer-element\.html/;
}
// element();
full();
2017-03-29 15:52:01 -07:00
2017-01-18 14:24:27 -08:00
const project = new PolymerProject({
shell: `./${entry}`,
fragments: [
'bower_components/shadycss/apply-shim.html',
'bower_components/shadycss/custom-style-interface.html'
]
2017-01-18 14:24:27 -08:00
});
2017-01-09 15:56:20 -08:00
function closureLintLogger(log) {
let chalk = require('chalk');
let result = log.split(/\n/).slice(-2)[0];
let warnings = result.match(/(\d+) warning/);
// write out log to use with diffing tools later
fs.writeFileSync('closure.log', chalk.stripColor(log));
if (warnings && Number(warnings[1]) > EXPECTED_WARNING_COUNT) {
console.error(chalk.red(`closure linting: actual warning count ${warnings[1]} greater than expected warning count ${EXPECTED_WARNING_COUNT}`));
process.exit(1);
}
}
let closurePluginOptions;
if (CLOSURE_LINT_ONLY) {
closurePluginOptions = {
logger: closureLintLogger
}
}
2017-01-09 15:56:20 -08:00
const closureStream = closure({
compilation_level: 'ADVANCED',
language_in: 'ES6_STRICT',
language_out: 'ES5_STRICT',
warning_level: 'VERBOSE',
2017-03-29 15:52:01 -07:00
output_wrapper: '(function(){\n%output%\n}).call(self);',
assume_function_wrapper: true,
2017-01-09 15:56:20 -08:00
rewrite_polyfills: false,
2017-03-29 15:52:01 -07:00
new_type_inf: true,
checks_only: CLOSURE_LINT_ONLY,
2017-03-29 15:52:01 -07:00
externs: [
'bower_components/shadycss/externs/shadycss-externs.js',
2017-03-29 15:52:01 -07:00
'externs/webcomponents-externs.js',
'externs/polymer-externs.js',
'externs/closure-types.js',
2017-03-29 15:52:01 -07:00
],
extra_annotation_name: [
'polymerMixin',
'polymerMixinClass',
'polymerElement'
]
}, closurePluginOptions);
2017-01-09 15:56:20 -08:00
2017-01-10 15:02:48 -08:00
const closurePipeline = lazypipe()
.pipe(() => closureStream)
.pipe(() => new OldNameStream(closureStream.fileList_))
2017-01-10 15:02:48 -08:00
2017-01-09 15:56:20 -08:00
// process source files in the project
2017-04-17 11:17:14 -07:00
const sources = project.sources();
2017-01-09 15:56:20 -08:00
// process dependencies
2017-04-17 11:17:14 -07:00
const dependencies = project.dependencies();
2017-01-09 15:56:20 -08:00
// merge the source and dependencies streams to we can analyze the project
const mergedFiles = mergeStream(sources, dependencies);
2017-03-29 15:52:01 -07:00
const splitter = new polymer.HtmlSplitter();
2017-01-09 15:56:20 -08:00
return mergedFiles
2017-04-17 11:17:14 -07:00
.pipe(project.bundler())
.pipe(new Uniq())
2017-03-29 15:52:01 -07:00
.pipe(splitter.split())
.pipe(gulpif(splitRx, closurePipeline()))
.pipe(splitter.rejoin())
.pipe(gulpif(joinRx, minimalDocument()))
.pipe(gulpif(joinRx, size({title: 'closure size', gzip: true, showTotal: false, showFiles: true})))
2017-01-18 14:24:27 -08:00
.pipe(gulp.dest(COMPILED_DIR))
});
gulp.task('lint-closure', (done) => {
CLOSURE_LINT_ONLY = true;
runseq('closure', done);
})
gulp.task('estimate-size', ['clean'], () => {
const babelPresets = {
presets: [['babili', {regexpConstructors: false}]]
};
2016-02-16 11:43:39 -08:00
const project = new PolymerProject({
shell: POLYMER_LEGACY,
fragments: [
'bower_components/shadycss/apply-shim.html',
'bower_components/shadycss/custom-style-interface.html'
]
});
// process source files in the project
const sources = project.sources();
2016-02-16 11:43:39 -08:00
// process dependencies
const dependencies = project.dependencies();
2016-02-16 11:43:39 -08:00
// merge the source and dependencies streams to we can analyze the project
const mergedFiles = mergeStream(sources, dependencies);
2016-02-16 11:43:39 -08:00
const bundledSplitter = new polymer.HtmlSplitter();
2016-02-16 11:43:39 -08:00
const bundlePipe = lazypipe()
.pipe(() => bundledSplitter.split())
.pipe(() => gulpif(/\.js$/, babel(babelPresets)))
.pipe(() => bundledSplitter.rejoin())
.pipe(minimalDocument)
2016-02-16 11:43:39 -08:00
return mergedFiles
.pipe(project.bundler())
.pipe(gulpif(/polymer\.html$/, bundlePipe()))
.pipe(new Uniq())
.pipe(gulpif(/polymer\.html$/, size({ title: 'bundled size', gzip: true, showTotal: false, showFiles: true })))
// write to the bundled folder
.pipe(gulp.dest(BUNDLED_DIR))
2016-02-16 11:43:39 -08:00
});
2017-01-18 14:24:27 -08:00
gulp.task('lint', function() {
2017-03-03 15:58:52 -08:00
return gulp.src(['lib/**/*.html', 'test/unit/*.html', 'util/*.js'])
2016-02-16 11:43:39 -08:00
.pipe(eslint())
.pipe(eslint.format())
.pipe(eslint.failAfterError());
});
2017-04-26 14:59:34 -07:00
gulp.task('generate-closure-externs', ['clean'], () => {
let genClosure = require('@polymer/gen-closure-declarations').generateDeclarations;
return genClosure().then((declarations) => {
fs.writeFileSync('externs/closure-types.js', declarations);
});
});