gulpfile.js
changeset 557 bca7a7e058a3
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/gulpfile.js	Thu Feb 13 11:43:31 2020 +0100
@@ -0,0 +1,53 @@
+var gulp = require('gulp'),
+	concat = require('gulp-concat');
+
+var package = require("./package.json"),
+	scripts = package.scripts;
+
+
+/** Fix pipe function */
+function fixPipe(stream) {
+	var origPipe = stream.pipe;
+	stream.pipe = function (dest) {
+		arguments[0] = dest.on('error', function (error) {
+			var nextStreams = dest._nextStreams;
+			if (nextStreams) {
+				nextStreams.forEach(function (nextStream) {
+					nextStream.emit('error', error);
+				});
+			} else if (dest.listeners('error').length === 1) {
+				throw error;
+			}
+		});
+		var nextStream = fixPipe(origPipe.apply(this, arguments));
+		(this._nextStreams || (this._nextStreams = [])).push(nextStream);
+		return nextStream;
+	};
+	return stream;
+}
+
+var origSrc = gulp.src;
+
+gulp.src = function() {
+	return fixPipe(origSrc.apply(this, arguments));
+};
+
+
+// Gulp tasks
+gulp.task('scripts', function() {
+	return gulp.src(scripts.sources, {cwd: scripts.base})
+		.pipe(concat(scripts.target.replace(/{version}/, package.version)))
+		.pipe(gulp.dest(scripts.base));
+});
+
+gulp.task('scripts-core', function() {
+	return gulp.src(scripts.core_sources, {cwd: scripts.base})
+		.pipe(concat(scripts.core_target.replace(/{version}/, package.version)))
+		.pipe(gulp.dest(scripts.base));
+});
+
+gulp.task('watch', function() {
+	gulp.watch(scripts.sources, {cwd: scripts.base}, ['scripts', 'scripts-core']);
+});
+
+gulp.task('default', ['scripts', 'scripts-core', 'watch']);