gulpfile.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. var gulp = require("gulp");
  2. var typescript = require("gulp-typescript");
  3. var srcToVariable = require("./gulp-srcToVariable");
  4. var merge2 = require("merge2");
  5. var concat = require("gulp-concat");
  6. var rename = require("gulp-rename");
  7. var cleants = require('gulp-clean-ts-extends');
  8. var replace = require("gulp-replace");
  9. var webserver = require('gulp-webserver');
  10. var uglify = require("gulp-uglify");
  11. var config = require("./config.json");
  12. var extendsSearchRegex = /var\s__extends[\s\S]+?\};/g;
  13. //function to convert the shaders' filenames to variable names.
  14. function shadersName(filename) {
  15. return filename.replace('.fragment', 'Pixel')
  16. .replace('.vertex', 'Vertex')
  17. .replace('.fx', 'Shader');
  18. }
  19. gulp.task('copyReference', function () {
  20. return gulp.src("../dist/preview release/babylon.max.js").pipe(gulp.dest("test"));
  21. });
  22. /*
  23. Compiles all typescript files and creating a declaration file.
  24. */
  25. gulp.task('default', ["copyReference"], function () {
  26. var tasks = config.materials.map(function (material) {
  27. var compilOutput = gulp.src(material.file)
  28. .pipe(typescript({
  29. noExternalResolve: false,
  30. target: 'ES5',
  31. declarationFiles: true,
  32. typescript: require('typescript')
  33. }));
  34. var js = compilOutput.js;
  35. // Build definitions file
  36. var dts = compilOutput.dts.pipe(gulp.dest(config.build.dtsOutputDirectory));
  37. var shader = gulp.src(material.shaderFiles).pipe(srcToVariable("BABYLON.Effect.ShadersStore", true, shadersName));
  38. return merge2(js, shader)
  39. .pipe(cleants())
  40. .pipe(replace(extendsSearchRegex, ""))
  41. .pipe(concat(material.output))
  42. .pipe(gulp.dest(config.build.distOutputDirectory))
  43. .pipe(rename({extname: ".min.js"}))
  44. .pipe(uglify())
  45. .pipe(gulp.dest(config.build.distOutputDirectory));
  46. });
  47. return tasks;
  48. });
  49. /**
  50. * Web server task to serve a local test page
  51. */
  52. gulp.task('webserver', function() {
  53. gulp.src('.')
  54. .pipe(webserver({
  55. livereload: false,
  56. open: 'http://localhost:1338/test/index.html',
  57. port: 1338,
  58. fallback: 'index.html'
  59. }));
  60. });