From e29480e19036e92b56d54eecc519f4a32c7e74e9 Mon Sep 17 00:00:00 2001 From: Brian Muenzenmeyer Date: Wed, 17 Aug 2016 07:33:44 -0500 Subject: [PATCH] Better handle missing outputfileSuffixes closes #433 --- core/lib/patternlab.js | 44 ++++++++++++++++++++++++++---------------- package.json | 2 +- 2 files changed, 28 insertions(+), 18 deletions(-) diff --git a/core/lib/patternlab.js b/core/lib/patternlab.js index 9bd28a153..ddc8aaa8b 100644 --- a/core/lib/patternlab.js +++ b/core/lib/patternlab.js @@ -1,5 +1,5 @@ /* - * patternlab-node - v2.4.1 - 2016 + * patternlab-node - v2.4.2 - 2016 * * Brian Muenzenmeyer, Geoff Pursell, and the web community. * Licensed under the MIT license. @@ -13,10 +13,8 @@ var diveSync = require('diveSync'), glob = require('glob'), _ = require('lodash'), - path = require('path'); - -// GTP: these two diveSync pattern processors factored out so they can be reused -// from unit tests to reduce code dupe! + path = require('path'), + plutils = require('./utilities'); function buildPatternData(dataFilesPath, fs) { var dataFilesPath = dataFilesPath; @@ -29,6 +27,8 @@ function buildPatternData(dataFilesPath, fs) { return mergeObject; } +// GTP: these two diveSync pattern processors factored out so they can be reused +// from unit tests to reduce code dupe! function processAllPatternsIterative(pattern_assembler, patterns_dir, patternlab) { diveSync( patterns_dir, @@ -57,6 +57,23 @@ function processAllPatternsRecursive(pattern_assembler, patterns_dir, patternlab ); } +function checkConfiguration(patternlab) { + //default the output suffixes if not present + var outputFileSuffixes = { + rendered: '', + rawTemplate: '', + markupOnly: '.markup-only' + } + + if (!patternlab.config.outputFileSuffixes) { + plutils.logOrange('Configuration Object "outputFileSuffixes" not found, and defaulted to the following:'); + console.log(outputFileSuffixes); + plutils.logOrange('Since Pattern Lab Core 2.3.0 this configuration option is required. Suggest you add it to your patternlab-config.json file.'); + console.log(); + } + patternlab.config.outputFileSuffixes = _.extend(outputFileSuffixes, patternlab.config.outputFileSuffixes); +} + var patternlab_engine = function (config) { 'use strict'; @@ -66,13 +83,14 @@ var patternlab_engine = function (config) { pe = require('./pattern_exporter'), lh = require('./lineage_hunter'), ui = require('./ui_builder'), - plutils = require('./utilities'), sm = require('./starterkit_manager'), patternlab = {}; patternlab.package = fs.readJSONSync(path.resolve(__dirname, '../../package.json')); patternlab.config = config || fs.readJSONSync(path.resolve(__dirname, '../../patternlab-config.json')); + checkConfiguration(patternlab); + var paths = patternlab.config.paths; function getVersion() { @@ -335,23 +353,15 @@ var patternlab_engine = function (config) { patternLabFoot : footerPartial }); - //default the output suffixes if not present - var outputFileSuffixes = { - rendered: '', - rawTemplate: '', - markupOnly: '.markup-only' - } - outputFileSuffixes = _.extend(outputFileSuffixes, patternlab.config.outputFileSuffixes); - //write the compiled template to the public patterns directory var patternPage = headHTML + pattern.patternPartialCode + footerHTML; - fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', outputFileSuffixes.rendered + '.html'), patternPage); + fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', patternlab.config.outputFileSuffixes.rendered + '.html'), patternPage); //write the mustache file too - fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', outputFileSuffixes.rawTemplate + pattern.fileExtension), pattern.template); + fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', patternlab.config.outputFileSuffixes.rawTemplate + pattern.fileExtension), pattern.template); //write the encoded version too - fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', outputFileSuffixes.markupOnly + '.html'), pattern.patternPartialCode); + fs.outputFileSync(paths.public.patterns + pattern.patternLink.replace('.html', patternlab.config.outputFileSuffixes.markupOnly + '.html'), pattern.patternPartialCode); return true; }); diff --git a/package.json b/package.json index d34b4f519..68ae8715b 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "patternlab-node", "description": "Pattern Lab is a collection of tools to help you create atomic design systems. This is the node command line interface (CLI).", - "version": "2.4.1", + "version": "2.4.2", "main": "./core/lib/patternlab.js", "dependencies": { "diveSync": "^0.3.0",