gulpTasks-libraries.js 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. // Gulp Tools
  2. var gulp = require("gulp");
  3. var webpack = require('webpack');
  4. var webpackStream = require("webpack-stream");
  5. var cp = require('child_process');
  6. var path = require("path");
  7. var concat = require('gulp-concat');
  8. var minimist = require("minimist");
  9. // Gulp Helpers
  10. var uncommentShaders = require('../helpers/gulp-removeShaderComments');
  11. var processShaders = require("../helpers/gulp-processShaders");
  12. var processAmdDeclarationToModule = require('../helpers/gulp-processAmdDeclarationToModule');
  13. var processModuleDeclarationToNamespace = require('../helpers/gulp-processModuleDeclarationToNamespace');
  14. var del = require("del");
  15. // Parse Command Line.
  16. var commandLineOptions = minimist(process.argv.slice(2), {
  17. boolean: ["noNamespace"]
  18. });
  19. // Import Build Config
  20. var config = require("../../Config/config.js");
  21. // Constants
  22. const tempTypingsAMDFileName = "tempTypings.js";
  23. const tempTypingsFileName = tempTypingsAMDFileName.replace(".js", ".d.ts");
  24. const tempTypingsAMDFile = path.join(config.computed.tempFolder, tempTypingsAMDFileName);
  25. const tempTypingsFile = path.join(config.computed.tempFolder, tempTypingsFileName);
  26. /**
  27. * Clean shader ts files.
  28. */
  29. var cleanShaders = function(settings) {
  30. return del(settings.computed.shaderTSGlob, { force: true });
  31. }
  32. /**
  33. * Create shader ts files.
  34. */
  35. var buildShaders = function(settings) {
  36. return gulp.src(settings.computed.shaderGlob)
  37. .pipe(uncommentShaders())
  38. .pipe(processShaders(settings.isCore));
  39. }
  40. /**
  41. * Build a single library (one of the material of mat lib) from a module (materialsLibrary for instance)
  42. */
  43. var buildExternalLibrariesMultiEntry = function(libraries, settings, isMin) {
  44. // Convert Module to Namespace for globals
  45. var outputDirectory = settings.computed.distDirectory;
  46. // Does name contain .min. for min files.
  47. var isMinOutputName = libraries[0].output.indexOf(".min.") > -1;
  48. // Webpack Config.
  49. var wpConfig = require(settings.computed.webpackConfigPath);
  50. // Create multi entry list.
  51. wpConfig.entry = { };
  52. for (let library of settings.libraries) {
  53. let name = library.output.replace(isMinOutputName ? ".min.js" : ".js", "");
  54. wpConfig.entry[name] = library.computed.entryPath;
  55. }
  56. // Create output by type (min vs max).
  57. if (isMin) {
  58. delete wpConfig.devtool;
  59. wpConfig.output.filename = isMinOutputName ? '[name].min.js' : '[name].js';
  60. }
  61. else {
  62. // Map Output
  63. wpConfig.devtool = "source-map";
  64. wpConfig.output.devtoolModuleFilenameTemplate = (info) => {
  65. info.resourcePath = path.normalize(info.resourcePath);
  66. if (!path.isAbsolute(info.resourcePath)) {
  67. info.resourcePath = path.join(settings.computed.srcDirectory, info.resourcePath);
  68. }
  69. return `webpack://BABYLONJS/${path.relative(config.computed.rootFolder, info.resourcePath).replace(/\\/g, "/")}`;
  70. };
  71. // Generate unminified file.
  72. wpConfig.mode = "development";
  73. wpConfig.output.filename = isMinOutputName ? '[name].js' : '[name].max.js';
  74. }
  75. // Generate minified file.
  76. let wpBuild = webpackStream(wpConfig, webpack);
  77. return wpBuild.pipe(gulp.dest(outputDirectory));
  78. }
  79. /**
  80. * Build AMD DTS Files
  81. */
  82. var buildAMDDTSFiles = function(libraries, settings, cb) {
  83. // TODO. Generate all d.ts
  84. let library = libraries[0];
  85. if (!library.preventLoadLibrary) {
  86. // Generate DTS the old way...
  87. cp.execSync(`tsc --module amd --outFile "${tempTypingsAMDFile}" --emitDeclarationOnly true`, {
  88. cwd: settings.computed.srcDirectory
  89. });
  90. }
  91. cb();
  92. }
  93. /**
  94. * Append Lose DTS Files allowing isolated Modules build
  95. */
  96. var appendLoseDTSFiles = function(settings) {
  97. if (settings.build.loseDTSFiles) {
  98. return gulp.src([tempTypingsFile, path.join(settings.computed.srcDirectory, settings.build.loseDTSFiles)])
  99. .pipe(concat(tempTypingsFileName))
  100. .pipe(gulp.dest(config.computed.tempFolder));
  101. }
  102. return Promise.resolve();
  103. }
  104. /**
  105. * Process DTS Files
  106. */
  107. var processDTSFiles = function(libraries, settings, cb) {
  108. // Convert Module to Namespace for globals
  109. var outputDirectory = settings.computed.distDirectory;
  110. // TODO. Generate all d.ts
  111. let library = libraries[0];
  112. if (!library.preventLoadLibrary) {
  113. // Find declaration path.
  114. let fileLocation = path.join(outputDirectory, settings.build.umd.processDeclaration.filename);
  115. // Convert the tsc AMD BUNDLED declaration to our expected one
  116. processAmdDeclarationToModule(tempTypingsFile, {
  117. output: fileLocation,
  118. moduleName: settings.build.umd.packageName,
  119. entryPoint: library.entry,
  120. externals: settings.build.umd.processDeclaration.classMap,
  121. });
  122. // Convert Module to Namespace for globals
  123. if (!commandLineOptions.noNamespace) {
  124. processModuleDeclarationToNamespace(fileLocation, settings.build.umd.packageName, settings.build.umd.processDeclaration);
  125. }
  126. }
  127. cb();
  128. }
  129. /**
  130. * Dynamic module creation In Serie for WebPack leaks.
  131. */
  132. function buildExternalLibraries(settings) {
  133. // Creates the required tasks.
  134. var tasks = [];
  135. var cleanup = function() { return cleanShaders(settings); };
  136. var shaders = function() { return buildShaders(settings); };
  137. var buildMin = function() { return buildExternalLibrariesMultiEntry(settings.libraries, settings, true) };
  138. var buildMax = function() { return buildExternalLibrariesMultiEntry(settings.libraries, settings, false) };
  139. var buildAMDDTS = function(cb) { return buildAMDDTSFiles(settings.libraries, settings, cb) };
  140. var appendLoseDTS = function() { return appendLoseDTSFiles(settings) };
  141. var processDTS = function(cb) { return processDTSFiles(settings.libraries, settings, cb) };
  142. tasks.push(cleanup, shaders, buildMin, buildMax, buildAMDDTS, appendLoseDTS, processDTS);
  143. return gulp.series.apply(this, tasks);
  144. }
  145. /**
  146. * Dynamic module creation.
  147. */
  148. config.modules.map(function(module) {
  149. const settings = config[module];
  150. gulp.task(module, buildExternalLibraries(settings));
  151. });