From 5ba442249c498e22ef69bc2f96bc3bfe6fd4051e Mon Sep 17 00:00:00 2001 From: KJ Date: Wed, 16 Nov 2016 10:11:56 -0800 Subject: [PATCH] Improving checks for module.exports support --- templates/returnExportsGlobal.hbs | 4 ++-- templates/umd+rails.hbs | 4 ++-- templates/umd.hbs | 2 +- templates/unit.hbs | 2 +- 4 files changed, 6 insertions(+), 6 deletions(-) diff --git a/templates/returnExportsGlobal.hbs b/templates/returnExportsGlobal.hbs index ba29da9..b528d0e 100644 --- a/templates/returnExportsGlobal.hbs +++ b/templates/returnExportsGlobal.hbs @@ -22,7 +22,7 @@ define({{#if amdModuleId}}'{{amdModuleId}}', {{/if}}[{{{amdDependencies.wrapped}}}], function ({{dependencies}}) { return ({{#if globalAlias}} root['{{{globalAlias}}}'] = {{/if}}factory({{dependencies}})); }); - } else if (typeof exports === 'object') { + } else if (typeof module === 'object' && module.exports) { {{!-- Node. Does not work with strict CommonJS, but only CommonJS-like enviroments that support module.exports, @@ -33,7 +33,7 @@ {{! FIX FOR BROWSERIFY: Set global alias if we in browserify. }} {{#if globalAlias}} - if(typeof window !== "undefined"){ + if(typeof window !== 'undefined'){ window['{{{globalAlias}}}'] = module_exports; } {{/if}} diff --git a/templates/umd+rails.hbs b/templates/umd+rails.hbs index 487c7ea..512478d 100644 --- a/templates/umd+rails.hbs +++ b/templates/umd+rails.hbs @@ -2,12 +2,12 @@ (function(factory) { /* jshint undef: true */ - if (typeof define === "function" && define.amd) { + if (typeof define === 'function' && define.amd) { define({{#if amdModuleId}}'{{amdModuleId}}', {{/if}}[ {{{amdDependencies.wrapped}}} ], factory); } - else if (typeof module !== "undefined" && module.exports) { + else if (typeof module === 'object' && module.exports) { module.exports = factory( {{{cjsDependencies.wrapped}}}); } diff --git a/templates/umd.hbs b/templates/umd.hbs index 3a70050..7d954a8 100644 --- a/templates/umd.hbs +++ b/templates/umd.hbs @@ -4,7 +4,7 @@ define({{#if amdModuleId}}'{{amdModuleId}}', {{/if}}[{{{amdDependencies.wrapped}}}], function ({{{amdDependencies.params}}}) { return ({{#if objectToExport}}root['{{{objectToExport}}}'] = {{/if}}factory({{{amdDependencies.params}}})); }); - } else if (typeof exports === 'object') { + } else if (typeof module === 'object' && module.exports) { // Node. Does not work with strict CommonJS, but // only CommonJS-like environments that support module.exports, // like Node. diff --git a/templates/unit.hbs b/templates/unit.hbs index e6f6092..6b51c33 100644 --- a/templates/unit.hbs +++ b/templates/unit.hbs @@ -1,6 +1,6 @@ {{! UMD template that can be useful to wrap standalone CommonJS/Node modules}} (function(root, factory) { - if(typeof exports === 'object') { + if(typeof module === 'object' && module.exports) { module.exports = factory({{#if cjsDependencies.wrapped}}{{{cjsDependencies.wrapped}}}, {{/if}}require, exports, module); } else if(typeof define === 'function' && define.amd) {