chore(build): Migrate remaining tasks under build.js.dev to broccoli.
This commit is contained in:
@ -1,7 +1,11 @@
|
||||
'use strict';
|
||||
|
||||
var broccoli = require('broccoli');
|
||||
var copyDereferenceSync = require('copy-dereference').sync;
|
||||
var fse = require('fs-extra');
|
||||
var path = require('path');
|
||||
var printSlowTrees = require('broccoli-slow-trees');
|
||||
|
||||
|
||||
module.exports = broccoliBuild;
|
||||
var broccoliExecuted = {};
|
||||
@ -29,24 +33,43 @@ function broccoliBuild(tree, outputRoot) {
|
||||
var builder = new broccoli.Builder(tree);
|
||||
return builder.build()
|
||||
.then(function (hash) {
|
||||
printSlowTrees(hash.graph);
|
||||
|
||||
var dir = hash.directory;
|
||||
try {
|
||||
copyDereferenceSync(path.join(dir, outputRoot), distPath);
|
||||
time('Write build output', function() {
|
||||
copyDereferenceSync(path.join(dir, outputRoot), distPath);
|
||||
});
|
||||
} catch (err) {
|
||||
if (err.code === 'EEXIST') err.message += ' (we cannot build into an existing directory)';
|
||||
throw err;
|
||||
}
|
||||
})
|
||||
.finally(function () {
|
||||
builder.cleanup();
|
||||
time('Build cleanup', function() {
|
||||
builder.cleanup();
|
||||
});
|
||||
})
|
||||
.catch(function (err) {
|
||||
// Should show file and line/col if present
|
||||
if (err.file) {
|
||||
console.error('File: ' + err.file);
|
||||
}
|
||||
console.error(err.stack);
|
||||
if (err.stack) {
|
||||
console.error(err.stack);
|
||||
} else {
|
||||
console.error(err);
|
||||
}
|
||||
console.error('\nBuild failed');
|
||||
process.exit(1);
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
function time(label, work) {
|
||||
|
||||
var start = Date.now();
|
||||
work();
|
||||
var duration = Date.now() - start;
|
||||
console.log("%s: %dms", label, duration);
|
||||
}
|
||||
|
10
tools/broccoli/html-replace/SCRIPTS.html
Normal file
10
tools/broccoli/html-replace/SCRIPTS.html
Normal file
@ -0,0 +1,10 @@
|
||||
<script src="traceur-runtime.js" type="text/javascript"></script>
|
||||
<script src="es6-module-loader-sans-promises.src.js" type="text/javascript"></script>
|
||||
<script src="zone.js" type="text/javascript"></script>
|
||||
<script src="long-stack-trace-zone.js" type="text/javascript"></script>
|
||||
<script src="system.src.js" type="text/javascript"></script>
|
||||
<script src="extension-register.js" type="text/javascript"></script>
|
||||
<script src="extension-cjs.js" type="text/javascript"></script>
|
||||
<script src="rx.all.js" type="text/javascript"></script>
|
||||
<script src="runtime_paths.js" type="text/javascript"></script>
|
||||
<script type="text/javascript">System.import('@@FILENAME_NO_EXT').then(function(m) { m.main(); }, console.error.bind(console))</script>
|
11
tools/broccoli/html-replace/SCRIPTS_benchmarks.html
Normal file
11
tools/broccoli/html-replace/SCRIPTS_benchmarks.html
Normal file
@ -0,0 +1,11 @@
|
||||
<script src="url_params_to_form.js" type="text/javascript"></script>
|
||||
<script src="traceur-runtime.js" type="text/javascript"></script>
|
||||
<script src="es6-module-loader-sans-promises.src.js" type="text/javascript"></script>
|
||||
<script src="zone.js" type="text/javascript"></script>
|
||||
<script src="long-stack-trace-zone.js" type="text/javascript"></script>
|
||||
<script src="system.src.js" type="text/javascript"></script>
|
||||
<script src="extension-register.js" type="text/javascript"></script>
|
||||
<script src="extension-cjs.js" type="text/javascript"></script>
|
||||
<script src="rx.all.js" type="text/javascript"></script>
|
||||
<script src="runtime_paths.js" type="text/javascript"></script>
|
||||
<script type="text/javascript">System.import('@@FILENAME_NO_EXT').then(function(m) { m.main(); }, console.error.bind(console))</script>
|
12
tools/broccoli/html-replace/SCRIPTS_benchmarks_external.html
Normal file
12
tools/broccoli/html-replace/SCRIPTS_benchmarks_external.html
Normal file
@ -0,0 +1,12 @@
|
||||
<script src="angular.js" type="text/javascript"></script>
|
||||
<script src="url_params_to_form.js" type="text/javascript"></script>
|
||||
<script src="traceur-runtime.js" type="text/javascript"></script>
|
||||
<script src="es6-module-loader-sans-promises.src.js" type="text/javascript"></script>
|
||||
<script src="zone.js" type="text/javascript"></script>
|
||||
<script src="long-stack-trace-zone.js" type="text/javascript"></script>
|
||||
<script src="system.src.js" type="text/javascript"></script>
|
||||
<script src="extension-register.js" type="text/javascript"></script>
|
||||
<script src="extension-cjs.js" type="text/javascript"></script>
|
||||
<script src="rx.all.js" type="text/javascript"></script>
|
||||
<script src="runtime_paths.js" type="text/javascript"></script>
|
||||
<script type="text/javascript">System.import('@@FILENAME_NO_EXT').then(function(m) { m.main(); }, console.error.bind(console))</script>
|
10
tools/broccoli/html-replace/index.js
Normal file
10
tools/broccoli/html-replace/index.js
Normal file
@ -0,0 +1,10 @@
|
||||
var fs = require('fs');
|
||||
var path = require('path');
|
||||
|
||||
module.exports = read;
|
||||
function read(file) {
|
||||
var content = fs.readFileSync(path.join(__dirname, file + '.html'), {encoding: 'utf-8'});
|
||||
// TODO(broccoli): we don't really need this, it's here to make the output match the tools/build/html
|
||||
return content.substring(0, content.lastIndexOf("\n"));
|
||||
}
|
||||
|
@ -48,6 +48,7 @@ var TraceurFilter = (function (_super) {
|
||||
});
|
||||
});
|
||||
};
|
||||
TraceurFilter.RUNTIME_PATH = traceur.RUNTIME_PATH;
|
||||
return TraceurFilter;
|
||||
})(Writer);
|
||||
module.exports = TraceurFilter;
|
||||
|
@ -8,7 +8,7 @@ var xtend = require('xtend');
|
||||
|
||||
class TraceurFilter extends Writer {
|
||||
constructor(private inputTree, private destExtension: string = '.js', private options = {}) {}
|
||||
|
||||
static RUNTIME_PATH = traceur.RUNTIME_PATH;
|
||||
write(readTree, destDir) {
|
||||
return readTree(this.inputTree)
|
||||
.then(srcDir => {
|
||||
|
Reference in New Issue
Block a user