aboutsummaryrefslogtreecommitdiff
path: root/node_modules/rechoir/index.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2016-10-10 03:43:44 +0200
committerFlorian Dold <florian.dold@gmail.com>2016-10-10 03:43:44 +0200
commitabd94a7f5a50f43c797a11b53549ae48fff667c3 (patch)
treeab8ed457f65cdd72e13e0571d2975729428f1551 /node_modules/rechoir/index.js
parenta0247c6a3fd6a09a41a7e35a3441324c4dcb58be (diff)
downloadwallet-core-abd94a7f5a50f43c797a11b53549ae48fff667c3.tar.xz
add node_modules to address #4364
Diffstat (limited to 'node_modules/rechoir/index.js')
-rw-r--r--node_modules/rechoir/index.js59
1 files changed, 59 insertions, 0 deletions
diff --git a/node_modules/rechoir/index.js b/node_modules/rechoir/index.js
new file mode 100644
index 000000000..0c36d0586
--- /dev/null
+++ b/node_modules/rechoir/index.js
@@ -0,0 +1,59 @@
+const path = require('path');
+
+const extension = require('./lib/extension');
+const normalize = require('./lib/normalize');
+const register = require('./lib/register');
+
+exports.prepare = function (extensions, filepath, cwd, nothrow) {
+ var option, attempt;
+ var attempts = [];
+ var err;
+ var onlyErrors = false;
+ var ext = extension(filepath);
+ if (Object.keys(require.extensions).indexOf(ext) !== -1) {
+ return true;
+ }
+ var config = normalize(extensions[ext]);
+ if (!config) {
+ if (nothrow) {
+ return;
+ } else {
+ throw new Error('No module loader found for "'+ext+'".');
+ }
+ }
+ if (!cwd) {
+ cwd = path.dirname(path.resolve(filepath));
+ }
+ if (!Array.isArray(config)) {
+ config = [config];
+ }
+ for (var i in config) {
+ option = config[i];
+ attempt = register(cwd, option.module, option.register);
+ error = (attempt instanceof Error) ? attempt : null;
+ if (error) {
+ attempt = null;
+ }
+ attempts.push({
+ moduleName: option.module,
+ module: attempt,
+ error: error
+ });
+ if (!error) {
+ onlyErrors = false;
+ break;
+ } else {
+ onlyErrors = true;
+ }
+ }
+ if (onlyErrors) {
+ err = new Error('Unable to use specified module loaders for "'+ext+'".');
+ err.failures = attempts;
+ if (nothrow) {
+ return err;
+ } else {
+ throw err;
+ }
+ }
+ return attempts;
+};