Update eslint config

This commit is contained in:
ismay 2015-08-06 17:04:12 +02:00
parent 1978ef4c62
commit 222a27de59
5 changed files with 121 additions and 35 deletions

View file

@ -8,7 +8,6 @@ rules:
quotes: [2, "single", "avoid-escape"]
# Relax rules to allow current code-style
curly: [2, "multi"]
new-cap: 0
no-shadow: 0
no-unused-vars: 0

View file

@ -1,4 +1,4 @@
eslint=node_modules/.bin/eslint lib/index.js test/index.js
eslint=node_modules/.bin/eslint lib/**/*.js test/index.js
mocha=node_modules/.bin/mocha --reporter spec --harmony-generators
node_modules: package.json

34
lib/helpers/check.js Normal file
View file

@ -0,0 +1,34 @@
/**
* Dependencies
*/
var match = require('multimatch');
var utf8 = require('is-utf8');
/**
* Expose `check`
*/
module.exports = check;
/**
* Helper for checking whether a file should be processed.
*
* @param {Object} files
* @param {String} file
* @param {String} pattern
* @return {Boolean}
*/
function check(files, file, pattern){
var data = files[file];
// Don't process binary files
if (!utf8(data.contents)) {
return false;
}
// Only process files that match the pattern (if there is a pattern)
if (pattern && !match(file, pattern)[0]) {
return false;
}
return true;
}

View file

@ -1,21 +1,27 @@
/**
* Dependencies
*/
var consolidate = require('consolidate');
var debug = require('debug')('metalsmith-layouts');
var each = require('async').each;
var extend = require('extend');
var match = require('multimatch');
var omit = require('lodash.omit');
var utf8 = require('is-utf8');
/**
* Helpers
*/
var check = require('./helpers/check');
/**
* Expose `plugin`.
*/
module.exports = plugin;
/**
* Settings.
* Settings
*
* Options supported by metalsmith-layouts
*/
var settings = ['engine', 'directory', 'pattern', 'default'];
/**
@ -30,56 +36,83 @@ var settings = ['engine', 'directory', 'pattern', 'default'];
*/
function plugin(opts){
/**
* Init
*/
opts = opts || {};
if (typeof opts === 'string') opts = { engine: opts };
if (!opts.engine) throw new Error('"engine" option required');
// Accept string option to specify the engine
if (typeof opts === 'string') {
opts = {engine: opts};
}
// An engine should be specified
if (!opts.engine) {
throw new Error('"engine" option required');
}
// Throw an error for unsupported engines or typos
if (!consolidate[opts.engine]) {
throw new Error('Unknown template engine: "' + opts.engine + '"');
}
// Map options to local variables
var engine = opts.engine;
var dir = opts.directory || 'layouts';
var pattern = opts.pattern;
var def = opts.default;
// Move all unrecognised options to params
var params = omit(opts, settings);
// Throw an error for unsupported engines or typos
if (!consolidate[engine]) throw new Error('Unknown template engine: "' + engine + '"');
/**
* Main plugin function
*/
return function(files, metalsmith, done){
var metadata = metalsmith.metadata();
var matches = {};
function check(file){
var data = files[file];
var lyt = data.layout || def;
if (!utf8(data.contents)) return false;
if (pattern && !match(file, pattern)[0]) return false;
if (!lyt) return false;
return true;
}
/**
* Stringify files that pass the check, and store in matches
*/
Object.keys(files).forEach(function(file){
if (!check(file)) return;
if (!check(files, file, pattern)) {
return;
}
debug('stringifying file: %s', file);
var data = files[file];
data.contents = data.contents.toString();
matches[file] = data;
});
each(Object.keys(matches), convert, done);
/**
* Render files
*/
function convert(file, done){
debug('converting file: %s', file);
var data = files[file];
// Deep clone params (by passing 'true')
var clonedParams = extend(true, {}, params);
var clone = extend({}, clonedParams, metadata, data);
var str = metalsmith.path(dir, data.layout || def);
var render = consolidate[engine];
render(str, clone, function(err, str){
if (err) return done(err);
if (err) {
return done(err);
}
data.contents = new Buffer(str);
debug('converted file: %s', file);
done();
});
}
/**
* Render all matched files
*/
each(Object.keys(matches), convert, done);
};
}

View file

@ -8,7 +8,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/basic')
.use(layouts({ engine: 'swig' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/basic/expected', 'test/fixtures/basic/build');
done();
});
@ -18,7 +20,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/basic')
.use(layouts('swig'))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/basic/expected', 'test/fixtures/basic/build');
done();
});
@ -28,7 +32,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/pattern')
.use(layouts({ engine: 'swig', pattern: '*.md' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/pattern/expected', 'test/fixtures/pattern/build');
done();
});
@ -38,7 +44,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/default')
.use(layouts({ engine: 'swig', pattern: '*.md', default: 'default.html' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/pattern/expected', 'test/fixtures/pattern/build');
done();
});
@ -48,7 +56,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/directory')
.use(layouts({ engine: 'swig', directory: 'templates' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/directory/expected', 'test/fixtures/directory/build');
done();
});
@ -59,7 +69,9 @@ describe('metalsmith-layouts', function(){
.metadata({ title: 'Global Title' })
.use(layouts({ engine: 'swig' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/metadata/expected', 'test/fixtures/metadata/build');
done();
});
@ -69,7 +81,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/binary')
.use(layouts({ engine: 'swig' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/binary/expected', 'test/fixtures/binary/build');
done();
});
@ -79,7 +93,9 @@ describe('metalsmith-layouts', function(){
Metalsmith('test/fixtures/include')
.use(layouts({ engine: 'swig' }))
.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/include/expected', 'test/fixtures/include/build');
done();
});
@ -93,9 +109,13 @@ describe('metalsmith-layouts', function(){
}));
instance.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
instance.build(function(err){
if (err) return done(err);
if (err) {
return done(err);
}
equal('test/fixtures/partials/expected', 'test/fixtures/partials/build');
done();
});