I have installed the grunt task grunt-contrib-copy
. I embedd it in my Gruntfile.js
and load the task via grunt.loadNpmTasks(\'grunt-contrib-c
If you have the liberty to change to a different Grunt task:
There is also https://github.com/clavery/grunt-copy-to which has an explicit "ignore" option to specify files and directories to omit. The README in Github shows an example configuration including ignore options.
It works a bit different from the regular copy as it honours the modification times. But that might actually be welcome (it was in my case).
From the README:
Like grunt-contrib-copy but only copies files that are newer and maintains modified times for copied files. Useful for creating build directories that can be later synced using tools that rely on file modified times.
(I'm only a user of that project (at least so far).)
Found the solution:
There is no need for these lines:
files: [
{src: ['.conf1', '.conf2', './config.js'], dest: 'output/toolkit/', filter: 'isFile'},
{src: ['./css/**/*', './img/**/*', './js/**/*', './release/**/*', './lib/**/*', './locale/**/*'], dest: 'output/toolkit/'},
{expand: true, cwd: './', src: ['**'], dest: 'output/'}
]
because {expand: true, cwd: './', src: ['**'], dest: 'output/'}
is a new copy step, copying all files from ./
to output
. Which is for me not needed, because the above lines are already copying the required files to output/toolkit
.
So the following two lines does the job. No need for options or anything else. To keep out the *.less
files '!**/*.less'
does the job.
files: [
{src: ['.conf1', '.conf2', 'config.js'], dest: 'output/toolkit/', filter: 'isFile'},
{src: ['css/**', 'img/**', 'js/**', 'release/**', 'lib/**', 'locale/**', '!**/*.less'], dest: 'output/toolkit/'}
]
I wanted to exclude all .gz files in my copy and this options did the job for all folders
{
expand: true,
cwd: './build/www/',
src: [ '**', '!**/*.gz' ],
dest: './mydDest'
}
So may be try !**/*.less, !gruntfile.js
(no parens)
I reckon this should do it. Not need for /**/*
. /**
covers all files in path and its subdirs
{src: ['./css/**', './img/**', './js/**', './release/**', './lib/**', './locale/**'], dest: 'output/toolkit/'},
{expand: true, cwd: './', src: ['**'], dest: 'output/'}
Assuming that 'Gruntfile.js' is in root directory, the last line in your copy options is configuring it to copy everything in root to 'output/'.
If this is intended, add '!Gruntfile.js' to your array of src file paths.
{
expand: true,
cwd: './',
src: ['**'], // ex. src: ['**', '!Gruntfile.js'],
dest: 'output/'
}
Refer to these solutions from this thread and original thread