Skip to content

Instantly share code, notes, and snippets.

@dennisreimann
Created December 1, 2015 21:25
Show Gist options
  • Star 5 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save dennisreimann/cd8d45eefaba43199dcd to your computer and use it in GitHub Desktop.
Save dennisreimann/cd8d45eefaba43199dcd to your computer and use it in GitHub Desktop.
building elm projects with gulp: basic setup
var gulp = require('gulp');
var elm = require('gulp-elm');
var plumber = require('gulp-plumber');
var del = require('del');
// builds elm files and static resources (i.e. html and css) from src to dist folder
var paths = {
dest: 'dist',
elm: 'src/*.elm',
staticAssets: 'src/*.{html,css}'
};
gulp.task('clean', function(cb) {
del([paths.dest], cb);
});
gulp.task('elm-init', elm.init);
gulp.task('elm', ['elm-init'], function() {
return gulp.src(paths.elm)
.pipe(plumber())
.pipe(elm())
.pipe(gulp.dest(paths.dest));
});
gulp.task('staticAssets', function() {
return gulp.src(paths.staticAssets)
.pipe(plumber())
.pipe(gulp.dest(paths.dest));
});
gulp.task('watch', function() {
gulp.watch(paths.elm, ['elm']);
gulp.watch(paths.staticAssets, ['static']);
});
gulp.task('build', ['elm', 'staticAssets']);
gulp.task('dev', ['build', 'watch']);
gulp.task('default', ['build']);
{
"devDependencies": {
"del": "^2.1.0",
"gulp": "^3.9.0",
"gulp-elm": "^0.2.0",
"gulp-plumber": "^1.0.1"
},
"scripts": {
"dev": "gulp clean && gulp dev",
"build": "gulp clean && gulp build"
}
}
@dennisreimann
Copy link
Author

Simple build:
npm run build

Development mode (run build on file change):
npm run dev

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment