gulpfile.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. var gulp = require("gulp");
  2. var uglify = require("gulp-uglify");
  3. var typescript = require("gulp-typescript");
  4. var sourcemaps = require("gulp-sourcemaps");
  5. var srcToVariable = require("./gulp-srcToVariable");
  6. var addModuleExports = require("./gulp-addModuleExports");
  7. var merge2 = require("merge2");
  8. var concat = require("gulp-concat");
  9. var rename = require("gulp-rename");
  10. var cleants = require('gulp-clean-ts-extends');
  11. var changed = require('gulp-changed');
  12. var runSequence = require('run-sequence');
  13. var config = require("./config.json");
  14. var shadersStream;
  15. var workersStream;
  16. //function to convert the shaders' filenames to variable names.
  17. function shadersName(filename) {
  18. return filename.replace('.fragment', 'Pixel')
  19. .replace('.vertex', 'Vertex')
  20. .replace('.fx', 'Shader');
  21. }
  22. gulp.task("shaders", function(cb) {
  23. shadersStream = config.shadersDirectories.map(function(shadersDef) {
  24. return gulp.src(shadersDef.files).pipe(srcToVariable(shadersDef.variable, true, shadersName));
  25. });
  26. cb();
  27. });
  28. gulp.task("workers", function(cb) {
  29. workersStream = config.workers.map(function(workerDef) {
  30. return gulp.src(workerDef.files).pipe(uglify()).pipe(srcToVariable(workerDef.variable));
  31. });
  32. cb();
  33. });
  34. /*
  35. Compiles all typescript files and creating a declaration file.
  36. */
  37. gulp.task('typescript-compile', function() {
  38. var tsResult = gulp.src(config.core.typescript)
  39. .pipe(typescript({
  40. noExternalResolve: true,
  41. target: 'ES5',
  42. declarationFiles: true,
  43. typescript: require('typescript')
  44. }));
  45. return merge2([
  46. tsResult.dts
  47. .pipe(concat(config.build.declarationFilename))
  48. .pipe(gulp.dest(config.build.outputDirectory)),
  49. tsResult.js
  50. .pipe(gulp.dest('../../Babylon/'))
  51. ]);
  52. });
  53. gulp.task('typescript-sourcemaps', function() {
  54. var tsResult = gulp.src(config.core.typescript)
  55. .pipe(sourcemaps.init()) // sourcemaps init. currently redundant directory def, waiting for this - https://github.com/floridoo/gulp-sourcemaps/issues/111
  56. .pipe(typescript({
  57. noExternalResolve: true,
  58. target: 'ES5',
  59. declarationFiles: true,
  60. typescript: require('typescript')
  61. }));
  62. return tsResult.js
  63. .pipe(sourcemaps.write("./")) // sourcemaps are written.
  64. .pipe(gulp.dest('../../Babylon/'));
  65. });
  66. gulp.task("buildNoWorker", ["shaders"], function () {
  67. return merge2(
  68. gulp.src(config.core.files, config.extras.files),
  69. shadersStream
  70. )
  71. .pipe(concat(config.build.minNoWorkerFilename))
  72. .pipe(cleants())
  73. .pipe(addModuleExports("BABYLON"))
  74. .pipe(uglify())
  75. .pipe(gulp.dest(config.build.outputDirectory))
  76. });
  77. gulp.task("build", ["workers", "shaders"], function () {
  78. return merge2(
  79. gulp.src(config.core.files, config.extras.files),
  80. shadersStream,
  81. workersStream
  82. )
  83. .pipe(concat(config.build.filename))
  84. .pipe(cleants())
  85. .pipe(addModuleExports("BABYLON"))
  86. .pipe(gulp.dest(config.build.outputDirectory))
  87. .pipe(rename(config.build.minFilename))
  88. .pipe(uglify())
  89. .pipe(gulp.dest(config.build.outputDirectory))
  90. });
  91. gulp.task("typescript", function(cb) {
  92. runSequence("typescript-compile", "build");
  93. });
  94. /**
  95. * The default task, call the tasks: build
  96. */
  97. gulp.task('default', function() {
  98. return runSequence("buildNoWorker", "build");
  99. });
  100. /**
  101. * Watch task, will call the default task if a js file is updated.
  102. */
  103. gulp.task('watch', function() {
  104. gulp.watch('../../Babylon/**/*.js', ['build']);
  105. });
  106. /**
  107. * Watch typescript task, will call the default typescript task if a typescript file is updated.
  108. */
  109. gulp.task('watch-typescript', function() {
  110. gulp.watch("../../Babylon/**/*.ts", ["typescript-compile", "build"]);
  111. });