gulpfile.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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.proceduralTextures.map(function (proceduralTexture) {
  27. var js = gulp.src(proceduralTexture.file)
  28. .pipe(typescript({
  29. noExternalResolve: false,
  30. target: 'ES5',
  31. declarationFiles: true,
  32. typescript: require('typescript')
  33. })).js;
  34. var shader = gulp.src(proceduralTexture.shaderFiles).pipe(srcToVariable("BABYLON.Effect.ShadersStore", true, shadersName));
  35. return merge2(js, shader)
  36. .pipe(cleants())
  37. .pipe(replace(extendsSearchRegex, ""))
  38. .pipe(concat(proceduralTexture.output))
  39. .pipe(gulp.dest(config.build.distOutputDirectory))
  40. .pipe(rename({extname: ".min.js"}))
  41. .pipe(uglify())
  42. .pipe(gulp.dest(config.build.distOutputDirectory));
  43. });
  44. return tasks;
  45. });
  46. /**
  47. * Web server task to serve a local test page
  48. */
  49. gulp.task('webserver', function() {
  50. gulp.src('.')
  51. .pipe(webserver({
  52. livereload: false,
  53. open: 'http://localhost:1338/test/index.html',
  54. port: 1338,
  55. fallback: 'index.html'
  56. }));
  57. });