Skip to content
This repository has been archived by the owner on Dec 10, 2019. It is now read-only.

Commit

Permalink
add a helper to normalize paths on Windows to the expected slash per …
Browse files Browse the repository at this point in the history
…analysis of #85

closes #85
  • Loading branch information
bmuenzenmeyer committed Nov 2, 2016
1 parent c599d09 commit 649ab26
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 26 deletions.
59 changes: 34 additions & 25 deletions gulpfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,54 +8,58 @@ var gulp = require('gulp'),
browserSync = require('browser-sync').create(),
argv = require('minimist')(process.argv.slice(2));

function resolvePath(pathInput) {
return path.resolve(pathInput).replace(/\\/g,"/");

This comment has been minimized.

Copy link
@eliland

eliland Nov 3, 2016

@bmuenzenmeyer This messes with the watchers!
When you now do gulp.watch(resolvePath(paths().source.css, '**/*.css')... only the first argument is forwarded to path.resolve() resulting in the whole folder being watched instead of just *.css files. This triggers an infinite change loop when combined with SASS or LESS :)

This comment has been minimized.

Copy link
@bmuenzenmeyer

bmuenzenmeyer Nov 3, 2016

Author Member

gah. thanks for letting me know. i am counting down the days to when most of this edition logic is in core and not here

}

/******************************************************
* COPY TASKS - stream assets from source to destination
******************************************************/
// JS copy
gulp.task('pl-copy:js', function(){
return gulp.src('**/*.js', {cwd: path.resolve(paths().source.js)} )
.pipe(gulp.dest(path.resolve(paths().public.js)));
return gulp.src('**/*.js', {cwd: resolvePath(paths().source.js)} )
.pipe(gulp.dest(resolvePath(paths().public.js)));
});

// Images copy
gulp.task('pl-copy:img', function(){
return gulp.src('**/*.*',{cwd: path.resolve(paths().source.images)} )
.pipe(gulp.dest(path.resolve(paths().public.images)));
return gulp.src('**/*.*',{cwd: resolvePath(paths().source.images)} )
.pipe(gulp.dest(resolvePath(paths().public.images)));
});

// Favicon copy
gulp.task('pl-copy:favicon', function(){
return gulp.src('favicon.ico', {cwd: path.resolve(paths().source.root)} )
.pipe(gulp.dest(path.resolve(paths().public.root)));
return gulp.src('favicon.ico', {cwd: resolvePath(paths().source.root)} )
.pipe(gulp.dest(resolvePath(paths().public.root)));
});

// Fonts copy
gulp.task('pl-copy:font', function(){
return gulp.src('*', {cwd: path.resolve(paths().source.fonts)})
.pipe(gulp.dest(path.resolve(paths().public.fonts)));
return gulp.src('*', {cwd: resolvePath(paths().source.fonts)})
.pipe(gulp.dest(resolvePath(paths().public.fonts)));
});

// CSS Copy
gulp.task('pl-copy:css', function(){
return gulp.src(path.resolve(paths().source.css, '*.css'))
.pipe(gulp.dest(path.resolve(paths().public.css)))
return gulp.src(resolvePath(paths().source.css, '*.css'))
.pipe(gulp.dest(resolvePath(paths().public.css)))
.pipe(browserSync.stream());
});

// Styleguide Copy everything but css
gulp.task('pl-copy:styleguide', function(){
return gulp.src(path.resolve(paths().source.styleguide, '**/!(*.css)'))
.pipe(gulp.dest(path.resolve(paths().public.root)))
return gulp.src(resolvePath(paths().source.styleguide, '**/!(*.css)'))
.pipe(gulp.dest(resolvePath(paths().public.root)))
.pipe(browserSync.stream());
});

// Styleguide Copy and flatten css
gulp.task('pl-copy:styleguide-css', function(){
return gulp.src(path.resolve(paths().source.styleguide, '**/*.css'))
return gulp.src(resolvePath(paths().source.styleguide, '**/*.css'))
.pipe(gulp.dest(function(file){
//flatten anything inside the styleguide into a single output dir per http://stackoverflow.com/a/34317320/1790362
file.path = path.join(file.base, path.basename(file.path));
return path.resolve(path.join(paths().public.styleguide, 'css'));
return resolvePath(path.join(paths().public.styleguide, 'css'));
}))
.pipe(browserSync.stream());
});
Expand Down Expand Up @@ -122,6 +126,11 @@ gulp.task('patternlab:build', gulp.series('pl-assets', build, function(done){
done();
}));

gulp.task('patternlab:installplugin', function (done) {
patternlab.installplugin(argv.plugin);
done();
});

/******************************************************
* SERVER AND WATCH TASKS
******************************************************/
Expand All @@ -132,7 +141,7 @@ function getSupportedTemplateExtensions() {
}
function getTemplateWatches() {
return getSupportedTemplateExtensions().map(function (dotExtension) {
return path.resolve(paths().source.patterns, '**/*' + dotExtension);
return resolvePath(paths().source.patterns, '**/*' + dotExtension);
});
}

Expand All @@ -145,17 +154,17 @@ function reloadCSS() {
}

function watch() {
gulp.watch(path.resolve(paths().source.css, '**/*.css'), { awaitWriteFinish: true }).on('change', gulp.series('pl-copy:css', reloadCSS));
gulp.watch(path.resolve(paths().source.styleguide, '**/*.*'), { awaitWriteFinish: true }).on('change', gulp.series('pl-copy:styleguide', 'pl-copy:styleguide-css', reloadCSS));
gulp.watch(resolvePath(paths().source.css, '**/*.css'), { awaitWriteFinish: true }).on('change', gulp.series('pl-copy:css', reloadCSS));
gulp.watch(resolvePath(paths().source.styleguide, '**/*.*'), { awaitWriteFinish: true }).on('change', gulp.series('pl-copy:styleguide', 'pl-copy:styleguide-css', reloadCSS));

var patternWatches = [
path.resolve(paths().source.patterns, '**/*.json'),
path.resolve(paths().source.patterns, '**/*.md'),
path.resolve(paths().source.data, '*.json'),
path.resolve(paths().source.fonts + '/*'),
path.resolve(paths().source.images + '/*'),
path.resolve(paths().source.meta, '*'),
path.resolve(paths().source.annotations + '/*')
resolvePath(paths().source.patterns, '**/*.json'),
resolvePath(paths().source.patterns, '**/*.md'),
resolvePath(paths().source.data, '*.json'),
resolvePath(paths().source.fonts + '/*'),
resolvePath(paths().source.images + '/*'),
resolvePath(paths().source.meta, '*'),
resolvePath(paths().source.annotations + '/*')
].concat(getTemplateWatches());

gulp.watch(patternWatches, { awaitWriteFinish: true }).on('change', gulp.series(build, reload));
Expand All @@ -164,7 +173,7 @@ function watch() {
gulp.task('patternlab:connect', gulp.series(function(done) {
browserSync.init({
server: {
baseDir: path.resolve(paths().public.root)
baseDir: resolvePath(paths().public.root)
},
snippetOptions: {
// Ignore all HTML files within the templates folder
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "edition-node-gulp",
"description": "The gulp wrapper around patternlab-node core, providing tasks to interact with the core library and move supporting frontend assets.",
"version": "1.3.2",
"version": "1.3.3",
"dependencies": {
"browser-sync": "^2.0.0",
"gulp": "gulpjs/gulp#4.0",
Expand Down

0 comments on commit 649ab26

Please sign in to comment.