123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481 |
- // Gulp Tools
- var gulp = require("gulp");
- var uglify = require("gulp-uglify");
- var typescript = require("gulp-typescript");
- var sourcemaps = require("gulp-sourcemaps");
- var srcToVariable = require("gulp-content-to-variable");
- var merge2 = require("merge2");
- var concat = require("gulp-concat");
- var rename = require("gulp-rename");
- var cleants = require("gulp-clean-ts-extends");
- var replace = require("gulp-replace");
- var expect = require("gulp-expect-file");
- var optimisejs = require("gulp-optimize-js");
- var filter = require('gulp-filter');
- var path = require("path");
- var webpack = require('webpack');
- var webpackStream = require("webpack-stream");
- var fs = require("fs");
- var dtsBundle = require('dts-bundle');
- var through = require('through2');
- // Gulp Helpers
- var addDtsExport = require("./helpers/gulp-addDtsExport");
- var addDecorateAndExtends = require("./helpers/gulp-decorateAndExtends");
- var addModuleExports = require("./helpers/gulp-addModuleExports");
- var addES6Exports = require("./helpers/gulp-addES6Exports");
- var uncommentShader = require("./helpers/gulp-removeShaderComments");
- var processDeclaration = require('./helpers/gulp-processTypescriptDeclaration');
- // Import Gulp Tasks
- require("./tasks/gulpTasks-tsLint");
- require("./tasks/gulpTasks-netlify");
- require("./tasks/gulpTasks-whatsNew");
- require("./tasks/gulpTasks-localRun");
- require("./tasks/gulpTasks-watch");
- require("./tasks/gulpTasks-typedoc");
- require("./tasks/gulpTasks-intellisense");
- require("./tasks/gulpTasks-tests");
- // Import Build Config
- var config = require("./config.json");
- var includeShadersStream;
- var shadersStream;
- var workersStream;
- var extendsSearchRegex = /var\s__extends[\s\S]+?\}\)\(\);/g;
- var decorateSearchRegex = /var\s__decorate[\s\S]+?\};/g;
- /**
- * TS configurations shared in the gulp file.
- */
- var tsConfig = {
- noResolve: true,
- target: "ES5",
- declarationFiles: true,
- typescript: require("typescript"),
- experimentalDecorators: true,
- isolatedModules: false,
- noImplicitAny: true,
- noImplicitReturns: true,
- noImplicitThis: true,
- noUnusedLocals: true,
- strictNullChecks: true,
- strictFunctionTypes: true,
- types: [],
- lib: [
- "dom",
- "es2015.promise",
- "es5"
- ]
- };
- var tsProject = typescript.createProject(tsConfig);
- function processDependency(kind, dependency, filesToLoad, firstLevelOnly) {
- if (!firstLevelOnly && dependency.dependUpon) {
- for (var i = 0; i < dependency.dependUpon.length; i++) {
- var dependencyName = dependency.dependUpon[i];
- var parent = config.workloads[dependencyName];
- processDependency(kind, parent, filesToLoad);
- }
- }
- var content = dependency[kind];
- if (!content) {
- return;
- }
- for (var i = 0; i < content.length; i++) {
- var file = content[i];
- if (filesToLoad.indexOf(file) === -1) {
- filesToLoad.push(file);
- }
- }
- }
- function determineFilesToProcess(kind) {
- var currentConfig = config.build.currentConfig;
- var buildConfiguration = config.buildConfigurations[currentConfig];
- var filesToLoad = [];
- for (var index = 0; index < buildConfiguration.length; index++) {
- var dependencyName = buildConfiguration[index];
- var dependency = config.workloads[dependencyName];
- if (kind === "directFiles" && !dependency) {
- filesToLoad.push("../../dist/preview release/" + dependencyName);
- }
- else if (dependency) {
- processDependency(kind, dependency, filesToLoad);
- }
- }
- if (kind === "shaderIncludes") {
- for (var index = 0; index < filesToLoad.length; index++) {
- filesToLoad[index] = "../../src/Shaders/ShadersInclude/" + filesToLoad[index] + ".fx";
- }
- } else if (kind === "shaders") {
- for (var index = 0; index < filesToLoad.length; index++) {
- var name = filesToLoad[index];
- filesToLoad[index] = "../../src/Shaders/" + filesToLoad[index] + ".fx";
- }
- }
- return filesToLoad;
- }
- /*
- * Shader Management.
- */
- function shadersName(filename) {
- return path.basename(filename)
- .replace(".fragment", "Pixel")
- .replace(".vertex", "Vertex")
- .replace(".fx", "Shader");
- }
- function includeShadersName(filename) {
- return path.basename(filename).replace(".fx", "");
- }
- /*
- * Main necessary files stream Management.
- */
- gulp.task("includeShaders", function(cb) {
- var filesToProcess = determineFilesToProcess("shaderIncludes");
- includeShadersStream = gulp.src(filesToProcess).
- pipe(expect.real({ errorOnFailure: true }, filesToProcess)).
- pipe(uncommentShader()).
- pipe(srcToVariable({
- variableName: "BABYLON.Effect.IncludesShadersStore", asMap: true, namingCallback: includeShadersName
- }));
- cb();
- });
- gulp.task("shaders", gulp.series("includeShaders", function(cb) {
- var filesToProcess = determineFilesToProcess("shaders");
- shadersStream = gulp.src(filesToProcess).
- pipe(expect.real({ errorOnFailure: true }, filesToProcess)).
- pipe(uncommentShader()).
- pipe(srcToVariable({
- variableName: "BABYLON.Effect.ShadersStore", asMap: true, namingCallback: shadersName
- }));
- cb();
- }));
- gulp.task("workers", function(cb) {
- workersStream = config.workers.map(function(workerDef) {
- return gulp.src(workerDef.files).
- pipe(expect.real({ errorOnFailure: true }, workerDef.files)).
- pipe(uglify()).
- pipe(srcToVariable({
- variableName: workerDef.variable
- }));
- });
- cb();
- });
- /**
- * Build tasks to concat minify uflify optimise the BJS js in different flavor (workers...).
- */
- gulp.task("buildWorker", gulp.series(gulp.parallel("workers", "shaders"), function() {
- var filesToProcess = determineFilesToProcess("files");
- return merge2(
- gulp.src(filesToProcess).
- pipe(expect.real({ errorOnFailure: true }, filesToProcess)),
- shadersStream,
- includeShadersStream,
- workersStream
- )
- .pipe(concat(config.build.minWorkerFilename))
- .pipe(cleants())
- .pipe(replace(extendsSearchRegex, ""))
- .pipe(replace(decorateSearchRegex, ""))
- .pipe(addDecorateAndExtends())
- .pipe(addModuleExports("BABYLON", {
- dependencies: config.build.dependencies
- }))
- .pipe(uglify())
- .pipe(optimisejs())
- .pipe(gulp.dest(config.build.outputDirectory));
- }));
- gulp.task("build", gulp.series("shaders", function build() {
- var filesToProcess = determineFilesToProcess("files");
- var directFilesToProcess = determineFilesToProcess("directFiles");
- let mergedStreams = merge2(gulp.src(filesToProcess)
- .pipe(expect.real({ errorOnFailure: true }, filesToProcess)),
- shadersStream,
- includeShadersStream);
- if (directFilesToProcess.length) {
- mergedStreams.add(gulp.src(directFilesToProcess));
- }
- return merge2(
- mergedStreams
- .pipe(concat(config.build.noModuleFilename))
- .pipe(cleants())
- .pipe(replace(extendsSearchRegex, ""))
- .pipe(replace(decorateSearchRegex, ""))
- .pipe(addDecorateAndExtends())
- .pipe(gulp.dest(config.build.outputDirectory))
- .pipe(rename(config.build.filename))
- .pipe(addModuleExports("BABYLON", {
- dependencies: config.build.dependencies
- }))
- .pipe(gulp.dest(config.build.outputDirectory))
- .pipe(rename(config.build.minFilename))
- .pipe(uglify())
- .pipe(optimisejs())
- .pipe(gulp.dest(config.build.outputDirectory)),
- mergedStreams
- .pipe(concat("es6.js"))
- .pipe(cleants())
- .pipe(replace(extendsSearchRegex, ""))
- .pipe(replace(decorateSearchRegex, ""))
- .pipe(addES6Exports("BABYLON"))
- .pipe(gulp.dest(config.build.outputDirectory))
- );
- }));
- /*
- * Compiles all typescript files and creating a js and a declaration file.
- */
- gulp.task("typescript-compile", function() {
- const dtsFilter = filter(['**', '!**/*.d.ts'], {restore: false});
- var tsResult = gulp.src(config.typescript)
- .pipe(dtsFilter)
- .pipe(sourcemaps.init())
- .pipe(tsProject({
- summarizeFailureOutput: true
- }));
- //If this gulp task is running on travis, file the build!
- if (process.env.TRAVIS) {
- tsResult.once("error", function() {
- tsResult.once("finish", function() {
- console.log("Typescript compile failed");
- process.exit(1);
- });
- });
- }
- return merge2([
- tsResult.dts
- .pipe(concat(config.build.declarationFilename))
- .pipe(addDtsExport("BABYLON", "babylonjs"))
- .pipe(gulp.dest(config.build.outputDirectory)),
- tsResult.js
- .pipe(sourcemaps.write("./",
- {
- includeContent: false,
- sourceRoot: (filePath) => {
- return "";
- }
- }))
- .pipe(gulp.dest(config.build.srcOutputDirectory))
- ])
- });
- /**
- * Build the releasable files.
- */
- gulp.task("typescript", gulp.series("typescript-compile", "buildWorker", "build"));
- var buildExternalLibrary = function(library, settings) {
- var outputDirectory = config.build.outputDirectory + settings.build.distOutputDirectory;
- if (!library.webpack) {
- throw "Missing Webpack configuration in " + library;
- }
- const sequence = [];
- if (settings.build.outputs) {
- settings.build.outputs.forEach(out => {
- let wpConfig = require(library.webpack);
- if (!out.minified) {
- wpConfig.mode = "development";
- }
- let wpBuild = webpackStream(wpConfig, require("webpack"));
- //shoud dtsBundle create the declaration?
- if (settings.build.dtsBundle) {
- let event = wpBuild
- .pipe(through.obj(function(file, enc, cb) {
- // only declaration files
- const isdts = /\.d\.ts$/.test(file.path);
- if (isdts) this.push(file);
- cb();
- }))
- .pipe(gulp.dest(outputDirectory));
- // dts-bundle does NOT support (gulp) streams, so files have to be saved and reloaded,
- // until I fix it
- event.on("end", function() {
- // create the file
- dtsBundle.bundle(settings.build.dtsBundle);
- // prepend the needed reference
- let fileLocation = path.join(path.dirname(settings.build.dtsBundle.main), settings.build.dtsBundle.out);
- fs.readFile(fileLocation, function(err, data) {
- if (err) throw err;
- data = (settings.build.dtsBundle.prependText || "") + '\n' + data.toString();
- fs.writeFileSync(fileLocation, data);
- if (settings.build.processDeclaration) {
- var newData = processDeclaration(data, settings.build.processDeclaration);
- fs.writeFileSync(fileLocation.replace('.module', ''), newData);
- }
- });
- });
- }
- let build = wpBuild
- .pipe(through.obj(function(file, enc, cb) {
- // only pipe js files
- const isJs = /\.js$/.test(file.path);
- if (isJs) this.push(file);
- cb();
- }))
- .pipe(addModuleExports(library.moduleDeclaration, { subModule: false, extendsRoot: false, externalUsingBabylon: true, noBabylonInit: library.babylonIncluded }));
- function processDestination(dest) {
- var outputDirectory = config.build.outputDirectory + dest.outputDirectory;
- build = build
- .pipe(rename(dest.filename.replace(".js", library.noBundleInName ? '.js' : ".bundle.js")))
- .pipe(gulp.dest(outputDirectory));
- if (library.babylonIncluded && dest.addBabylonDeclaration) {
- // include the babylon declaration
- if (dest.addBabylonDeclaration === true) {
- dest.addBabylonDeclaration = [config.build.declarationFilename];
- }
- var decsToAdd = dest.addBabylonDeclaration.map(function(dec) {
- return config.build.outputDirectory + '/' + dec;
- });
- sequence.unshift(gulp.src(decsToAdd)
- .pipe(rename(function(path) {
- path.dirname = '';
- }))
- .pipe(gulp.dest(outputDirectory)))
- }
- }
- out.destinations.forEach(dest => {
- processDestination(dest);
- });
- sequence.push(build);
- });
- } else {
- var wpConfig;
- if (library.entry) {
- wpConfig = require(settings.build.webpack);
- wpConfig.entry = {
- 'main': path.resolve(wpConfig.context, library.entry),
- };
- wpConfig.output.filename = library.output;
- }
- else {
- wpConfig = require(library.webpack);
- }
- let wpBuild = webpackStream(wpConfig, webpack);
- let buildEvent = wpBuild.pipe(gulp.dest(outputDirectory));
- sequence.push(buildEvent);
- // Generate unminified
- wpConfig.mode = "development";
- wpConfig.output.filename = wpConfig.output.filename.replace(".min", "");
- wpBuild = webpackStream(wpConfig, webpack);
- let buildEvent2 = wpBuild.pipe(gulp.dest(outputDirectory));
- sequence.push(buildEvent2);
- if (library.isMain) {
- if (settings.build.dtsBundle || settings.build.processDeclaration) {
- buildEvent.on("end", function() {
- if (settings.build.dtsBundle) {
- dtsBundle.bundle(settings.build.dtsBundle);
- }
- if (settings.build.processDeclaration) {
- let fileLocation = path.join(outputDirectory, settings.build.processDeclaration.filename);
- fs.readFile(fileLocation, function(err, data) {
- if (err) throw err;
- // For Raanan, litteral import hack TO BETTER INTEGRATE
- data = data + "";
- data = data.replace('import "../sass/main.scss";', "");
- var newData = processDeclaration(data, settings.build.processDeclaration);
- fs.writeFileSync(fileLocation.replace('.module', ''), newData);
- //legacy module support
- fs.writeFileSync(fileLocation, data + "\n" + newData);
- });
- }
- });
- }
- }
- }
- return merge2(sequence);
- }
- /**
- * Dynamic module creation In Serie for WebPack leaks.
- */
- function buildExternalLibraries(settings) {
- var tasks = settings.libraries.map(function(library) {
- var build = function(cb) {
- return buildExternalLibrary(library, settings);
- }
- return build;
- });
- return gulp.series.apply(this, tasks);
- }
- /**
- * Dynamic module creation.
- */
- config.modules.map(function(module) {
- gulp.task(module, buildExternalLibraries(config[module]));
- });
- /**
- * Build all libs.
- */
- gulp.task("typescript-libraries", gulp.series(config.modules));
- /**
- * Custom build with full path file control; used by profile.html
- */
- gulp.task("build-custom", gulp.series("typescript-compile", "build"));
- /**
- * Validate compile the code and check the comments and style case convention through typedoc
- */
- gulp.task("typedoc-check", gulp.series("typescript-compile", "gui", "loaders", "serializers", "typedoc-generate", "typedoc-validate"));
- /**
- * Combine Webserver and Watch as long as vscode does not handle multi tasks.
- */
- gulp.task("run", gulp.series("watch", "webserver"));
- /**
- * Do it all (Build).
- */
- gulp.task("typescript-all", gulp.series("typescript", "typescript-libraries", "netlify-cleanup"));
- /**
- * Do it all (tests).
- */
- gulp.task("tests-all", gulp.series("tests-unit", "tests-modules", "tests-validation-virtualscreen", "tests-validation-browserstack"));
- /**
- * The default task, concat and min the main BJS files.
- */
- gulp.task("default", gulp.series("tsLint", "typescript-all", "intellisense", "typedoc-all", "tests-all"));
|